【vue/过滤器】解析富文本返回的 html 中,单独给指定标签加样式

包含使用 quill 解析富文本传过来的内容
方法1:使用全局过滤器:

<div style="width: 100%;" class="ql-snow ql-editor" v-html="safeHtmlContent"></div>
import Vue from 'vue'

import "quill/dist/quill.core.css";
import "quill/dist/quill.snow.css";
import "quill/dist/quill.bubble.css";
Vue.filter('formatter', function (value) {
   
  // 只给 p 标签加首行缩进的样式
  return value.replace(/<p>/g, '<p style="text-indent: 20px;">');
});
// 和 data 平级的
computed: {
   
    safeHtmlContent() {
   
        // 在这里应用过滤器
        return this.$options.filters.formatter(this.articleInfo.articleContent);
    }
},

但是使用中有一个疑问,全局 Vue.filter可以用,但是 filters 却用不了,一直报错过滤器未定义,本来我以为是数据还没有获取到,查了一下, 原因出在 v-html 上,因为vue2.0 以上的版本,不可以给 v-html 使用 filters,只可以在 v-bind插值表达式中使用,如果非要使用可以用这个方法:

<div v-html="$options.filters.过滤器名(需要过滤的数据)"></div>

方法2

使用 filters 局部过滤器的写法,它和 data 平级:

<div style="width: 100%;" class="ql-snow ql-editor" v-html="$options.filters.safeHtmlContent(this.articleInfo.content)"></div>
filters:{
   
    safeHtmlContent(val){
   
        return val.replace(/<p>/g, '<p style="text-indent: 20px;">');
    }
},

方法2 的好处是:遇到一个页面有多种这样的情况也可以愉快的使用过滤器:

<div style="width: 100%;" class="ql-snow ql-editor" v-html="isList[4].articleContent"></div>

可见全局过滤器比较灵活;
我的理解是:要过滤的东西是使用的时候确定而不是在过滤器里确定,适合多次使用,这样也就弄懂了全局过滤器和局部过滤器的区别,以前是只知其然而不知其所以然。

相关推荐

  1. vue改变v-html包含body标签样式修改方法

    2024-02-06 22:30:01       31 阅读
  2. HTML<img>标签使用指南

    2024-02-06 22:30:01       6 阅读
  3. HTML<a>标签使用指南

    2024-02-06 22:30:01       6 阅读
  4. HTML文本标签:微观排版艺术

    2024-02-06 22:30:01       7 阅读
  5. 深入解析 HTML `<a>` 标签及其丰富功能

    2024-02-06 22:30:01       14 阅读
  6. HTML<br>、<hr>和<pre>标签使用指南

    2024-02-06 22:30:01       8 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-06 22:30:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-06 22:30:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-06 22:30:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-06 22:30:01       18 阅读

热门阅读

  1. 23种设计模式之工厂模式

    2024-02-06 22:30:01       32 阅读
  2. 设计模式(结构型模式)桥接模式

    2024-02-06 22:30:01       27 阅读
  3. Vue 插槽的基本用法

    2024-02-06 22:30:01       30 阅读
  4. MySQL深入——18

    2024-02-06 22:30:01       30 阅读
  5. FastAdmin

    2024-02-06 22:30:01       36 阅读
  6. H12-821_315

    2024-02-06 22:30:01       29 阅读
  7. 数组对象过滤

    2024-02-06 22:30:01       32 阅读
  8. k8s的Deployment部署策略线上踩坑

    2024-02-06 22:30:01       26 阅读
  9. 算法.1-三大排序算法-对数器-二分

    2024-02-06 22:30:01       27 阅读