浅谈关于.vue文件中style的scoped属性


Posted in Javascript onAugust 19, 2017

本文介绍了.vue文件中style的scoped属性以及踩到的坑,具体如下:

scoped可以实现style只作用于当前的.vue文件

<template>
  <div class="user"></div>
</template>
<script>

</script>

<style lang='less' scoped>
.user {
  color:#333;
}
</style>

上面的文件渲染出的dom结构会是这样的

<div data-v-53795c54 class="user"></div>

css样式是这样的

.user[data-v-53795c54] {
  color:#333;
}

这样就现实了样式只作用于当前.vue文件。

问题:添加scoped属性后样式不起作用

原因是,css被构建成.user[data-v-53795c54] 但是doc节点依然是普通的<div class="user"></div>,导致样式不能作用在dom上而失效。

原因在引用的组件上,解决的方法是将scoped属性关闭。

scoped关闭时的使用建议

如果需要将scoped关闭,那么style就是作用于整个单页应用

可是我们仍然想要样式之作用于当前的.vue文件,减少对其他文件样式的影响

1、给template下的根节点加一个class,并基于这个class添加样式

<template>
<div class="user">
<p class="name">zaunk</p>
</div>
</template>
<script>

</script>

<style lang='less>
.user {
color:#333;
.name {
color:#122222;
}
}
</style>

2、基于第一条建议,不要有定义两个相同class名称的根节点,因为都作用于整个单页会有一个失效。

3、不要使用 span {}这种做样式设置。因为

<template>
<div class="user">
<el-button class="name">zaunk</el-button>
</div>
</template>
<style lang='less>
.user {
color:#333;
span {
color:#122222;
}
}
</style>

上面的样式同样会作用于组件el-button,这是很危险的

在vue组件中style scoped中遇到的坑

浅谈关于.vue文件中style的scoped属性

在uve组件中我们我们经常需要给style添加scoped来使得当前样式只作用于当前组件的节点。添加scoped之后,实际上vue在背后做的工作是将当前组件的节点添加一个像data-v-1233这样唯一属性的标识,当然也会给当前style的所有样式添加[data-v-1233]这样的话,就可以使得当前样式只作用于当前组件的节点。但是我们需要注意的是如果我们添加了子组件,同样的,如果子组件也用scoped标识了,那么在父组件中是不能设置子组件中的节点的。若父组件有scoped,子组件没有设置,同样,也是不能在父组件中设置子组件的节点的样式的,因为父组件用了scoped,那么父组件中style设置的样式都是唯一的了,不会作用与其他的组件样式,我在用vue-quill-editor富文本编辑器的时候就遇到了这个坑,我只是想让内容区设置一个高度,这样的话,是必须在App.vue中设置的,我们App.vue相当于根容器,没有设置scoped,所以是可以设置的。

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

Javascript 相关文章推荐
你真的了解JavaScript吗?
Feb 24 Javascript
js中各浏览器中鼠标按键值的差异
Apr 07 Javascript
兼容IE和FF的图片上传前预览js代码
May 28 Javascript
js 一个关于图片onload加载的事
Nov 10 Javascript
JavaScript 学习笔记之变量及其作用域
Jan 14 Javascript
Jquery中$.post和$.ajax的用法小结
Apr 28 Javascript
node.js下LDAP查询实例分享
Sep 30 Javascript
node 利用进程通信实现Cluster共享内存
Oct 27 Javascript
jQuery第一次运行页面默认触发点击事件的实例
Jan 10 jQuery
深入Vue-Router路由嵌套理解
Aug 13 Javascript
vue+node实现图片上传及预览的示例方法
Nov 22 Javascript
解决Layui数据表格显示无数据提示的问题
Nov 14 Javascript
如何理解Vue的作用域插槽的实现原理
Aug 19 #Javascript
Vue Transition实现类原生组件跳转过渡动画的示例
Aug 19 #Javascript
JavaScript文件的同步和异步加载的实现代码
Aug 19 #Javascript
深入理解ES6学习笔记之块级作用域绑定
Aug 19 #Javascript
深入理解ES6的迭代器与生成器
Aug 19 #Javascript
Mui使用jquery并且使用点击跳转新窗口的实例
Aug 19 #jQuery
Vue自定义事件(详解)
Aug 19 #Javascript
You might like
php下删除字符串中HTML标签的函数
2008/08/27 PHP
详解php魔术方法(Magic methods)的使用方法
2016/02/14 PHP
收集的10个免费的jQuery相册
2011/02/26 Javascript
在表单提交前进行验证的几种方式整理
2013/07/31 Javascript
使用jquery实现放大镜效果
2014/09/02 Javascript
JavaScript字符串对象replace方法实例(用于字符串替换或正则替换)
2014/10/16 Javascript
bootstrap警告框使用方法解析
2017/01/13 Javascript
详解Angular.js数据绑定时自动转义html标签及内容
2017/03/30 Javascript
Angular.js中数组操作的方法教程
2017/07/31 Javascript
自定义vue组件发布到npm的方法
2018/05/09 Javascript
Vue 实现列表动态添加和删除的两种方法小结
2018/09/07 Javascript
element-ui upload组件多文件上传的示例代码
2018/10/17 Javascript
vuejs+element UI点击编辑表格某一行时获取内容填入表单的示例
2018/10/31 Javascript
在Vue项目中取消ESLint代码检测的步骤讲解
2019/01/27 Javascript
Vue 组件修改根实例的数据的方法
2019/04/02 Javascript
如何用vue-cli3脚手架搭建一个基于ts的基础脚手架的方法
2019/12/12 Javascript
JavaScript 正则应用详解【模式、欲查、反向引用等】
2020/05/13 Javascript
[01:56]无止竞 再出发——中国军团出征2017年DOTA2国际邀请赛
2017/07/05 DOTA
Python cookbook(数据结构与算法)对切片命名清除索引的方法
2018/03/13 Python
Opencv-Python图像透视变换cv2.warpPerspective的示例
2019/04/11 Python
python对象转字典的两种实现方式示例
2019/11/07 Python
python3.x 生成3维随机数组实例
2019/11/28 Python
如何基于python测量代码运行时间
2019/12/25 Python
Python多线程获取返回值代码实例
2020/02/17 Python
浅谈keras中的keras.utils.to_categorical用法
2020/07/02 Python
python爬虫要用到的库总结
2020/07/28 Python
pycharm 实现调试窗口恢复
2021/02/05 Python
css3 给背景设置渐变色的方法
2019/09/12 HTML / CSS
CSS3制作漂亮的照片墙的实现代码
2016/06/08 HTML / CSS
迪卡侬波兰体育用品商店:Decathlon波兰
2020/03/31 全球购物
会计职业生涯规划书
2014/01/13 职场文书
《在大海中永生》教学反思
2014/02/24 职场文书
让生命充满爱演讲稿
2014/05/10 职场文书
保护环境标语
2014/06/09 职场文书
综治维稳工作承诺书
2014/08/30 职场文书
毕业班工作总结
2015/08/10 职场文书