摘要:如今單頁應(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
默認(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": "DocumentI’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í)一周` } }
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 config 為Moka初始配置, 不推薦修改
{ 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
摘要:需要環(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 =...
摘要:當(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...
摘要:我采用原生編寫后臺(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...
閱讀 2153·2023-05-11 16:55
閱讀 3516·2021-08-10 09:43
閱讀 2631·2019-08-30 15:44
閱讀 2452·2019-08-29 16:39
閱讀 594·2019-08-29 13:46
閱讀 2015·2019-08-29 13:29
閱讀 931·2019-08-29 13:05
閱讀 702·2019-08-26 13:51