详解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 相关文章推荐
js实现翻页后保持checkbox选中状态的实现方法
Nov 03 Javascript
Eval and new funciton not the same thing
Dec 27 Javascript
jquery实现顶部向右伸缩的导航区域代码
Sep 02 Javascript
Js制作点击输入框时默认文字消失的效果
Sep 05 Javascript
基于JS实现EOS隐藏错误提示层代码
Apr 25 Javascript
使用Script元素发送JSONP请求的方法
Jun 12 Javascript
基于JS实现回到页面顶部的五种写法(从实现到增强)
Sep 03 Javascript
JS实现用户注册时获取短信验证码和倒计时功能
Oct 27 Javascript
详解在vue-cli中使用graphql即vue-apollo的用法
Sep 08 Javascript
基于Proxy的小程序状态管理实现
Jun 14 Javascript
封装一下vue中的axios示例代码详解
Feb 16 Javascript
React 高阶组件HOC用法归纳
Jun 13 Javascript
详解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
PHP编实现程动态图像的创建代码
2008/09/28 PHP
php静态文件返回304技巧分享
2015/01/06 PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
2017/11/17 PHP
PHP实现生成模糊图片的方法示例
2017/12/21 PHP
Javascript 汉字字节判断
2009/08/01 Javascript
!DOCTYPE声明对JavaScript的影响分析
2010/04/12 Javascript
js字符编码函数区别分析
2011/12/28 Javascript
纯HTML5制作围住神经猫游戏-附源码下载
2015/08/23 Javascript
Jquery时间轴特效(三种不同类型)
2015/11/02 Javascript
JS实现焦点图轮播效果的方法详解
2016/12/19 Javascript
详解NodeJS框架express的路径映射(路由)功能及控制
2017/03/24 NodeJs
深入浅析AngularJS中的一次性数据绑定 (bindonce)
2017/05/11 Javascript
Vue2.0学习之详解Vue 组件及父子组件通信
2017/12/12 Javascript
浅谈在vue中用webpack打包之后运行文件的问题以及相关配置方法
2018/02/21 Javascript
vue中实现Monaco Editor自定义提示功能
2019/07/05 Javascript
layui表格 列自动适应大小失效的解决方法
2019/09/06 Javascript
JS判断数组四种实现方法详解
2020/06/29 Javascript
如何在vue 中引入使用jquery
2020/11/10 jQuery
[01:17]辉夜杯战队访谈宣传片—EHOME
2015/12/25 DOTA
Python使用PyGreSQL操作PostgreSQL数据库教程
2014/07/30 Python
在Python中使用成员运算符的示例
2015/05/13 Python
深度辨析Python的eval()与exec()的方法
2019/03/26 Python
python cumsum函数的具体使用
2019/07/29 Python
python中时间转换datetime和pd.to_datetime详析
2019/08/11 Python
Python 简单计算要求形状面积的实例
2020/01/18 Python
python GUI库图形界面开发之PyQt5信号与槽事件处理机制详细介绍与实例解析
2020/03/08 Python
pycharm解决关闭flask后依旧可以访问服务的问题
2020/04/03 Python
Python 使用SFTP和FTP实现对服务器的文件下载功能
2020/12/17 Python
css3 实现滚动条美化效果的实例代码
2021/01/06 HTML / CSS
HTML5响应式(自适应)网页设计的实现
2017/11/17 HTML / CSS
极简鞋类,赤脚的感觉:Lems Shoes
2019/08/06 全球购物
业务经理岗位职责
2013/11/11 职场文书
飞机制造技术专业求职信
2014/07/27 职场文书
2016计算机专业毕业生自荐信
2016/01/28 职场文书
导游词之镇江西津古渡
2019/11/06 职场文书
动画「半妖的夜叉姬」新BD特典图公开
2022/03/22 日漫