本篇文章给大家带来了scoped css和css module的区别的相关知识,scoped css和css module都是为了控制css的局部作用域,防止类名重复等问题,那么两者有什么区别呢,希望对大家有帮助。

scoped css和css module都是为了控制css的局部作用域,防止类名重复等问题。那么两者有什么区别呢?
1.1.解释
为所有类名重新生成类名,有效避开了css权重和类名重复的问题。css module直接替换了类名,排除了用户设置类名影响组件样式的可能性,这样就不必为了命名绞尽脑汁。
1.2实现原理
通过给样式名加hash字符串后缀的方式,实现特定作用域语境中的样式编译后的样式在全局唯一。
1.3使用方法
//webpack.base.conf.jsmodule: {
rules: [
// ... 其它规则省略
{
test: /\.css$/,
use: [
'vue-style-loader',
{
loader: 'css-loader',
options: {
// 开启 CSS Modules
modules: true,
// 自定义生成的类名
localIdentName: '[local]_[hash:base64:8]'
}
}
]
}
]
}<style module>.red {
color: red;}.bold {
font-weight: bold;}</style><template>
<p :class="$style.red">
This should be red </p></template><template>
<p>
<p :class="{ [$style.red]: isRed }">
Am I red?
</p>
<p :class="[$style.red, $style.bold]">
Red and bold </p>
</p></template><script>export default {
created () {
console.log(this.$style.red)
// -> "red_1VyoJ-uZ"
// 一个基于文件名和类名生成的标识符
}}</script>1.4使用效果
立即学习“前端免费学习笔记(深入)”;
<template>
<p :class="$style.gray">
Im gray </p></template><style module>.gray {
color: gray;}</style>编译后结果:
//编译结果<p class="gray_3FI3s6uz">Im gray</p>.gray_3FI3s6uz {
color: gray;}1.5注意点
2.1实现原理
vue通过在DOM结构以及css样式上加唯一不重复的标记,以保证唯一,达到样式私有化模块化的目的。无法完全避开css权重和类名重复的问题。
2.2使用方法
在 < style >标签添加 scoped属性
2.3使用效果
<style scoped>h1 {
color: #f00;}</style>编译后结果:
h1[data-v-4c3b6c1c] {
color: #f00;}2.4缺点
css module实际效果要比scoped较好,而且css module配置并不难,所以我更推荐css module。
(学习视频分享:css视频教程)
以上就是详细解答css作用域之scoped css和css module的区别的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号