Angular4增加對markdown的支持

ngx-markdown 是 Angular2+ 的一個第三方庫,它的主要功能是將md文件轉(zhuǎn)換為HTML格式,并且支持語法高亮含潘。
DEMO網(wǎng)站:https://jfcere.github.io/ngx-markdown
GITHUB地址:https://github.com/jfcere/ngx-markdown

1. 安裝

1.1 安裝 ngx-markdown

  • 使用 npm 進(jìn)行安裝淀歇,在 `angular`項(xiàng)目目錄中執(zhí)行:
npm install ngx-markdown --save
  • 在應(yīng)用中引入 marked 的支持.引入:
"scripts" : [
    "../node_modules/marked/lib/marked.js"  //增加此句
]

1.2 安裝語法高亮

如果用不到語法高亮,可以跳過此步驟.

使用一下命令添加語法高亮的包到你的應(yīng)用中:

npm install prismjs --save

為了使 prism.js 語法高亮可以正常執(zhí)行,需要引入以下文件 :

  • prism.js 的關(guān)鍵庫文件, node_modules/prismjs/prism.js
  • 一個高亮主題, node_modules/prismjs/themes
  • 代碼語言描述文件, node_modules/prismjs/components 文件

如果你使用的是 Angular Cli 構(gòu)建工具,可以將下列語句添加到.angular-cli.json文件中:

"styles": [
  "styles.css",
+ "../node_modules/prismjs/themes/prism-okaidia.css"
],
"scripts": [
+ "../node_modules/prismjs/prism.js",
+ "../node_modules/prismjs/components/prism-csharp.min.js", # c-sharp language syntax
+ "../node_modules/prismjs/components/prism-css.min.js" # css language syntax
]

2. 配置

2.1 主應(yīng)用模塊

在使用ngx-markdown之前, 你必須引入MarkdowmModuleAppModule 中去, 并且在 forRoot 中聲明:

import { NgModule } from '@angular/core';
+ import { MarkdownModule } from 'ngx-markdown';

import { AppComponent } from './app.component';

@NgModule({
  imports: [
+   MarkdownModule.forRoot(),
  ],
  declarations: [AppComponent],
  bootstrap: [AppComponent],
})
export class AppModule { }

2.1.1 Marked配置

可以在 MarkdownModuleforRoot 方法中來對Markded進(jìn)行配置:

import { MarkdownModule, MarkedOptions } from 'ngx-markdown';

// using default options
MarkdownModule.forRoot(),

// using specific options with ValueProvider
MarkdownModule.forRoot({
  provide: MarkedOptions,
  useValue: {
    gfm: true,
    tables: true,
    breaks: false,
    pedantic: false,
    sanitize: false,
    smartLists: true,
    smartypants: false,
  },
}),

2.1.2 MarkedOptions.render

MarkedOptions 還包括一個render屬性, 你可以通過它重寫將markdown數(shù)據(jù)轉(zhuǎn)換為HTML的具體轉(zhuǎn)換方式.

例如:

import { MarkedOptions, MarkedRenderer } from 'ngx-markdown';

// function that returns `MarkedOptions` with renderer override
export function markedOptionsFactory(): MarkedOptions {
  const renderer = new MarkedRenderer();

  renderer.blockquote = (text: string) => {
    return '<blockquote class="blockquote"><p>' + text + '</p></blockquote>';
  };

  return {
    renderer: renderer,
    gfm: true,
    tables: true,
    breaks: false,
    pedantic: false,
    sanitize: false,
    smartLists: true,
    smartypants: false,
  };
}

// using specific option with FactoryProvider
MarkdownModule.forRoot({
  provide: MarkedOptions,
  useFactory: markedOptionsFactory,
}),

2.2 其他的模塊

當(dāng)你將 MarkdownModule 引入到其他應(yīng)用模塊中的時候, 可以使用forChild 方法實(shí)現(xiàn).
例如:

import { NgModule } from '@angular/core';
+ import { MarkdownModule } from 'ngx-markdown';

import { HomeComponent } from './home.component';

@NgModule({
  imports: [
+   MarkdownModule.forChild(),
  ],
  declarations: [HomeComponent],
})
export class HomeModule { }

3. 使用

3.1 組件

有三種方式來將markdown文件渲染為HTML.
分別是:

<!-- static markdown -->
<markdown>
  # Markdown
</markdown>

<!-- loaded from remote url -->
<markdown [src]="'path/to/file.md'" (error)="onError($event)"></markdown>

<!-- variable binding -->
<markdown [data]="markdown"></markdown>

第三種, 是使用的Angular中的數(shù)據(jù)綁定.

3.2 指令組件(Directive)

<!-- static markdown -->
<div markdown>
  # Markdown
</div>

<!-- loaded from remote url -->
<div markdown [src]="'path/to/file.md'" (error)="onError($event)"></div>

<!-- variable binding -->
<div markdown [data]="markdown"></div>

3.3 管道(Pipe)

<!-- chain `language` pipe with `markdown` pipe to convert typescriptMarkdown variable content -->
<div [innerHTML]="typescriptMarkdown | language : 'typescript' | markdown"></div>

3.4 服務(wù)(Service)

import { Component, OnInit } from '@angular/core';
import { MarkdownService } from 'ngx-markdown';

@Component({ ... })
export class ExampleComponent implements OnInit() {
  constructor(private markdownService: MarkdownService) { }

  ngOnInit() {
    // outputs: <p>I am using <strong>markdown</strong>.</p>
    console.log(this.markdownService.compile('I am using __markdown__.'));
  }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市姚糊,隨后出現(xiàn)的幾起案子贿衍,更是在濱河造成了極大的恐慌,老刑警劉巖救恨,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贸辈,死亡現(xiàn)場離奇詭異,居然都是意外死亡肠槽,警方通過查閱死者的電腦和手機(jī)擎淤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來秸仙,“玉大人嘴拢,你說我怎么就攤上這事〖偶停” “怎么了炊汤?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長弊攘。 經(jīng)常有香客問我抢腐,道長,這世上最難降的妖魔是什么襟交? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任迈倍,我火速辦了婚禮,結(jié)果婚禮上捣域,老公的妹妹穿的比我還像新娘啼染。我一直安慰自己,他們只是感情好焕梅,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布迹鹅。 她就那樣靜靜地躺著,像睡著了一般贞言。 火紅的嫁衣襯著肌膚如雪斜棚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天,我揣著相機(jī)與錄音弟蚀,去河邊找鬼蚤霞。 笑死,一個胖子當(dāng)著我的面吹牛义钉,可吹牛的內(nèi)容都是我干的昧绣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼捶闸,長吁一口氣:“原來是場噩夢啊……” “哼夜畴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起删壮,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤贪绘,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后醉锅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡发绢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年硬耍,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片边酒。...
    茶點(diǎn)故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡经柴,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出墩朦,到底是詐尸還是另有隱情坯认,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布氓涣,位于F島的核電站牛哺,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏劳吠。R本人自食惡果不足惜引润,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望痒玩。 院中可真熱鬧淳附,春花似錦、人聲如沸蠢古。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽草讶。三九已至洽糟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背脊框。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工颁督, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浇雹。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓沉御,卻偏偏與公主長得像,于是被迫代替她去往敵國和親昭灵。 傳聞我的和親對象是個殘疾皇子吠裆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容