Vue scoped及deep使用方法解析


Posted in Javascript onAugust 01, 2020

众所周知,在组件中给style 标签添加属性 scoped 属性可以避免组件内样式对外界造成污染,scoped使得组件内的样式变成局域样式,只作用于当前组件。

原理如下-------

在编译组件的时候,如果当前组件内style标签上有scoped属性,那么会在当前所有标签上添加一个【data-v-hash】属性,而当前样式表内的所有末尾选择器后面也会加上该属性,那么就使得当前组件内的样式只会作用于当前组件内的元素。值得注意的是,当父组件,子组件同时使用scoped属性时,子组件最外层的标签既会被加上当前组件的hash值,又会加上父级组件的hash值,像这样

//子组件最外层标签
<div data-v-b45036b2 data-v-384b136e ></div>

但是有个问题------

在我们用scoped的时候回发现一个问题,就是我们在当前组件内使用的scoped,但是我想在当前组件内改变子组件的样式(非最外层标签),的时候会发现不好使。

<style scoped>
.father-div .child-div{color:red;}
</style>

因为到了浏览器上会解析成

<div data-v-384b136e ></div> 

不好使的原因是应为父组件内样式内解析的是父组件的hash值,而子组件内标签上添加的是子组件的hash值,对应不上当然没效果,那怎么解决呢?

使用deep------

当遇到这种困扰的时候我们可以另写一个style标签,然后不加scoped属性,来盖子组件的样式,当前这么写是可以的,但是不太优雅,这时我们可以用到/deep/属性,

.father-div /deep/ .child-div{color:red;}

当遇到"/deep/"的时候会将"/deep/"的位置替换成组件的hash值,解析成

.father-div[data-v-b45036b2] .child-div{color:red;}

这样只需要注意css的权重就可以覆盖子组件内的样式了,

注意:子组件内最外层的样式由于是带了父子组件的两个hash值,所以是会被两头控制的,不需要/deep/就可以在父组件内覆盖样式

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
动态加载js和css(外部文件)
Apr 17 Javascript
解决jquery中动态新增的元素节点无法触发事件问题的两种方法
Oct 30 Javascript
jquery彩色投票进度条简单实例演示
Jul 23 Javascript
JavaScript组合模式学习要点
Aug 26 Javascript
node+express制作爬虫教程
Nov 11 Javascript
react实现pure render时bind(this)隐患需注意!
Mar 09 Javascript
实例详解display:none与visible:hidden的区别
Mar 30 Javascript
AngularJS实现的输入框字数限制提醒功能示例
Oct 26 Javascript
vue 设置proxyTable参数进行代理跨域
Apr 09 Javascript
微信小程序中上传图片并进行压缩的实现代码
Aug 28 Javascript
jQuery分组选择器简单用法示例
Apr 04 jQuery
Vue-cli4 配置 element-ui 按需引入操作
Sep 11 Javascript
Vue中computed及watch区别实例解析
Aug 01 #Javascript
Vue数组响应式操作及高阶函数使用代码详解
Aug 01 #Javascript
vue 组件简介
Jul 31 #Javascript
three.js 制作动态二维码的示例代码
Jul 31 #Javascript
vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据操作
Jul 31 #Javascript
vue抽出组件并传值实例
Jul 31 #Javascript
Vue通过Blob对象实现导出Excel功能示例代码
Jul 31 #Javascript
You might like
重新认识php array_merge函数
2014/08/31 PHP
php根据某字段对多维数组进行排序的方法
2015/03/07 PHP
php curl抓取网页的介绍和推广及使用CURL抓取淘宝页面集成方法
2015/11/30 PHP
php添加数据到xml文件的简单例子
2016/09/08 PHP
PHP 中常量的知识整理
2017/04/14 PHP
PHP实现微信提现(企业付款到零钱)
2019/08/01 PHP
Laravel统计一段时间间隔的数据方法
2019/10/09 PHP
JavaScript 面向对象的 私有成员和公开成员
2010/05/13 Javascript
基于jquery的图片的切换(以数字的形式)
2011/02/14 Javascript
jQuery中获取Radio元素值的方法
2013/07/02 Javascript
jquery的checkbox,radio,select等方法小结
2016/08/30 Javascript
微信小程序-小说阅读小程序实例(demo)
2017/01/12 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
2017/02/12 Javascript
webpack之devtool详解
2018/02/10 Javascript
JS实现的RC4加密算法示例
2018/08/16 Javascript
javascript事件循环event loop的简单模型解释与应用分析
2020/03/14 Javascript
[01:01:52]DOTA2-DPC中国联赛正赛 iG vs LBZS BO3 第一场 3月4日
2021/03/11 DOTA
Python模拟登陆淘宝并统计淘宝消费情况的代码实例分享
2016/07/04 Python
Scrapy-redis爬虫分布式爬取的分析和实现
2017/02/07 Python
详解python的ORM中Pony用法
2018/02/09 Python
Pandas读取MySQL数据到DataFrame的方法
2018/07/25 Python
python障碍式期权定价公式
2019/07/19 Python
在macOS上搭建python环境的实现方法
2019/08/13 Python
借助HTML5 Canvas API制作一个简单的猜字游戏
2016/03/25 HTML / CSS
ROSEFIELD手表荷兰官方网上商店:北欧极简设计女士腕表品牌
2018/01/24 全球购物
中国旅游网站:途牛旅游网
2019/09/29 全球购物
介绍一下Linux中的链接
2016/06/05 面试题
党员承诺书内容
2014/03/26 职场文书
2014年基层党支部工作总结
2014/12/04 职场文书
骨干教师考核评语
2014/12/31 职场文书
新郎新娘答谢词
2015/01/04 职场文书
2015年为民办实事工作总结
2015/05/26 职场文书
大国崛起日本观后感
2015/06/02 职场文书
python如何进行基准测试
2021/04/26 Python
go类型转换及与C的类型转换方式
2021/05/05 Golang
Go语言特点及基本数据类型使用详解
2022/03/21 Golang