vue.js v-html渲染的dom如何添加css

v-html渲染的html代码中有img,但是没有设置宽高,所有图片都是按照本身大小显示的,页面被图片弄的很难看,希望能给img标签加上固定的宽高等样式

阅读 17.2k
8 个回答

v-html是属于某个div的吧?
那么img就是div的后代元素吧。
提前定义好样式不行么?

.selector img{
    xxx
}

或者你获取v-html那个绑定的div的ref,然后用获取节点的方式给它里面的img加css

样式标签不能加scoped。否则v-html渲染样式会修改无效

首先,你要定义一个图片的样式类,然后在渲染的时候,通过使用:class给特定的标签绑定上你定义的样式类

template:
<p class="informationContent" v-html="item.informationContent"></p>

sytle:
.informationContent >>> img
height 50px
width 50px

我是这样解决的,不知道能不能帮到人

在v-html节点上写一个class或者id,比如 class="vhtml",然后在style里面设置图片的宽高
.vhtml img{width:100px;height:100px;}

新手上路,请多包涵

使用深度作用选择器

<style scoped>
.notice-content >>> .img { /* ... */ }
</style>

Sass Scss 之类的预处理器使用

::v-deep .notice-content img  {
  width: 100%;
}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏