怎么给一个 css 文件里的每个 selector 添加一个前缀 .aaa

2021-09-11 18:45:28 +08:00
 find456789

我的 css 文件如下:

h1{color:red}
div{color:red}
p{color:red}
h4{color:red}

我用 js 读取到了这个 css 文件

我想给这个 css 里的每个选择器,加一个前缀,变成这样

 .aaa  h1{color:red}
 .aaa  div{color:red}
 .aaa  p{color:red}
 .aaa  h4{color:red}

我这样做的目的是,不想破坏全局样式,只想让这些样式应用在 .aaa 这个 class 里

想问问大家, 怎么用 js 添加前缀呢?

因为 css 文件里,的 选择器 每个页面都不同, 所以 要用 js 来动态改, 我想到的方案是用 正则

但我尝试了好久, 都没有解决

特来请教大家

谢谢

1152 次点击
所在节点    问与答
7 条回复
iBugOne
2021-09-11 19:07:42 +08:00
放弃 js,用一套更阳间的 css 处理系统,比如 Sass/SCSS
xell
2021-09-11 19:41:29 +08:00
你真要这么做的话,就去找一个现成的 js 可用的 css 解析器,例如 https://www.npmjs.com/package/cssparser,然后事情就比较简单了。
troywith77
2021-09-11 20:00:28 +08:00
villivateur
2021-09-11 20:21:06 +08:00
直接用正则匹配?

大概就是
把 ^([\w\d]+{\w+:\w+})
替换成 .aaa $1
newbieRenew
2021-09-11 20:53:44 +08:00
用啥正则,直接复制丢到 scss 里 ,套一层就行了

.aaa{
h1{…}
div{…}
}
shapl
2021-09-11 23:14:35 +08:00
预处理器吖。。。scss 、less 、、、都行。
shapl
2021-09-11 23:19:08 +08:00
如果你不想依赖 npm 、不想侵入项目去改动。
我推荐你使用 vscode 的插件,Easy LESS
编辑 *.less,会在指定目录输出 *.css

```
{
"less.compile": {
"compress": false, //是否压缩
"sourceMap": false, //是否生成 map 文件,有了这个可以在调试台看到 less 行数
"out": "../css/", // 是否输出 css 文件,false 为不输出
"outExt": ".css", // 输出文件的后缀,小程序可以写'wxss'
},
}
```

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/801248

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX