小编Kon*_*sov的帖子

带有范围CSS的Vue.js样式v-html

如何使用vue-loader使用范围限定的CSS为v-html内容设置样式?

简单示例:component.vue

<template>
  <div class="icon" v-html="icon"></icon>
</template>
<script>
  export default {
    data () {
      return {icon: '<svg>...</svg>'}
    }
  }
</script>
<style scoped>
  .icon svg {
    fill: red;
  }
</style>
Run Code Online (Sandbox Code Playgroud)

产生HTML <div data-v-9b8ff292="" class="icon"><svg>...</svg></div>

生成CSS .info svg[data-v-9b8ff292] { fill: red; }

如您所见,v-html内容没有data-v属性,但是生成css具有svg的data-v属性。

我知道这是vue-loader的预期行为(https://github.com/vuejs/vue-loader/issues/359)。并在本期中提到了后代选择器。但是如您所见,我在CSS中使用了它,但是它没有用。

如何为v-html内容设置样式?

vue.js vue-loader

4
推荐指数
4
解决办法
2694
查看次数

标签 统计

vue-loader ×1

vue.js ×1