动态设置 CSS 样式时,如何写入各浏览器兼容性样式?

简介: 动态设置 CSS 样式时,如何写入各浏览器兼容性样式?

前言


我们知道,通过原生 JS 脚本动态设置内联样式的方式有:

<!-- 省略一万行代码... -->
<style>
  @keyframes slidein {
    from {
      transform: scaleX(0);
    }
    to {
      transform: scaleX(1);
    }
  }
</style>
<div id="app">关关雎鸠,在河之洲...</div>

const element = document.getElementById('app')
// 1️⃣ 方式一(泛指一类,下同)
element.style.fontSize = '30px'
// 2️⃣ 方式二
element.style.setProperty('font-size', '30px')
// 3️⃣ 方式三(请注意,这可能会抹掉其他 CSS 属性的哦)
element.style.cssText = 'color: 30px'
element.setAttribute('style', 'color: 30px')


但是,这里面有一些限制在里面...


  • 方式一:无法设置权重 !important,若带上权重,其属性值也不会生效。
  • 方式二:无法设置带 -webkit--moz--o--ms- 等各浏览器厂商实验性或非标准的 CSS 属性,如 -webkit-animation
  • 方式三:可以处理以上两种方式无法实现的功能。另外,要获取内联样式中某个 CSS 属性是否含有 !important 权重,也需借助 element.style.cssText 方可获取。


正文


验证


方式一

// 对比一
element.style.fontSize = '30px' // 有效
element.style.fontSize = '50px !important' // 无效,除了不会设置权重之外,50px 也不会生效哦。
// 对比二
// 假设 element 元素本身就含有 font-size: 30px !important 的内联样式
element.style.fontSize // 输出 "30px",注意是不含权重的
element.style.fontSize = '50px' // 这是有效的,同时权重也会丢失
element.style.fontSize = '50px !important' // 无效
// 对比三
element.style.animation = '3s slidein' // 有效
element.style.webkitAnimation = '3s slidein' // 有效,但是最终会变成 animation: "3s slidein",而不是 -webkit-animation: "3s slidein"
element.style.MozAnimation = '3s slidein' // 有效,但同上


小结:


  • 通过 element.style.fontSize 这一类形式读写内联样式时,都无法读取写入权重,而且需要注意的是 element.style.fontSize = '30 !important' 并不会被写入哦。
  • 通过 element.style.webkitAnimation = '3s slidein'element.style.MozAnimation = '3s slidein' 形式写入包含浏览器厂商特性的 CSS 属性时,将会被处理成标准的 CSS 属性。例如:-webkit-animation 变为 animation,跟预期结果是有出入的。
  • 另外,请注意写法。标准 CSS 属性是小驼峰形式,而带浏览器厂商特性的 CSS 属性,则可能不是小驼峰命名规则。例如:webkitXxxMozXxx 首字母大小写就不一样。

请注意,以上示例仅列举了个别属性,但其实是泛指同一类。


方式二

// 对比一
element.style.setProperty('font-size', '30px') // 有效
element.style.setProperty('font-size', '30px', 'important') // 有效(可设置权重,但请注意是不含 ! 的)
// 对比二
element.style.setProperty('-webkit-animation', '3s slidein') // 有效,可会变为 animation。同方式一
element.style.setProperty('-moz-animation', '3s slidein') // 有效,可会变为 animation。同方式一


小结:


  • 可通过 CSSStyleDeclaration.setProperty(propertyName, value, priority) 方法,并传递 important(请注意是不含 ! 的) 给 priority 参数,来设置 CSS 优先级。


方式三


这种方式,除了可以实现以上功能之外,最重要的是,它可以设置 -webkit--moz--o--ms- 等实验性或非标准的 CSS 属性。

element.style.cssText = 'font-size: 30px; -webkit-animation: 3s slidein' // 有效
element.setProperty('style', 'font-size: 30px; -webkit-animation: 3s slidein') // 有效

⚠️ 尽管以上两种方式都能实现,但注意可能会抹掉当前元素的其他 CSS 属性,可利用类型以下的方式处理。

const { cssText } = element.style
element.style.cssText = `${cssText} font-size: 30px; color: #f00`


References



The end.

目录
相关文章
|
6天前
|
前端开发
前端基础(四)_CSS层叠样式表_什么是css_css样式的引入方式_样式表的优先级_样式选择器
本文详细介绍了CSS(层叠样式表)的基本概念、语法规则、引入方式、样式表的优先级和样式选择器。文章解释了CSS的作用,展示了如何在HTML中通过行内样式、内部样式和外部样式引入CSS,讨论了不同CSS选择器的优先级和如何确定最终的样式应用。此外,还强调了使用`!important`规则时的优先级高于行内样式。
28 1
|
19天前
|
缓存 前端开发
css内部样式和外部样式的性能比较和使用规范
CSS 的内部样式和外部样式各有优缺点,适用于不同场景。
|
10天前
|
JavaScript 前端开发
jQuery - 获取并设置 CSS 类
jQuery - 获取并设置 CSS 类
10 1
|
14天前
|
前端开发
css <样式一>
css <样式一>
14 1
|
24天前
|
JavaScript 前端开发
jQuery - 获取并设置 CSS 类
jQuery - 获取并设置 CSS 类
21 5
|
1月前
|
设计模式 移动开发 前端开发
CSS内联样式的使用,吐血整理
CSS内联样式的使用,吐血整理
35 6
|
8天前
|
前端开发
Vue3基础(十ba)___在css中使用props或者计算属性的变量,来实现动态样式
本文介绍了如何在Vue3中通过CSS变量和props或计算属性来实现动态样式。
12 0
|
2月前
|
XML 前端开发 数据格式
CSS常用样式及示例
CSS常用样式及示例
|
2月前
|
前端开发 Java UED
JSF 面向组件开发究竟藏着何种奥秘?带你探寻可复用 UI 组件设计的神秘之路
【8月更文挑战第31天】在现代软件开发中,高效与可维护性至关重要。JavaServer Faces(JSF)框架通过其面向组件的开发模式,提供了构建复杂用户界面的强大工具,特别适用于设计可复用的 UI 组件。通过合理设计组件的功能与外观,可以显著提高开发效率并降低维护成本。本文以一个具体的 `MessageComponent` 示例展示了如何创建可复用的 JSF 组件,并介绍了如何在 JSF 页面中使用这些组件。结合其他技术如 PrimeFaces 和 Bootstrap,可以进一步丰富组件库,提升用户体验。
44 0
|
2月前
|
前端开发 JavaScript 开发者
【前端革新力】React与CSS-in-JS完美邂逅:从styled-components到emotion,全面解析样式管理新趋势的实战应用与优势剖析!
【8月更文挑战第31天】CSS-in-JS 作为一种新兴的样式管理方式,近年来在前端社区受到广泛关注。它将样式嵌入 JavaScript,实现了样式与逻辑的高度耦合,提升了开发效率并解决了全局样式污染等问题。本文通过具体代码示例,探讨 CSS-in-JS 在 React 开发中的应用,并分享实践心得。首先介绍了 CSS-in-JS 的基本概念,然后详细展示了如何使用 styled-components 和 emotion 这两个流行库创建样式化组件。
38 0