欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular中使用MathJax遇到的一些問(wèn)題

 更新時(shí)間:2017年12月15日 09:34:51   作者:神奇魔法咸魚(yú)堂  
這篇文章主要給大家介紹了關(guān)于Angular中使用MathJax遇到的一些問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

話說(shuō)我本來(lái)是傾向于 KaTeX 的,因?yàn)槲腋杏X(jué)他很快,而且 MathJax 似乎很難配。但是大家表示對(duì)缺少功能的 KaTeX 并無(wú)好感,給我提供了一些鉆研 MathJax 的動(dòng)力。

MathJax簡(jiǎn)介

MathJax是一款運(yùn)行在瀏覽器中的開(kāi)源數(shù)學(xué)符號(hào)渲染引擎,使用MathJax可以方便的在瀏覽器中顯示數(shù)學(xué)公式,不需要使用圖片。目前,MathJax可以解析Latex、MathML和ASCIIMathML的標(biāo)記語(yǔ)言。MathJax項(xiàng)目于2009年開(kāi)始,發(fā)起人有American Mathematical Society, Design Science等,還有眾多的支持者,個(gè)人感覺(jué)MathJax會(huì)成為今后數(shù)學(xué)符號(hào)渲染引擎中的主流,也許現(xiàn)在已經(jīng)是了。

個(gè)人其實(shí)也不算鉆研,因?yàn)閷?shí)際上 MathJax 很簡(jiǎn)單,調(diào)用 MathJax.Hub.Queue(['Typeset', MathJax.Hub, this.element.nativeElement]); 就可以渲染一個(gè)元素(這個(gè) this.element.nativeElement 是從 Angular 中調(diào)用它 DOM 的語(yǔ)法),這個(gè) .Queue 實(shí)際上是 MathJax 自己實(shí)現(xiàn)的回調(diào)格式,語(yǔ)法非常清奇,參數(shù)個(gè)數(shù)不定,每個(gè)都是數(shù)組,代表一個(gè)回調(diào),順序執(zhí)行。比如這個(gè) ['Typeset', MathJax.Hub, this.element.nativeElement] ,第一個(gè)元素是方法名,第二個(gè)元素是 this ,之后的元素都是參數(shù)……

我們可以看到這個(gè)就相當(dāng)于執(zhí)行 MathJax.Hub.Typeset(this.element.nativeElement) ,那為啥不執(zhí)行這個(gè)?因?yàn)檫@方法是同步的,會(huì)導(dǎo)致頁(yè)面十分卡。于是 MathJax 就自己封裝了一個(gè)異步隊(duì)列(它的 API 可能幾百年沒(méi)改了)

我們說(shuō)回 Angular。因?yàn)橐?markdown,我的思路是用 marked 封裝一個(gè) directive。那么我們就應(yīng)該在 marked 渲染完成之后用 MathJax 去 Typeset 這個(gè)組件。但真的這樣做了,卻產(chǎn)生了奇妙的效果——切換頁(yè)面之后,要等將近一分鐘才開(kāi)始渲染。我在它的隊(duì)列里放了幾個(gè) log,發(fā)現(xiàn)每個(gè)元素都被 queue 了 4 次,幾十個(gè)元素,難怪要一分鐘才開(kāi)始渲染下一頁(yè)的內(nèi)容,即使大部分 markdown 里面根本沒(méi)有數(shù)學(xué)。

這時(shí)候我開(kāi)始灰心了,這個(gè)問(wèn)題就沒(méi)有解決辦法了嗎?絕望之時(shí),我想到能不能直接 Typeset document,結(jié)果是可以的,而且十分快。所以渲染并不慢,可能是渲染的初始化過(guò)程比較慢。那么這時(shí)候方案就出來(lái)了,我們可以盡量減少渲染次數(shù),同時(shí)只渲染 document。只要這個(gè)渲染還在進(jìn)行,那么有再多的元素 queue 上來(lái),我們也只當(dāng)作 queue 了一次。

于是我就寫(xiě)了這么個(gè) service:

@Injectable()
export class MathjaxService {
 public isQueued = false;
 public isRunning = false;
 window: any;
 constructor(@Inject(PLATFORM_ID) private platformId: Object) {
 if (isPlatformBrowser(this.platformId)) {
 this.window = window as any;
 }
 }
 finishRunning() {
 this.isRunning = false;
 if (this.isQueued) {
 this.queueChange();
 }
 }
 queueChange() {
 if (this.isRunning) {
 this.isQueued = true;
 } else {
 this.isQueued = false;
 this.isRunning = true;
 if (isPlatformBrowser(this.platformId)) {
 if (this.window.MathJax) {
  this.window.MathJax.Hub.Config({
  messageStyle: 'none',
  tex2jax: {
  // preview: 'none',
  inlineMath: [['$', '$']],
  processEscapes: true
  }
  });
  this.window.MathJax.Hub.Queue(['log', console, 'start'], ['Typeset', this.window.MathJax.Hub, document], ['log', console, 'end'], ['finishRunning', this]);
 }
 } else {
 this.finishRunning();
 }
 }
 }
}

事實(shí)證明,它能圓滿完成任務(wù),它也就是現(xiàn)在運(yùn)行在 這個(gè)網(wǎng)站 上的代碼。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • AngularJS 表達(dá)式詳解及實(shí)例代碼

    AngularJS 表達(dá)式詳解及實(shí)例代碼

    這篇文章主要介紹了AngularJS 表達(dá)式,這里整理了詳細(xì)的資料,有需要的小伙伴可以參考下
    2016-09-09
  • angularJS提交表單(form)

    angularJS提交表單(form)

    這篇文章主要介紹了angularJS提交表單(form)的方法和示例,需要的朋友可以參考下
    2015-02-02
  • Angular 1.x個(gè)人使用的經(jīng)驗(yàn)小結(jié)

    Angular 1.x個(gè)人使用的經(jīng)驗(yàn)小結(jié)

    這篇文章主要給大家介紹了關(guān)于Angular 1.x個(gè)人使用的一些經(jīng)驗(yàn),屬于一些基礎(chǔ)入門(mén)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-07-07
  • 詳解angular用$sce服務(wù)來(lái)過(guò)濾HTML標(biāo)簽

    詳解angular用$sce服務(wù)來(lái)過(guò)濾HTML標(biāo)簽

    這篇文章主要介紹了詳解angular用$sce服務(wù)來(lái)過(guò)濾HTML標(biāo)簽,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-04-04
  • 詳解Angular項(xiàng)目中共享模塊的實(shí)現(xiàn)

    詳解Angular項(xiàng)目中共享模塊的實(shí)現(xiàn)

    本文主要介紹了Angular的共享模塊的實(shí)現(xiàn),對(duì)此感興趣的同學(xué),可以實(shí)驗(yàn)一下
    2021-05-05
  • Angular.js自定義指令學(xué)習(xí)筆記實(shí)例

    Angular.js自定義指令學(xué)習(xí)筆記實(shí)例

    這篇文章主要介紹了Angular.js自定義指令的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • 簡(jiǎn)介AngularJS中使用factory和service的方法

    簡(jiǎn)介AngularJS中使用factory和service的方法

    這篇文章主要簡(jiǎn)單介紹了AngularJS中使用factory和service的方法,主要針對(duì)自定義工廠和服務(wù)的創(chuàng)建來(lái)講,需要的朋友可以參考下
    2015-06-06
  • AngularJS的內(nèi)置過(guò)濾器詳解

    AngularJS的內(nèi)置過(guò)濾器詳解

    在我們開(kāi)發(fā)中經(jīng)常需要在頁(yè)面顯示給用戶的信息需要一定處理格式化,才能顯示給用戶。在angularjs中為我們提供了叫filter的指令,讓我們能夠很輕易就能做到著一些列的功能,angularjs內(nèi)部為我們提供了number等很多內(nèi)置的filter。
    2015-05-05
  • Angular的$http與$location

    Angular的$http與$location

    這篇文章主要為大家詳細(xì)介紹了Angular的$http與$location,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • AngulaJS路由 ui-router 傳參實(shí)例

    AngulaJS路由 ui-router 傳參實(shí)例

    本篇文章主要介紹了AngulaJS路由 ui-router 傳參實(shí)例 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04

最新評(píng)論