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

11 篇文章 0 订阅

先提前做个demo
在这里插入图片描述

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8" />
  <title>Vue 下拉框</title>
  <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css" />
  <script src="https://unpkg.com/vue/dist/vue.js"></script>
  <script src="https://unpkg.com/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 { /* ... */ }

参考 https://segmentfault.com/q/1010000009086298

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值