ホームページ ウェブフロントエンド jsチュートリアル Angular で MathJax を使用するときにどのような問題が発生しますか?

Angular で MathJax を使用するときにどのような問題が発生しますか?

Jun 20, 2018 pm 04:24 PM
使用

この記事では、主に Angular で MathJax を使用する際に発生するいくつかの問題について、サンプル コードを通じて詳しく紹介します。必要な友人が集まって学ぶことができます。

前書き

つまり、私は元々 KaTeX に傾いていたのですが、その理由は、KaTeX は速くて、MathJax はそれに合わせるのが難しいと感じていたからです。しかし、誰もが KaTeX の機能の欠如に不満を表明しており、それが私に MathJax を掘り下げる動機を与えてくれました。

MathJax の紹介

MathJax はブラウザ上で動作するオープンソースの数学記号レンダリング エンジンです。MathJax を使用すると、画像を使用せずにブラウザ上で数式を簡単に表示できます。現在、MathJax は、Latex、MathML、および ASCIIMathML のマークアップ言語を解析できます。 MathJax プロジェクトは 2009 年に開始されました。発起人には米国数学会やデザイン サイエンスなどが含まれ、多くの支援者が参加しています。個人的には、MathJax が将来の数学記号レンダリング エンジンの主流になると感じています。おそらくすでにそうなっているでしょう。ケース。

個人的には、これはそれほど深い研究ではありません。実際、MathJax は非常に単純で、単に MathJax.Hub.Queue(['Typeset', MathJax.Hub, this.element.nativeElement]); を呼び出すだけです。 > 要素をレンダリングします (this.element.nativeElement は Angular からその DOM を呼び出すための構文です)。この .Queue は実際には MathJax 自体によって実装されたコールバック形式です。それぞれの構文は非常に奇妙です。順番に実行されるコールバックを表す配列。たとえば、この ['Typeset', MathJax.Hub, this.element.nativeElement] では、最初の要素がメソッド名、2 番目の要素が this、後続の要素がパラメーターです...<code>MathJax.Hub.Queue(['Typeset', MathJax.Hub, this.element.nativeElement]); 就可以渲染一个元素(这个 this.element.nativeElement 是从 Angular 中调用它 DOM 的语法),这个 .Queue 实际上是 MathJax 自己实现的回调格式,语法非常清奇,参数个数不定,每个都是数组,代表一个回调,顺序执行。比如这个 ['Typeset', MathJax.Hub, this.element.nativeElement] ,第一个元素是方法名,第二个元素是 this ,之后的元素都是参数……

我们可以看到这个就相当于执行 MathJax.Hub.Typeset(this.element.nativeElement)

これがわかると思います。 MathJax.Hub.Typeset(this.element.nativeElement) を実行するには、これを実行してみてはいかがでしょうか?このメソッドは同期的であるため、ページが非常にスタックしてしまいます。したがって、MathJax は非同期キューをカプセル化します (その API は何百年も変わっていない可能性があります)

Angular に戻りましょう。マークダウンを使用する必要があるため、私のアイデアは、ディレクティブをカプセル化するためにマークを使用することです。次に、マークされたレンダリングが完了した後、MathJax を使用してコンポーネントをタイプセットする必要があります。しかし、実際にこれを実行してみると、素晴らしい効果が得られました。ページを切り替えた後、レンダリングが開始されるまでに 1 分近くかかりました。いくつかのログをキューに入れてみたところ、各要素が 4 回、つまり数十の要素がキューに入れられていることがわかりました。ほとんどのマークダウンには数学がまったく含まれていないにもかかわらず、次のページのコンテンツのレンダリングを開始するのに 1 分かかるのも不思議ではありません。

この時点で私は落胆し始めました、この問題に対する解決策はありませんか?絶望的になったとき、文書を直接植字できないか考えた結果、それが可能であり、非常に高速であることがわかりました。したがって、レンダリングが遅いわけではなく、レンダリングの初期化プロセスが遅いのかもしれません。この時点での解決策は、レンダリングの数を最小限に抑え、ドキュメントのみをレンダリングすることです。レンダリングが進行中である限り、どれだけ多くの要素がキューに入っても、それらをキューとして扱うのは 1 回だけです。

そこで私はこのサービスを書きました:

@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: &#39;none&#39;,
  tex2jax: {
  // preview: &#39;none&#39;,
  inlineMath: [[&#39;$&#39;, &#39;$&#39;]],
  processEscapes: true
  }
  });
  this.window.MathJax.Hub.Queue([&#39;log&#39;, console, &#39;start&#39;], [&#39;Typeset&#39;, this.window.MathJax.Hub, document], [&#39;log&#39;, console, &#39;end&#39;], [&#39;finishRunning&#39;, this]);
 }
 } else {
 this.finishRunning();
 }
 }
 }
}
ログイン後にコピー

上記は私が皆さんのためにまとめたものです。将来的に皆さんに役立つことを願っています。

関連記事:

jQueryでカルーセルの左右切り替えを実装する方法

jQueryでデータを取得してページに割り当てる方法

three.jsで3Dモデル表示を実装する方法

Angular CLI インストールチュートリアル

Vuejs の nextTick() による非同期更新キューの実装

ReactNative を使用して Toast を実装する方法

CommonsChunkPlugin を使用してパブリック モジュールを抽出する方法

🎜

以上がAngular で MathJax を使用するときにどのような問題が発生しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

マグネットリンクの使い方 マグネットリンクの使い方 Feb 18, 2024 am 10:02 AM

マグネット リンクは、リソースをダウンロードするためのリンク方法であり、従来のダウンロード方法よりも便利で効率的です。マグネット リンクを使用すると、中間サーバーに依存せずに、ピアツーピア方式でリソースをダウンロードできます。この記事ではマグネットリンクの使い方と注意点を紹介します。 1. マグネット リンクとは? マグネット リンクは、P2P (Peer-to-Peer) プロトコルに基づくダウンロード方式です。ユーザーはマグネット リンクを通じてリソースの発行者に直接接続し、リソースの共有とダウンロードを完了できます。従来のダウンロード方法と比較して、磁気

mdfおよびmdsファイルの使用方法 mdfおよびmdsファイルの使用方法 Feb 19, 2024 pm 05:36 PM

mdf ファイルと mds ファイルの使用方法 コンピューター技術の継続的な進歩により、さまざまな方法でデータを保存および共有できるようになりました。デジタル メディアの分野では、特殊なファイル形式に遭遇することがよくあります。この記事では、一般的なファイル形式である mdf および mds ファイルについて説明し、その使用方法を紹介します。まず、mdf ファイルと mds ファイルの意味を理解する必要があります。 mdf は CD/DVD イメージ ファイルの拡張子で、mds ファイルは mdf ファイルのメタデータ ファイルです。

CrystalDiskmarkとはどのようなソフトウェアですか? -crystaldiskmarkの使い方は? CrystalDiskmarkとはどのようなソフトウェアですか? -crystaldiskmarkの使い方は? Mar 18, 2024 pm 02:58 PM

CrystalDiskMark は、シーケンシャルおよびランダムの読み取り/書き込み速度を迅速に測定する、ハード ドライブ用の小型 HDD ベンチマーク ツールです。次に、編集者が CrystalDiskMark と Crystaldiskmark の使用方法を紹介します。 1. CrystalDiskMark の概要 CrystalDiskMark は、機械式ハード ドライブとソリッド ステート ドライブ (SSD) の読み取りおよび書き込み速度とパフォーマンスを評価するために広く使用されているディスク パフォーマンス テスト ツールです。 ). ランダム I/O パフォーマンス。これは無料の Windows アプリケーションで、使いやすいインターフェイスとハード ドライブのパフォーマンスのさまざまな側面を評価するためのさまざまなテスト モードを提供し、ハードウェアのレビューで広く使用されています。

foob​​ar2000のダウンロード方法は? -foobar2000の使い方 foob​​ar2000のダウンロード方法は? -foobar2000の使い方 Mar 18, 2024 am 10:58 AM

foob​​ar2000 は、音楽リソースをいつでも聴くことができるソフトウェアです。あらゆる種類の音楽をロスレス音質で提供します。音楽プレーヤーの強化版により、より包括的で快適な音楽体験を得ることができます。その設計コンセプトは、高度なオーディオをコンピュータ上で再生可能 デバイスを携帯電話に移植し、より便利で効率的な音楽再生体験を提供 シンプルでわかりやすく、使いやすいインターフェースデザイン 過度な装飾や煩雑な操作を排除したミニマルなデザインスタイルを採用また、さまざまなスキンとテーマをサポートし、自分の好みに合わせて設定をカスタマイズし、複数のオーディオ形式の再生をサポートする専用の音楽プレーヤーを作成します。過度の音量による聴覚障害を避けるために、自分の聴覚の状態に合わせて調整してください。次は私がお手伝いさせてください

NetEase メールボックス マスターの使用方法 NetEase メールボックス マスターの使用方法 Mar 27, 2024 pm 05:32 PM

NetEase Mailbox は、中国のネットユーザーに広く使用されている電子メール アドレスとして、その安定した効率的なサービスで常にユーザーの信頼を獲得してきました。 NetEase Mailbox Master は、携帯電話ユーザー向けに特別に作成された電子メール ソフトウェアで、電子メールの送受信プロセスが大幅に簡素化され、電子メールの処理がより便利になります。 NetEase Mailbox Master の使い方と具体的な機能について、以下ではこのサイトの編集者が詳しく紹介しますので、お役に立てれば幸いです。まず、モバイル アプリ ストアで NetEase Mailbox Master アプリを検索してダウンロードします。 App Store または Baidu Mobile Assistant で「Ne​​tEase Mailbox Master」を検索し、画面の指示に従ってインストールします。ダウンロードとインストールが完了したら、NetEase の電子メール アカウントを開いてログインします。ログイン インターフェイスは次のとおりです。

Baidu Netdisk アプリの使用方法 Baidu Netdisk アプリの使用方法 Mar 27, 2024 pm 06:46 PM

クラウド ストレージは今日、私たちの日常生活や仕事に欠かせない部分になっています。中国有数のクラウド ストレージ サービスの 1 つである Baidu Netdisk は、強力なストレージ機能、効率的な伝送速度、便利な操作体験により多くのユーザーの支持を得ています。また、重要なファイルのバックアップ、情報の共有、オンラインでのビデオの視聴、または音楽の聴きたい場合でも、Baidu Cloud Disk はニーズを満たすことができます。しかし、Baidu Netdisk アプリの具体的な使用方法を理解していないユーザーも多いため、このチュートリアルでは Baidu Netdisk アプリの使用方法を詳しく紹介します。まだ混乱しているユーザーは、この記事に従って詳細を学ぶことができます。 Baidu Cloud Network Disk の使用方法: 1. インストール まず、Baidu Cloud ソフトウェアをダウンロードしてインストールするときに、カスタム インストール オプションを選択してください。

PIP ミラー ソースの簡単なガイド: 使い方を簡単にマスターする PIP ミラー ソースの簡単なガイド: 使い方を簡単にマスターする Jan 16, 2024 am 10:18 AM

簡単に始めましょう: pip ミラー ソースの使用方法 世界中での Python の人気により、pip は Python パッケージ管理の標準ツールになりました。ただし、pip を使用してパッケージをインストールするときに多くの開発者が直面する一般的な問題は速度の遅さです。これは、デフォルトでは、pip は Python 公式ソースまたはその他の外部ソースからパッケージをダウンロードしますが、これらのソースが海外のサーバーに配置されている可能性があるため、ダウンロード速度が遅くなることがあります。ダウンロード速度を向上させるために、pip ミラー ソースを使用できます。ピップミラーソースとは何ですか?簡単に言えば、ただ、

BTCC チュートリアル: BTCC 取引所で MetaMask ウォレットをバインドして使用する方法は? BTCC チュートリアル: BTCC 取引所で MetaMask ウォレットをバインドして使用する方法は? Apr 26, 2024 am 09:40 AM

MetaMask (中国語ではリトル フォックス ウォレットとも呼ばれます) は、無料で評判の高い暗号化ウォレット ソフトウェアです。現在、BTCC は MetaMask ウォレットへのバインドをサポートしており、バインド後は MetaMask ウォレットを使用してすぐにログイン、値の保存、コインの購入などが可能になり、初回バインドで 20 USDT のトライアル ボーナスも獲得できます。 BTCCMetaMask ウォレットのチュートリアルでは、MetaMask の登録方法と使用方法、および BTCC で Little Fox ウォレットをバインドして使用する方法を詳しく紹介します。メタマスクウォレットとは何ですか? 3,000 万人を超えるユーザーを抱える MetaMask Little Fox ウォレットは、現在最も人気のある暗号通貨ウォレットの 1 つです。無料で使用でき、拡張機能としてネットワーク上にインストールできます。

See all articles