Angular에서 MathJax를 사용할 때 어떤 문제가 발생합니까?
이 글에서는 주로 MathJax를 Angular에서 사용할 때 발생하는 몇 가지 문제를 소개합니다. 이 글에서는 샘플 코드를 통해 매우 자세하게 소개합니다. 학습이나 업무에 필요한 모든 사람이 함께 와서 배울 수 있습니다. .
머리말
즉, 원래는 KaTeX가 빠르다고 느꼈고 MathJax는 맞추기 어려울 것 같아서 쪽으로 기울었습니다. 그러나 모든 사람들은 KaTeX의 기능 부족에 대한 불만을 표현했고, 이는 나에게 MathJax를 탐구할 동기를 부여했습니다.
MathJax 소개
MathJax는 브라우저에서 실행되는 오픈 소스 수학 기호 렌더링 엔진입니다. MathJax를 사용하면 이미지를 사용하지 않고도 브라우저에 수학 공식을 쉽게 표시할 수 있습니다. 현재 MathJax는 Latex, MathML, ASCIIMathML의 마크업 언어를 구문 분석할 수 있습니다. MathJax 프로젝트는 2009년에 시작되었습니다. 발기인으로는 American Mathematical Society, Design Science 등이 있고 많은 지지자들이 있습니다. 저는 개인적으로 MathJax가 앞으로 수학 기호 렌더링 엔진의 주류가 될 것이라고 생각합니다. 사례.
개인적으로, 실제로 MathJax는 매우 간단하기 때문에 깊이 있는 연구는 아닙니다. MathJax.Hub.Queue(['Typeset', MathJax.Hub, this.element.nativeElement]);를 호출하면 됩니다. > 요소를 렌더링합니다(this.element.nativeElement는 Angular에서 DOM을 호출하기 위한 구문입니다). 이 .Queue는 실제로 MathJax 자체에 의해 구현된 콜백 형식입니다. 구문은 각각 매우 이상합니다. 콜백을 나타내는 배열로, 순차적으로 실행됩니다. 예를 들어 이 ['Typeset', MathJax.Hub, this.element.nativeElement], 첫 번째 요소는 메서드 이름, 두 번째 요소는 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분이 걸리는 것은 당연합니다. 이때부터 저는 낙담하기 시작했습니다. 이 문제에 대한 해결책은 없을까요? 절박할 때 문서를 직접 조판할 수 있을까 고민해 본 결과, 가능하고 매우 빨랐습니다. 따라서 렌더링이 느리지 않고 렌더링 초기화 프로세스가 느릴 수도 있습니다. 그러면 이때 렌더링 횟수를 최소화하고 문서만 렌더링하면 해결 방법이 나옵니다. 렌더링이 계속 진행 중인 한 대기열에 요소가 얼마나 많이 들어와도 해당 요소를 한 번만 대기열로 처리합니다. 그래서 제가 이 서비스를 썼습니다:
@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(); } } } }
jquery에서 왼쪽 및 오른쪽 캐러셀 전환을 구현하는 방법
jQuery에서 데이터를 가져와 페이지에 할당하는 방법
Vuejs의 nextTick()을 통해 비동기 업데이트 대기열 구현
ReactNative를 사용하여 Toast를 구현하는 방법
CommonsChunkPlugin을 사용하여 공용 모듈을 추출하는 방법
🎜위 내용은 Angular에서 MathJax를 사용할 때 어떤 문제가 발생합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











마그넷 링크는 리소스를 다운로드하기 위한 링크 방식으로, 기존 다운로드 방식보다 더 편리하고 효율적입니다. 마그넷 링크를 사용하면 중간 서버에 의존하지 않고 P2P 방식으로 리소스를 다운로드할 수 있습니다. 이번 글에서는 마그넷 링크의 사용법과 주의할 점을 소개하겠습니다. 1. 마그넷 링크란 무엇인가요? 마그넷 링크는 P2P(Peer-to-Peer) 프로토콜을 기반으로 한 다운로드 방식입니다. 마그넷 링크를 통해 사용자는 리소스 게시자에 직접 연결하여 리소스 공유 및 다운로드를 완료할 수 있습니다. 전통적인 다운로드 방법과 비교하여 자기

mdf 파일, mds 파일 사용법 컴퓨터 기술의 지속적인 발전으로 우리는 다양한 방법으로 데이터를 저장하고 공유할 수 있게 되었습니다. 디지털 미디어 분야에서는 특별한 파일 형식을 자주 접하게 됩니다. 이 기사에서는 일반적인 파일 형식인 mdf 및 mds 파일에 대해 설명하고 사용 방법을 소개합니다. 먼저 mdf 파일과 mds 파일의 의미를 이해해야 합니다. mdf는 CD/DVD 이미지 파일의 확장자이고, mds 파일은 mdf 파일의 메타데이터 파일입니다.

CrystalDiskMark는 순차 및 무작위 읽기/쓰기 속도를 빠르게 측정하는 하드 드라이브용 소형 HDD 벤치마크 도구입니다. 다음으로 편집자님에게 CrystalDiskMark 소개와 crystaldiskmark 사용법을 소개하겠습니다~ 1. CrystalDiskMark 소개 CrystalDiskMark는 기계식 하드 드라이브와 솔리드 스테이트 드라이브(SSD)의 읽기 및 쓰기 속도와 성능을 평가하는 데 널리 사용되는 디스크 성능 테스트 도구입니다. ). 무작위 I/O 성능. 무료 Windows 응용 프로그램이며 사용자 친화적인 인터페이스와 다양한 테스트 모드를 제공하여 하드 드라이브 성능의 다양한 측면을 평가하고 하드웨어 검토에 널리 사용됩니다.

foobar2000은 언제든지 음악 리소스를 들을 수 있는 소프트웨어입니다. 모든 종류의 음악을 무손실 음질로 제공합니다. 음악 플레이어의 향상된 버전을 사용하면 더욱 포괄적이고 편안한 음악 경험을 얻을 수 있습니다. 컴퓨터에서 고급 오디오를 재생합니다. 이 장치는 보다 편리하고 효율적인 음악 재생 경험을 제공합니다. 인터페이스 디자인은 단순하고 명확하며 사용하기 쉽습니다. 또한 다양한 스킨과 테마를 지원하고, 자신의 선호도에 따라 설정을 개인화하며, 다양한 오디오 형식의 재생을 지원하는 전용 음악 플레이어를 생성합니다. 또한 볼륨을 조정하는 오디오 게인 기능도 지원합니다. 과도한 볼륨으로 인한 청력 손상을 방지하려면 자신의 청력 상태에 따라 조정하십시오. 다음엔 내가 도와줄게

오늘날 클라우드 스토리지는 우리의 일상 생활과 업무에 없어서는 안 될 부분이 되었습니다. 중국 최고의 클라우드 스토리지 서비스 중 하나인 Baidu Netdisk는 강력한 스토리지 기능, 효율적인 전송 속도 및 편리한 운영 경험으로 많은 사용자의 호감을 얻었습니다. 중요한 파일을 백업하고, 정보를 공유하고, 온라인으로 비디오를 시청하고, 음악을 듣고 싶은 경우 Baidu Cloud Disk는 귀하의 요구를 충족할 수 있습니다. 그러나 많은 사용자가 Baidu Netdisk 앱의 구체적인 사용 방법을 이해하지 못할 수 있으므로 이 튜토리얼에서는 Baidu Netdisk 앱 사용 방법을 자세히 소개합니다. Baidu 클라우드 네트워크 디스크 사용 방법: 1. 설치 먼저 Baidu Cloud 소프트웨어를 다운로드하고 설치할 때 사용자 정의 설치 옵션을 선택하십시오.

NetEase Mailbox는 중국 네티즌들이 널리 사용하는 이메일 주소로, 안정적이고 효율적인 서비스로 항상 사용자들의 신뢰를 얻어 왔습니다. NetEase Mailbox Master는 휴대폰 사용자를 위해 특별히 제작된 이메일 소프트웨어로 이메일 보내기 및 받기 프로세스를 크게 단순화하고 이메일 처리를 더욱 편리하게 만듭니다. 따라서 NetEase Mailbox Master를 사용하는 방법과 그 기능이 무엇인지 아래에서 이 사이트의 편집자가 자세한 소개를 제공하여 도움을 드릴 것입니다! 먼저, 모바일 앱스토어에서 NetEase Mailbox Master 앱을 검색하여 다운로드하실 수 있습니다. App Store 또는 Baidu Mobile Assistant에서 "NetEase Mailbox Master"를 검색한 후 안내에 따라 설치하세요. 다운로드 및 설치가 완료되면 NetEase 이메일 계정을 열고 로그인합니다. 로그인 인터페이스는 아래와 같습니다.

MetaMask(중국어로 Little Fox Wallet이라고도 함)는 무료이며 호평을 받는 암호화 지갑 소프트웨어입니다. 현재 BTCC는 MetaMask 지갑에 대한 바인딩을 지원합니다. 바인딩 후 MetaMask 지갑을 사용하여 빠르게 로그인하고 가치를 저장하고 코인을 구매할 수 있으며 첫 바인딩에는 20 USDT 평가판 보너스도 받을 수 있습니다. BTCCMetaMask 지갑 튜토리얼에서는 MetaMask 등록 및 사용 방법, BTCC에서 Little Fox 지갑을 바인딩하고 사용하는 방법을 자세히 소개합니다. MetaMask 지갑이란 무엇입니까? 3천만 명 이상의 사용자를 보유한 MetaMask Little Fox Wallet은 오늘날 가장 인기 있는 암호화폐 지갑 중 하나입니다. 무료로 사용할 수 있으며 확장으로 네트워크에 설치할 수 있습니다.

스피커의 재생 버튼을 길게 누른 후 소프트웨어에서 Wi-Fi에 연결하면 사용 가능합니다. 튜토리얼 적용 모델: Xiaomi 12 시스템: EMUI11.0 버전: Xiaoai Classmate 2.4.21 분석 1 먼저 스피커의 재생 버튼을 찾아 길게 눌러 네트워크 배포 모드로 들어갑니다. 2 휴대폰의 Xiaoai 스피커 소프트웨어에서 Xiaomi 계정에 로그인하고 클릭하여 새 Xiaoai 스피커를 추가하세요. 3. Wi-Fi의 이름과 비밀번호를 입력한 후 Xiao Ai에게 전화를 걸어 사용할 수 있습니다. 보충: Xiaoai 스피커에는 어떤 기능이 있습니까? 1 Xiaoai 스피커에는 시스템 기능, 소셜 기능, 엔터테인먼트 기능, 지식 기능, 생활 기능, 스마트 홈 및 교육 계획이 있습니다. 요약/주의사항: 간편한 연결 및 사용을 위해서는 Xiao Ai 앱을 휴대폰에 미리 설치해야 합니다.
