详解vue 中 scoped 样式作用域的规则


Posted in Javascript onSeptember 14, 2020

哈喽!大家好!我是木瓜太香,今天我们来聊一个 vue 的样式作用域的问题,通常我们开发项目的时候是要在 style 上加上 scoped 来起到规定组件作用域的效果的,所以了解他们的规则也是很有必要的,可以让你更清晰的了解你的项目样式是怎么运作的。

先来说说实现方式

vue中的样式作用域是通过属性选择器来实现的,例如同样一个类名,我们是通过 .类名[属性名] 来做区分的,我们这里主要是要搞清楚这里的属性名是怎么分配的。

样式作用域规则

接下来我们分情况来说一下样式作用域:

对于有样式作用域的组件,该组件的所有后代元素都会具备一个相同的作用域属性,而该组件的内部的根元素除了具备当前组件作用域属性也会具备其父级组件的作用域,当然如果父级没有作用域则不具备对于没有样式作用域的组件,如果父组件是有作用域的,那么该组件只有根元素会继承父组价的作用域,其后代的元素不会有作用域对于处在同一层次的组件,其作用域是相同的,从下一代开始才会有所区别特别要注意的是对于组件的复用,在当前项目,不管是什么层级,复用的组件作用域都相同

样式作用域图示

详解vue 中 scoped 样式作用域的规则

实际应用效果

有了基本的样式作用域知识储备之后,接下来我们来看一下 vue 最终会怎么将这些样式作用域应用到选择器的。

对于单个的选择器 .box[data-v-abc] 对于复合选择器:.box a[data-v-abc] .box[data-v-abc],.wrap[data-v-abc] .box > div[data-v-abc]

根据上面的知识储备,我们就知道,如果组件都只被引用一次,通常是不存在样式干扰的,但是如果一个组件在一个页面中复用多次,依然是有样式干扰的可能。

PS:下面看下vue中scoped的原理

vue中scoped的作用:

实现组件的私有化, 当前style属性只属于当前模块.

但是当我们使用公共组件的时候会造成很多困难.

scoped的实现原理:

在DOM结构中可以发现,vue通过在DOM结构以及css样式上加了唯一标记,达到样式私有化,不污染全局的作用,

详解vue 中 scoped 样式作用域的规则

详解vue 中 scoped 样式作用域的规则

可以看出,加上scoped后的组件里的会多 data-v-5db9451a 属性, css样式中可以看出;

1. 给DOM节点加一个不重复属性 data-v-5db9451a 标志唯一性.

2. 使每个样式选择器后添加类似于"不重复属性"的字段, 类似于作用域的作用,不影响全局.

3. 如果组件内部还有组件,只会给最外层的组件里的标签加上唯一属性字段,不影响组件内部引用的组件.

谨慎使用:

1. 父组件无scoped属性,子组件带有scoped,父组件是无法操作子组件的.

2.父组件有scoped属性,子组件无scoped.父组件也无法设置子组件样式.因为父组件的所有标签都会带有data-v-5db9451a唯一标志,但子组件不会带有这个唯一标志属性.

3.父子组建都有,同理也无法设置样式,更改起来增加代码量.

总结

到此这篇关于vue 中 scoped 样式作用域的规则的文章就介绍到这了,更多相关vue scoped 样式作用域内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
javascript脚本编程解决考试分数统计问题
Oct 18 Javascript
cnblogs 代码高亮显示后的代码复制问题解决实现代码
Dec 14 Javascript
Extjs 继承Ext.data.Store不起作用原因分析及解决
Apr 15 Javascript
javascript实现textarea中tab键的缩排处理方法
Jun 26 Javascript
Node.js中 __dirname 的使用介绍
Jun 19 Javascript
Underscore之Array_动力节点Java学院整理
Jul 10 Javascript
详解redux异步操作实践
Aug 15 Javascript
浅析js中mvvm模式实现的原理
Oct 06 Javascript
vue移动端使用appClound拉起支付宝支付的实现方法
Nov 21 Javascript
使用pkg打包ThinkJS项目的方法步骤
Dec 30 Javascript
微信小程序收藏功能的实现代码
Jun 19 Javascript
vue+vant实现购物车全选和反选功能
Nov 17 Vue.js
详解JavaScript 高阶函数
Sep 14 #Javascript
vue实现简单计算商品价格
Sep 14 #Javascript
Vue中添加滚动事件设置的方法详解
Sep 14 #Javascript
JavaScript位置参数实现原理及过程解析
Sep 14 #Javascript
swiper自定义分页器的样式
Sep 14 #Javascript
js+canvas实现转盘效果(两个版本)
Sep 13 #Javascript
js实现3D粒子酷炫动态旋转特效
Sep 13 #Javascript
You might like
建立动态的WML站点(一)
2006/10/09 PHP
php中关于codeigniter的xmlrpc的类在进行数据交换时的类型问题
2011/07/03 PHP
深入Nginx + PHP 缓存详解
2013/07/11 PHP
php等比例缩放图片及剪切图片代码分享
2016/02/13 PHP
PHP中addslashes与mysql_escape_string的区别分析
2016/04/25 PHP
微信封装的调用微信签名包的类库
2017/06/08 PHP
Yii 框架入口脚本示例分析
2020/05/19 PHP
用js怎么把&字符换成"&amp:"
2006/10/19 Javascript
javascript入门·动态的时钟,显示完整的一些方法,新年倒计时
2007/10/01 Javascript
在网页里看flash的trace数据的js类
2009/01/10 Javascript
JQuery 插件模板 制作jquery插件的朋友可以参考下
2010/03/17 Javascript
jQuery 表单验证扩展(四)
2010/10/20 Javascript
js对象的比较
2011/02/26 Javascript
js substr、substring和slice使用说明小记
2011/09/15 Javascript
Ext JS 4官方文档之三 -- 类体系概述与实践
2012/12/16 Javascript
全面了解构造函数继承关键apply call
2016/07/26 Javascript
jQuery实现将div中滚动条滚动到指定位置的方法
2016/08/10 Javascript
AngularJS中的DOM操作用法分析
2016/11/04 Javascript
微信小程序 动画的简单实例
2017/10/12 Javascript
javascript自定义事件功能与用法实例分析
2017/11/08 Javascript
了解JavaScript函数中的默认参数
2019/05/30 Javascript
vue-cli3+ts+webpack实现多入口多出口功能
2019/05/30 Javascript
vue v-for 使用问题整理小结
2019/08/04 Javascript
vue.js 子组件无法获取父组件store值的解决方式
2019/11/08 Javascript
React实现阿里云OSS上传文件的示例
2020/08/10 Javascript
Python类方法__init__和__del__构造、析构过程分析
2015/03/06 Python
Python多层装饰器用法实例分析
2018/02/09 Python
pip install urllib2不能安装的解决方法
2018/06/12 Python
解决Python pandas plot输出图形中显示中文乱码问题
2018/12/12 Python
深入解析python中的实例方法、类方法和静态方法
2019/03/11 Python
Python3内置函数chr和ord实现进制转换
2020/06/05 Python
HTML5在线预览PDF的示例代码
2017/09/14 HTML / CSS
后勤人员岗位职责
2013/12/17 职场文书
医药类个人求职的自我评价
2014/02/12 职场文书
仓库保管员岗位职责
2015/02/09 职场文书
基于Python实现对比Exce的工具
2022/04/07 Python