MarkNoteParser - 用Swift/Obj-c實(shí)現(xiàn)的markdown解析器

我用Obj-c和Swfit實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的markdown解析器,源代碼放在github上了。
Objective-C 版本: https://github.com/marknote/MarkNoteParserObjC
Swift 版本: https://github.com/marknote/MarknoteParser

緣由

我有一個(gè)小應(yīng)用 MarkNote ,這是一個(gè)使用markdown語(yǔ)法來(lái)記筆記的小工具。
最開(kāi)始的時(shí)候, 我使用 marked 來(lái)把 markdown 渲染為HTML。marked使用起來(lái)簡(jiǎn)單。不過(guò),一個(gè)native的應(yīng)用居然用基于javascript的引擎來(lái)做解析,心里總覺(jué)得有點(diǎn)不爽 :)
找了找沒(méi)找到合適的
基于Swfit/Object-c實(shí)現(xiàn)的 markdown解析起 , 我決定自己輪子一個(gè)。于是就有了這個(gè)項(xiàng)目。
一開(kāi)始我只是實(shí)現(xiàn)了Swfit版本,后來(lái)xcode升級(jí)到7.0之后,swift的應(yīng)用文件生成很大,很多時(shí)候都大于40m(當(dāng)然,app store最后會(huì)優(yōu)化,尺寸大大減少)。于是覺(jué)得obj-c也很有必要,就又一口氣擼了一個(gè) obj-c版本的。

使用方法

swift 版本

  • 直接拷貝以下2個(gè)文件到你的工程中:
    -- StringExtensions.swift , String 類(lèi)擴(kuò)展;
    -- MarkNoteParser.swift, 這是解析器類(lèi);

  • 在你的代碼中就直接可以調(diào)用 MarkNoteParser.toHtml() 把markdown文本轉(zhuǎn)為HTML 字符, 用法如下:

func markdown(input :String)->String{
        let result = MarkNoteParser.toHtml(input)
        println("input: \(input) result:\(result)")
        return result
    }

objective-c 版本

  • 把 "MarkNoteParserOC" 目錄下的所有文件拷貝到你的工程中 , 然后在你的代碼中引入頭文件:
#import "MarkNoteParser.h"

-然后你就可以使用 MarkNoteParser 來(lái)解析markdown了,示例如下:

NSString* result = [MarkNoteParser toHtml:input];
return result;

特點(diǎn)

標(biāo)題支持

# H1
## H2
### H3

轉(zhuǎn)換為:

<h1>H1</h1><h2>H2</h2><h3>H3</h3>

粗體斜體Emphasis支持

Emphasis, aka italics, with *asterisks* or _underscores_.
Strong emphasis, aka bold, with **asterisks** or __underscores__.
Strikethrough uses two tildes. ~~Scratch this.~~

轉(zhuǎn)換為:

<p>Emphasis, aka italics, with <em>asterisks</em> or <em>underscores</em>.<br/></p>
<p>Strong emphasis, aka bold, with <strong>asterisks</strong> or <strong>underscores</strong>.<br/></p>
<p>Strikethrough uses two tildes. <u>Scratch this.</u><br/></p>

鏈接支持

[I'm an inline-style link](https://www.google.com)
[I'm an inline-style link with title](https://www.google.com "Google's Homepage")

轉(zhuǎn)換為:

<p><a m an inline-style link</a><br/></p>
<p><a  title="Google's Homepage">I'm an inline-style link with title</a><br/></p>

圖片支持

![alt text](https://avatars3.githubusercontent.com/u/12975088?v=3&s=40 "Logo Title")

轉(zhuǎn)換為:

<img src="https://avatars3.githubusercontent.com/u/12975088?v=3&s=40" title="Logo Title" alt="alt text" />

代碼支持

<pre class="lang-markdown">

var s = "JavaScript syntax highlighting";
alert(s);

</pre>

轉(zhuǎn)換為:

<pre class="lang-javascript">
var s = "JavaScript syntax highlighting";
alert(s);
</pre>

表格支持

| Tables        | Are           | Cool  |
| ------------- |:-------------:| -----:|
| col 3 is      | right-aligned | $1600 |
| col 2 is      | centered      |   $12 |
| zebra stripes | are neat      |    $1 |

轉(zhuǎn)換為:

<table><tr><th> Tables        </th><th> Are           </th><th style="text-align: center;"> Cool </th></tr><tr><td> col 3 is      </td><td> right-aligned </td><td style="text-align: center;"> $1600 </td></tr><tr><td> col 2 is      </td><td> centered      </td><td style="text-align: center;">   $12 </td></tr><tr><td> zebra stripes </td><td> are neat      </td><td style="text-align: center;">    $1 </td></tr></table><p>The outer pipes (|) are optional, and you don't need to make the raw Markdown line up prettily. You can also use inline Markdown.<br/></p>

問(wèn)題反饋

如果你有任何問(wèn)題或者建議,可以在這里給我反饋。謝謝!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,252評(píng)論 4 61
  • 魚(yú)頭上大學(xué)生時(shí),談了一個(gè)男朋友,學(xué)生時(shí)代不是每個(gè)人都有很多錢(qián),一起逛街時(shí),魚(yú)頭畢竟是作為女孩子,看到好看的衣服都喜...
    陳奕蓉閱讀 477評(píng)論 0 2
  • 最近《楚喬傳》火熱了熒屏,我也追起了趙麗穎, 不造勢(shì),不整容,穎寶可是娛樂(lè)圈里難得的一股清流啊。 其實(shí)林更新飾演的...
    葉塞尼婭閱讀 527評(píng)論 0 1
  • 奧地利心理學(xué)家阿德勒曾提出過(guò)“補(bǔ)償心理”理論,講的是: 一個(gè)人在成長(zhǎng)過(guò)程中總會(huì)有一些生理或心理上的不足,為...
    Chaylse醬閱讀 524評(píng)論 0 0