javascript – DOM替换元素上的整个样式属性(CSSStyleDeclaration)

我知道要替换单个样式,代码看起来像这样:
myDOMElement.style.height = '400px';

但是,如果我想一举完全替换整个样式对象,从而加快速度并避免重绘,该怎么办?例如,我想这样做:

//Get the computed style
var computedStyle = window.getComputedStyle(myDOMElement);

//Change some stuff in that CSsstyleDeclaration without rendering
computedStyle.height = '10px';
computedStyle.width = '20px';
computedStyle.whatever = 'something';

//Apply the entirety of computedStyle to the DOM Element,thereby only redrawing once
myDOMElement.style = computedStyle;

但是,当我运行此代码时,我的新样式才会被忽略.我该怎么做才能解决这个问题?

解决方法

你真的不想使用getComputedStyle(“myElement”),因为IE的版本不支持它.

您可以直接附加到style属性.

var myStyle = "color: #090";
document.getElementById("myElement").style.csstext += '; ' + myStyle; // to append
document.getElementById("myElement").style.csstext = myStyle; // to replace

myStyle可以包含许多css规则,因此您可以在一次重绘中获取它们.作为奖励,您可以获得内联样式的CSS特性值,它将覆盖除“!important”之外的所有内容.

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...