css-loader 笔记 (局部、全局样式 webpack 配
2018-07-15 本文已影响0人
不知道的是
没配置 modules 和 localIdentName 时
// webpack.config.dev.js
{
loader: require.resolve('css-loader'),
options: {
importLoaders: 1,
},
},
/* ./src/components/Greeting/index.css */
:local(.red) { color: red; }
/*
* When declaring a local classname you can
* compose a local class from another local classname.
* <https://github.com/webpack-contrib/css-loader>
*/
:local(.green) {
composes: red;
color: green;
}
:local(.btnGoodbye) {
composes: bye hi from '../Goodbye/index.css';
color: crimson;
}
:local(h2) {
color: chocolate;
}
.blue {
color: blue;
}
/* styles.css */
.App {
font-family: sans-serif;
text-align: center;
}
data:image/s3,"s3://crabby-images/08930/08930398d7cb7c00fdbdb4b6ad38ae359cfc5695" alt=""
配置了 modules 和 localIdentName 时
{
loader: require.resolve('css-loader'),
options: {
importLoaders: 1,
modules: true,
localIdentName: '[path][name]__[local]--[hash:base64:5]',
camelCase: true // Export Classnames in CamelCase
},
},
/* ./src/components/Greeting/index.css */
:local(.red) { color: red; }
/*
* When declaring a local classname you can
* compose a local class from another local classname.
* <https://github.com/webpack-contrib/css-loader>
*/
:local(.green) {
composes: red;
color: green;
}
:local(.btnGoodbye) {
composes: bye hi from '../Goodbye/index.css';
color: crimson;
}
:local(h2) {
color: chocolate;
}
/* 全局样式需要 + :global,否则不起作用 */
:global(.blue) {
color: blue;
}
/* nested */
:local(.about > a:nth-last-child(1)) {
float: right;
margin-right: 0;
}
/* styles.css */
:global(.App) {
font-family: sans-serif;
text-align: center;
}
data:image/s3,"s3://crabby-images/f0901/f090102a52570dd0cad4e3882bccdce505b4c4b2" alt=""
data:image/s3,"s3://crabby-images/bc811/bc8117db0aa087efedcfad0e14a3024e60cf65e4" alt=""
camelCase
data:image/s3,"s3://crabby-images/e0cdd/e0cdda60ae7dcb75ecec860f0b6dee378a8b36a3" alt=""
data:image/s3,"s3://crabby-images/b4873/b48738fe6060b8cf25a0ab088fccd40bd0459a70" alt=""
data:image/s3,"s3://crabby-images/67b06/67b06f6abb17b76e19f97bb3f0c0219459cff4be" alt=""
其它:
/* :local 对“标签选择器”不起作用,标签选择器定义的样式仍旧是全局的 */
:local(ul > li) {
height: 1.4rem;
color: #555;
line-height: 1.4rem;
text-align: left;
border-bottom: 1px solid #CCC;
}
codesandbox 不起作用
data:image/s3,"s3://crabby-images/e4ca7/e4ca7e4269618f7ff5ad69bfb2e9533e339392fb" alt=""
本地起作用
data:image/s3,"s3://crabby-images/931d6/931d6d7e47e2bc0fbd499ea8c6e3b0c2c3b2ff54" alt=""
codesandbox vanilla parcel
data:image/s3,"s3://crabby-images/ec430/ec430b319c81b184f5ab8b298ea0bc54f4b0cd81" alt=""
data:image/s3,"s3://crabby-images/80e80/80e80710b06484939d80f87d099543eab2bcde08" alt=""
data:image/s3,"s3://crabby-images/fcf4f/fcf4fe847862e537939a0dc020834c248a7b1e54" alt=""
data:image/s3,"s3://crabby-images/03521/0352136d2c6682cc4840d7ec5c0aa6b4451036eb" alt=""
应使用 className
data:image/s3,"s3://crabby-images/cfe39/cfe394f444c610cf747f97dd4e1771f6a4e4de60" alt=""
仓库地址:
https://github.com/MonguDykrai/React-LocalStyle-DEMO
https://codesandbox.io/s/yq7lxrvo49