prismjs不支持html,如何在vue中引入Prism.js

官网下载Prism.js和Prism.css 分别放在assets/js、assets/css文件夹下(也可以放在同一个文件下,都可以的)

可以直接在main.js全局导入,也可以在文章显示的组件下单独导入

import prismjs from '@/assets/js/prism'

import prismCss from '@/assets/css/prism.css'

如何使用:

 
 

//双指针

public boolean hasCycle(ListNode head) {

if(head == null || head.next == null) return false;

ListNode fast = head.next;

ListNode slow = head;

while(fast != slow){

if(fast == null || fast.next == null)

return false;

fast = fast.next.next;

slow = slow.next;

}

return true;

}

1580bff7cc5a

显示效果

Prism默认只有在以下标签里面的代码才会被高亮显示,

 
 

......

class="line-numbers"是添加行号,

class="language-java" 实现java语法高亮,当然也可以设置javascript的语法高亮

使用问题

一:页面刷新后,高亮无效

组件挂载后添加highlightAll()方法

mounted(){

.......

Prismjs.highlightAll()

}

二:在项目中,后端返回一个article对象,然后通过 v-html把article.htmlContent显示出来,

但是我们在数据库中保存的html文章里的

元素是没有任何css样式的

没有

这下怎么办?

一开始我想着在 v-html里的内容被渲染时,动态添加类名,但是查阅了很多资料都不行,

头疼之际,突然想到我不可以动态添加类名但是我可以在后端返回的html内容里用正则表达式去替换

标签啊

说干就干:

//定义替换方法

replaceHtml(htmlContent) {

let reg=new RegExp("

let reg1=new RegExp("

let stringObj=htmlContent

let newstr=stringObj.replace(reg,`

let newstr2=newstr.replace(reg1,`

return newstr2

/*return htmlContent*/

},

用正则表达式替换后,

元素的确添加相应的类名了,但是高亮样式依旧加载不出来

我又蒙逼了,然后我又想,是不是Prism.js不能处理v-html里的内容,然后我又去查阅资料,没结果,然后我自己在组件内定义了一个变量且把用正则表达式替换后的一模一样的html字符串赋给它,然后用 v-html显示,结果是可以实现高亮显示的

-------------------------------------------------------------------

html:"

\n" +

" \n" +

" //双指针\n" +

" public boolean hasCycle(ListNode head) {\n" +

" if(head == null || head.next == null) return false;\n" +

" ListNode fast = head.next;\n" +

" ListNode slow = head;\n" +

" while(fast != slow){\n" +

" if(fast == null || fast.next == null)\n" +

" return false;\n" +

" fast = fast.next.next;\n" +

" slow = slow.next;\n" +

" }\n" +

" return true;\n" +

" }\n" +

"

",

这下就不关v-html的原因了, v-html也只是把html形式的字符串显示出来而已,没做其他操作。

最后我终于才想到,在组件内定义的html字符串变量能被高亮显示,我后台异步请求回来的却没效果,很可能是因为我没有在节点未被赋值前进行了highlightAll()操作,导致异步请求的文章没有高亮效果

于是设置异步渲染

setTimeout(()=>{

prismjs.highlightAll()

}

,0)

最后,后台传回来的文章成功高亮显示

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值