浅谈vue中style的scoped属性(修改特定Element组件样式的方法)

在单页.vue文件中,为了保证各组件间的css样式不冲突,极可能会使用到局部css,也就是给<style>标签加上一个scoped属性(固然也能够用各类命名规则来规避这个问题)。javascript

一开始用的时候感受很神奇,因而看代码查资料了解了一下原理。
所谓的局部css,就是经过vue-loader这个插件,在编译打包的时候将带有scoped属性的css打上一个tag,同时将template内的全部html都打上一个相同的tag,最后经过css的属性选择器定位,造就了所谓的局部css。css

原理都懂了,再有兴趣深究能够看一下vue-loader的源码。html

下面说一个本身在开发中遇到的问题vue

最近项目中也在使用element-ui进行开发,有时候须要对引入的组件进行一些样式的重写调整,但仅仅是针对某一个页面而不是总体修改,在当前组件中用局部属性致使了不能重写element-ui的样式的问题。java

下面是简单的例子,想修改.el-table th的样式git

<style lang="css" scoped>
    .el-table th {
        background-color: #eee;
    }
</style>

可是发现并不能正常的修改样式,因而经过chrome查看元素一探究竟
发现html中只有子组件的根元素被打了tag标签而编译后的css中是最后一个属性被加了tag标签,因此天然就定位不到元素修改他的样式了github

<div data-v-15ed03ea class="el-table el-table--fit el-table--enable-row-hover el-table--enable-row-transition" style="width: 100%;">
    <th>...<th>
</div>

<style type="text/css">
.el-table th[data-v-15ed03ea] {
    background-color: #eee;
}
</style>

既然问题的原理已经清楚了,那么接下来开始寻找解决方案,咱们的目的只须要将tag打给咱们要修改子组件样式的根元素就能够了chrome

https://vue-loader.vuejs.org/en/features/scoped-css.html3 vue-loader的官方文档中也说了这个问题 因此使用 >>> 符号能够作到,可是注意vue-loader的版本要高于12.2.0 这个功能是这个版本后才具备的
https://github.com/vuejs/vue-loader/releases/tag/v12.2.0element-ui

最后上一下测试的demo测试

<template>
  <div>
      <el-table
      :data="tableData"
      style="width: 100%">
      <el-table-column
          prop="date"
          label="日期"
          width="180">
      </el-table-column>
      <el-table-column
          prop="name"
          label="姓名"
          width="180">
      </el-table-column>
      <el-table-column
          prop="address"
          label="地址">
      </el-table-column>
      </el-table>
      <div>
          <span>123</span>
          <p>321</p>
          <p>321</p>
      </div>

      </div>

    </template>
  <script>
  export default {
      data() {
      return {
          tableData: [{
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
          }, {
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1517 弄'
          }, {
          date: '2016-05-01',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1519 弄'
          }, {
          date: '2016-05-03',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1516 弄'
          }]
      }
      }
  }
  </script>
  <style lang="css" scoped>
      .el-table >>> th {
          background-color: #eee;
      }
  </style>
相关文章
相关标签/搜索