前端工程化之:webpack3-4(css in js)

一、css in js

 css in js 的核心思想是:用一个 JS 对象来描述样式,而不是 css 样式表。

例如下面的对象就是一个用于描述样式的对象:

const styles = {
    backgroundColor: "#f40",
    color: "#fff",
    width: "400px",
    height: "500px",
    margin: "0 auto"
}

由于这种描述样式的方式根本就不存在类名,自然不会有类名冲突。

至于如何把样式应用到界面上,不是它所关心的事情,你可以用任何技术、任何框架、任何方式将它应用到界面。

 css in js 的特点:

  • 绝无冲突的可能:由于它根本不存在类名,所以绝不可能出现类名冲突;
  • 更加灵活:可以充分利用 JS 语言灵活的特点,用各种招式来处理样式;
  • 应用面更广:只要支持 js 语言,就可以支持 css in js ,因此,在一些用 JS 语言开发移动端应用的时候非常好用,因为移动端应用很有可能并不支持 css
  • 书写不便:书写样式,特别是公共样式的时候,处理起来不是很方便;
  • 在页面中增加了大量冗余内容:在页面中处理 css in js 时,往往是将样式加入到元素的 style 属性中,会大量增加元素的内联样式,并且可能会有大量重复,不易阅读最终的页面代码。

你可能感兴趣的:(前端,css,javascript)