如何解决highlightjs在vue-router中失效的问题 财富值51

2016-10-26 20:02发布

通过路由切换过去的一个含有pre和code标签的页面,引入highlightjs并执行,结果页面没有任何变化,执行的时间用过afterEach,window.onload和setTimeout都实验过,页面都不会高亮代码,请问各位大神解决办法?

3条回答
小米哥哥2 - 这个人很懒,什么都没留下
1楼 · 2016-10-26 20:17.采纳回答

you should not use that global init function, as it is intended to highlight all pre tags on page load, and is meant to be used on static pages.

Highlightjs offers a method for "Custom Initialization"with hljs.highlightBlock(), which you should warp in a custom directive:

So, simply add v-highlightjs to each tag that is supposed to be highlighted. That will re-highlight those tags each time Vue inserts them into the DOM (router navigation to another component etc...)

一周热门 更多>