成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

實(shí)現(xiàn)自己的“單頁”博客,只需要一個(gè)指令 (Moka)

JeOam / 2008人閱讀

摘要:如今單頁應(yīng)用橫行霸道而且新時(shí)代知識(shí)信息海量我們更需要自己的來沉淀知識(shí)。綜上走入了我們的實(shí)現(xiàn)。還有默認(rèn)主題是用開發(fā)的但不幸的是本人誤操作把源碼都刪了但萬幸的是留下了生產(chǎn)環(huán)境的代碼

如今,單頁應(yīng)用"橫行霸道", 而且新時(shí)代知識(shí)信息海量,我們更需要自己的Blog來沉淀知識(shí)。
綜上,Moka走入了我們的實(shí)現(xiàn)。

github.com/moyuyc/moka

Usage

為了第一眼能看到效果, 我先把如何安裝使用說一下。

一切從npm開始

    $ npm i -g moka-cli

安裝完成后

$ moka -h # 幫助
$ moka -v # 版本

$ mkdir myBlog
$ cd myBlog
$ moka i  # 開啟自己的spa Blog
$ moka g  # generate static pages
$ moka s  # 開啟本地服務(wù),可以在本地看到效果了!
$ moka n abc # 新建一個(gè)article

$ moka d  # 根據(jù) moka.config.json deploy 發(fā)布 
$ moka b  # 根據(jù) moka.config.json bak 備份所有文件

線上效果
moyuyc.github.io

Moka主題配置

默認(rèn)主題是用react/webpack開發(fā)的,
但...不幸的是, 本人誤操作把源碼都刪了..., 但萬幸的是...留下了build, 生產(chǎn)環(huán)境的代碼...

{
  "avatar": "/head.jpg", // 頭像
  "title": " Moyu Dev Blog ", // 網(wǎng)站title
  "description": " Web, Node C/C++ Dev ",

  "mainInfoColor": "", // 首頁信息的文字顏色, 默認(rèn)白色
  "canvasColor": "",   // 首頁飄散的雪花顏色

  "leftPercentage": 50,// 左側(cè)百分比, 右側(cè)將會(huì)自動(dòng)為100-leftPercentage, <=0 將會(huì)在非首頁頁面隱藏left

  "pageSize": 6, // 每頁文章數(shù)目, <=0 一頁展示所有
  "summaryNum": 50, // 摘要的文字截?cái)嘧謹(jǐn)?shù)

  "postTarget": "_blank", // 文章中l(wèi)ink的跳轉(zhuǎn)方式
  "iconTarget": "_blank", // 左側(cè)icon的link的跳轉(zhuǎn)方式
  "projectTarget": "_blank", // project中l(wèi)ink的跳轉(zhuǎn)方式

  "home": { // 首頁中右側(cè)文字內(nèi)容
    "title": "About Me",
    "contentHtml": "

I’m a Javascript enthusiast. I organise Baidu BEFE Meetup and try my best to help out with the team. I’m also a member of the core dev team.

" }, // projects "projects": [ { "title": "Moyu Theme", "state": "Doing", //可無 "image": "https://raw.githubusercontent.com/TaylanTatli/Ramme/master/assets/img/screenshot-post.png" "link": "" // 點(diǎn)擊跳轉(zhuǎn)地址 }, { "title": "Moyu Theme", "state": "Doing", "image": "https://raw.githubusercontent.com/TaylanTatli/Ramme/master/assets/img/screenshot-post.png" }, { "title": "Moyu Theme", "state": "Doing", "image": "https://raw.githubusercontent.com/TaylanTatli/Ramme/master/assets/img/screenshot-post.png" }, { "title": "Moyu Theme", "state": "Doing", "image": "https://raw.githubusercontent.com/TaylanTatli/Ramme/master/assets/img/screenshot-post.png" }, { "title": "Moyu Theme", "state": "Doing", "image": "https://raw.githubusercontent.com/TaylanTatli/Ramme/master/assets/img/screenshot-post.png" } ], "icon": [ // 左側(cè)icons key命名參看font-awesome.css { "github": "https://github.com/moyuyc" } ], "coverImage": { // 左側(cè)封面 "images": { "tags": "http://taylantatli.me/Halve/images/unsplash-gallery-image-3.jpg", "home": "http://taylantatli.me/Halve/images/unsplash-image-10.jpg", "article": "http://taylantatli.me/Halve/images/unsplash-gallery-image-3.jpg", "serach": "http://taylantatli.me/Halve/images/unsplash-image-10.jpg", "notExist": "http://taylantatli.me/Halve/images/unsplash-gallery-image-3.jpg", "posts": [ // posts可為數(shù)組(對(duì)于每一頁), 可為字符串 "http://taylantatli.me/Halve/images/unsplash-image-10.jpg", "http://taylantatli.me/Halve/images/home.png", "http://taylantatli.me/Halve/images/unsplash-gallery-image-3.jpg" ] }, "articleCover": true // 是否開啟文章封面, 在文章頭部配置 `cover: ...` 效果請(qǐng)看默認(rèn)文章`Linux C學(xué)習(xí)一周` } }
Document

Moka, 認(rèn)為前端UI與數(shù)據(jù)應(yīng)該完全分離開來, 而不是像hexo那樣傳統(tǒng)的blog。
這樣做的好處不言而喻, 可能第一次加載數(shù)據(jù)較多, 但是后續(xù)操作更加暢快, 網(wǎng)站體驗(yàn)更加優(yōu)化了。

既然如此, 那么Moka產(chǎn)生的數(shù)據(jù)是什么樣子的呢?

數(shù)據(jù)格式

Moka 采用主流的json字符串

$ moka generate 后產(chǎn)生的json如下

{
    "main": {
        "filename": {
            "content": "...",
            "head": {
                "date": "",
                "title": "",
                "tags": [tagnames...] or "tagname"
            }
        }
    },
    "index": {
        "sorted": [filenames...],
        "tagMap": {
            "tagname": [filenames...]
        }
    }
}

說明

"content"可以通過配置控制, 返回markdown或者html(請(qǐng)看下文配置returnRaw說明)

"head"表示在文章中頭部---...---中解析出來的數(shù)據(jù), tags 可以是Array(多個(gè))或String(單個(gè))

"sorted"為按照時(shí)間倒序的filenames數(shù)組

"tagMap"為所有tag的映射, 即哪些文章包含"tagname"

配置說明

主要包含 default config, moka.config.json, theme.config.json, theme.config.js

default configMoka初始配置, 不推薦修改

{
 theme: "moka", // 當(dāng)前主題
 apiRoot: "moka_api", // moka generate 數(shù)據(jù)和配置 所存放的文件夾
 
 skipRegExp: "/[^.(md|markdown)]$/", // 在 _articles 中渲染忽略的文件名正則表達(dá)式
 
 timeFormat: "YYYY/MM/DD HH:mm:ss", // 默認(rèn)產(chǎn)生的時(shí)間格式 (參看moment.js)

 // marked 配置參看(marked.js: https://github.com/chjj/marked)
 marked: {
     options: {
         gfm: true,
         tables: true,
         breaks: false,
         pedantic: false,
         sanitize: false,
         smartLists: true,
         smartypants: false,
         highlight: function (code) {
return require("highlight.js").highlightAuto(code).value;
         }
     },
     setup: function (renderer) {
         renderer.heading = function (text, level) {
var escapedText = text.toLowerCase().replace(/[^w]+/g, "-");

return "" +
text + "";
         }
     }
 },

 returnRaw: false,  // * 是否返回markdown字符串, 那么需要主題自己轉(zhuǎn)換markdown
 title: "Blog",
 favicon: "favicon.ico", // 網(wǎng)站圖標(biāo)
 injectScript: true,  // 是否注入`moka.inject.js`
 themeBuild: "build" // 將會(huì)取 themes/moka/build 中文件放到 static 中, 認(rèn)為build為生產(chǎn)環(huán)境代碼
}

moka.config.json 為全局站點(diǎn)配置, 在apiRoot中可以得到

{
    "theme": "moka",
    "title": "Moyu Blog",
    "favicon": "favicon.ico",
    "author": "moyu",
    "description": "moyu Blog",
    "siteName": "site",
    
    // moka generate 配置
    "deploy": {
        "type": "git",
        "url": "https://github.com/moyuyc/moyuyc.github.io.git",
        "branch": "master"
    }
}

theme.config.json 為主題配置, 在apiRoot中可以得到, 完全為主題開發(fā)者自定義

關(guān)于默認(rèn)主題配置說明, 請(qǐng)看[theme readme](THEME_README.md)

theme.config.js 為了主題開放者也能夠控制Moka產(chǎn)生數(shù)據(jù), 可以修改該文件, 從而覆蓋默認(rèn)配置

module.exports = {
    apiRoot: "moka_api",
    skipRegExp: "/[^.(md|markdown)]$/",
    //http://momentjs.com/
    timeFormat: "YYYY-MM-DD HH:mm", // 返回的時(shí)間格式

    marked: {
        options: {
            gfm: true,
            tables: true,
            breaks: false,
            pedantic: false,
            sanitize: false,
            smartLists: true,
            smartypants: false
        },
        setup: function (renderer) {
            // 在這里控制renderer規(guī)則, 詳細(xì)請(qǐng)看 marked
        }
    },
    
    returnRaw: false,
    themeBuild: "build",
}

閑話

開發(fā)者可以通過ajax/fetch/...異步獲取 apiRoot配置下的db.json/moka.config.json/theme.config.json

然后盡情用react/vue/webpack/...開發(fā)自己喜歡的主題吧。

還有默認(rèn)主題是用react/webpack開發(fā)的,
但...不幸的是, 本人誤操作把源碼都刪了..., 但萬幸的是...留下了build, 生產(chǎn)環(huán)境的代碼...

star it!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92361.html

相關(guān)文章

  • 一句命令!搞定高逼格單頁博客

    摘要:需要環(huán)境與環(huán)境下請(qǐng)?jiān)谥袌?zhí)行效果見更多信息搭建單頁桌面版,專為設(shè)計(jì) 需要node環(huán)境與git環(huán)境 curl -s https://raw.githubusercontent.com/moyuyc/my-shell-code/master/moka-start.sh | bash windows下請(qǐng)?jiān)趃it bash中執(zhí)行 效果見moyuyc.github.io 更多信息 moka =...

    keithyau 評(píng)論0 收藏0
  • 使用Vue快速開發(fā)單頁應(yīng)用-vue-router

    摘要:當(dāng)前路由對(duì)象調(diào)用此函數(shù)處理切換過程的下一步終止切換重定向到另一個(gè)路由由于是路由切換后,只有上面的兩個(gè)屬性。原文地址其他使用快速開發(fā)單頁應(yīng)用主體結(jié)構(gòu)使用快速開發(fā)單頁應(yīng)用使用快速開發(fā)單頁應(yīng)用登錄頁面使用快速開發(fā)單頁應(yīng)用功能組件與路由組件通信 本文所涉及代碼全在vue-cnode vue-router主要作用是將路由控制,轉(zhuǎn)移到前端。我們將會(huì)在vue-router里面保存一個(gè)路由表,在vue...

    mingde 評(píng)論0 收藏0
  • 采用vue+webpack構(gòu)建單頁應(yīng)用——私人博客MintloG誕生記

    摘要:我采用原生編寫后臺(tái),因?yàn)楦杏X增刪改查的功能很簡(jiǎn)單,就懶得用框架了其實(shí)是不會(huì)。瀏覽模式它也有一個(gè),用來切換文章列表和文章詳情,也就是和編輯模式它加載了作為工具欄,然后可以進(jìn)行文章的撰寫與修改。 介紹 項(xiàng)目地址:https://github.com/jrainlau/MintloG (特別亂,參考就好-_-|||)showImg(https://segmentfault.com/img/b...

    Terry_Tai 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<