1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > elementUi【 下拉框】样式修改无效或者无法修改?

elementUi【 下拉框】样式修改无效或者无法修改?

时间:2021-10-27 08:49:43

相关推荐

elementUi【 下拉框】样式修改无效或者无法修改?

先提前做个demo

<!DOCTYPE html><html><head><meta charset="utf-8" /><title>Vue 下拉框</title><link rel="stylesheet" href="/element-ui/lib/theme-chalk/index.css" /><script src="/vue/dist/vue.js"></script><script src="/element-ui/lib/index.js"></script><style>.wrapper .el-select__tags-text {display: inline-block;max-width: 209px;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;}.wrapper .el-select .el-tag__close.el-icon-close {top: -7px;}.el-select-dropdown {max-width: 340px;}.el-select-dropdown__item {overflow: unset;text-overflow: unset;}.el-select-dropdown__list {overflow: auto;}.el-select-dropdown__item span {display: inline-block;}</style></head><body><div id="app"><p>{{ message }}</p><div class="wrapper"><el-select v-model="value" multiple filterable allow-create collapse-tags style="width: 340px;"default-first-option placeholder="请选择文章标签"><el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value":title="item.label"></el-option></el-select></div></div></body><script>new Vue({el: "#app",data: {message: "Hello Vue.js!",options: [{value: "HTML",label: "HTML",},{value: "CSS",label: "CSS",},{value: "JavaScript",label: "JavaScript",},{value: "name",label: "好好学习天天向上好好学习天天向上好好学习天天向上好好学习天天向上好好学习天天向上好好学习天天向上好好学习天天向上好好学习天天向上好好学习天天向上",},],value: [],}});</script></html>

这种是可行的 为什么运用到项目里面就不可以了?

使用element ui和vue2.0 脚手架开发,elementUi样式修改没有效果,添加important也没用,审查元素你会发现你修改的样式根本就没在页面上面显示这是为什么呢?

众所周知,vue项目 vue页面被浏览器解析后,在标签中出现data-v-xxx标记,如下:

这是在标记vue文件中css时使用scoped标记产生的,因为要保证各文件中的css不相互影响,给每个component都做了唯一的标记,所以每引入一个component就会出现一个新的data-v-xxx标记。所以加了scoped,他就会匹配标签中的data-v-xxx属性

所以原因就是在这里了,给style加scoped了,但是el的元素是没有data-v-xxx

所以:解决方法:

方法一:直接写style注意不要加scoped【但这会污染全局样式】,可以用一个组件最外层的class包裹住,就不会改到所有的组件的样式

<style lang="scss">.logMgCls {display: inline-block;.el-select__tags-text {display: inline-block;max-width: 211px;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;}.el-select .el-tag__close.el-icon-close {top: -7px;}.el-select-dropdown {max-width: 620px;}.el-select-dropdown__item {overflow: unset;text-overflow: unset;}.el-select-dropdown__list {overflow: auto;}.el-select-dropdown__item span {display: inline-block;}}</style>

方法二:父组件的 scoped 样式不能穿透到子组件上 使用 vue-loader 的写法如果希望 scoped 样式中的一个选择器能够作用得“更深”,例如影响子组件,使用 /deep/ 或者 >>> 解决

<style scoped>.a >>> .b {/* ... */ }</style>

被编译为:

.a[data-v-f3f3eg9] .b {/* ... */ }

参考 /q/1010000009086298

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。