用Razor作靜態頁面生成器

原本是用asp.net webpages作的博客網站,數據庫用了一個陌生的本地數據庫,只是以爲用起來很爽快,用新鮮的東西有一種刺激。後來數據庫掛了,估計是存某個字段的時候出了問題,但是新鮮的東西,也不知道用什麼工具能夠查,只好怪本身太年輕。費了一番力氣,總算是把數據挽救回來,忽然意識到阿里雲那邊又快到期了。html

不打算續租了,備案又麻煩,乾脆就改爲靜態,掛GitHub吧。前端

關於GitHub上建站的方法直接看這裏 https://pages.github.com/git

建完以後設置CNAME和A Record綁定好域名。github

以後就能夠用Git來上傳頁面了,還可使用Jekyll來製做博客。可是我是不懂那些的,技能樹點的不同,也懶得爲了一個博客去學另外一顆樹上的東西。web

追溯當時用webpages的緣由,其實也是由於Razor,因此計劃落定,用Razor作模版,Markdown作博文編輯,最後生成html。還須要把博文記錄下來,隨便用什麼均可以,就直接存本地文件了,換言之這文件就成了我網站的數據庫,爲了之後檢查方便就用文本文件。數據庫

一、Razor模板markdown

二、Markdown編輯asp.net

三、Json存檔編輯器

這樣定好以後,建立解決方案,WPF項目模板,NuGet添加RazorEngine、MarkdownSharp、NewtonsoftJson,建立一個窗體,Page導航,兩個Page,分別是目錄頁和內容頁。工具

目錄頁是一個ListView,列出全部的文章,建立Article類,有屬性Title, Content, Author, Time, Description, Link。Link是生成以後的存放的靜態頁面的路徑,能夠帶/符號。

目錄頁上能夠新建和刪除文章,右下角是導出按鈕,點擊生成整站的頁面。由於是博客站,因此確定有兩類頁面,也是目錄頁和博文內容頁。目錄頁是根路徑下的index.html, 內容頁將依據編輯時候錄入的Link屬性,生成對應的路徑,並在改路徑下建立index.html,因而你訪問的時候能夠是這個樣子http://localhost/2015/1/1/link/

雙擊ListViewItem,也就是其中一篇文章,Page Navigate到內容頁,在內容頁你能夠編輯文章,左邊是編輯界面右邊是預覽界面。編輯採用Markdown語法。

Save保存,Back按鈕導航回上一頁。

這裏我在Save的時候會序列化成JSON寫入本地文件,須要妥善保存此文件。

在目錄頁進行導出操做的時候,會讀取模板文件,模板文件有兩個,請看下圖

編譯後使用的時候須要確保Template目錄下有這兩個文件。後綴是cshtml,雖然能夠是任意後綴,但cshtml能獲得vs編輯器的幫助,模板中使用razor語法調用@Model中的屬性,自定義前端標籤來進行佈局。在Index.cshtml中,Model就是List<Article>,在Detail.cshtml中,Model是Article。

以文章頁面的導出爲例,關鍵代碼以下:

Markdown mk = new Markdown();
string content = mk.Transform(article.Content);//markdown轉換html
var model = new
{
ID
= article.ID, Title = article.Title, Content = content, Link = article.Link, WriteTime = article.WriteTime, Description = article.Description, Author = article.Author, }; string text = Engine.Razor.RunCompile(WebSource.Instance.DetailTemplate, "templateDetail", null, model);//razor轉換html string outputFilePath = string.Format("{0}/output/{1}", AppDomain.CurrentDomain.BaseDirectory, article.Link); Directory.CreateDirectory(outputFilePath);//建立目錄 File.WriteAllText(outputFilePath + "/index.html", text);//寫入文件

最後生成的整站頁面在output目錄下。

工具完成,花了一個多小時的時間。嗯,Razor用來作代碼生成確實很好使。

下面是第一個試驗品

http://ifchen.com/

相關文章
相關標籤/搜索