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

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

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

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

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

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

方法2

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

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

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

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

可见全局过滤器比较灵活;

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

相关推荐
Laravel技术社区13 分钟前
用PHP8实现斗地主游戏,实现三带一,三带二,四带二,顺子,王炸功能(第二集)
前端·游戏·php
郑州光合科技余经理15 分钟前
PHP构建:支撑欧美澳市场的同城生活服务平台开发
java·开发语言·数据库·uni-app·php·排序算法·生活
m0_738120721 小时前
应急响应——知攻善防Web-3靶机详细教程
服务器·前端·网络·安全·web安全·php
hh随便起个名7 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
我是小路路呀8 小时前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
程序员爱钓鱼8 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder8 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
JIngJaneIL9 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
敲敲了个代码9 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_9 小时前
列表渲染(v-for)
前端·javascript·vue.js