摘要:異步任務的核心是名稱與任務名一致的函數(shù),該函數(shù)接受兩個參數(shù)一個函數(shù)和命令行的輸入值。
廢話:如果是“不能給 hr 發(fā)這樣的簡歷”之類大家都懂的話,麻煩您就不要回復了,謝謝! 國際慣例: https://github.com/dongsuo/vu... 正文:
作為一名程序員,還是有一份有特色的在線簡歷會比較好吧……
在線簡歷很容易做得很丑哎……
套模板這種事情有點丟人呀……
那……干嘛不用程序員最熟悉的命令行來寫簡歷呢?
啊咧?!
上圖就是一個用vuejs在瀏覽器中模擬出來的終端界面,用這個來做一份簡歷還是有點小酷吧?(在線體驗:https://dongsuo.github.io/ter...,源碼:https://github.com/dongsuo/vu...
OK,閑話少敘,來動手做一個吧。
首先,你需要把這個項目(https://github.com/dongsuo/vu... fork到你自己的Github目錄下,然后pull到本地。(如果你不明白這一步的話,以下是你可以在谷歌或者百度輸入框輸入的關(guān)鍵詞:git,github,倉庫,repository,本地倉庫。所有關(guān)鍵詞可以隨意組配,直到你明白這一步為止,下同。)
然后,在你本地的命令行工具中,進入本地項目目錄,執(zhí)行 npm install,等任務跑完,執(zhí)行 npm run dev就可以了,你的默認瀏覽器會自動打開 http://localhost:8080 這個地址。(關(guān)鍵詞:nodejs, npm, 淘寶鏡像,node_modules目錄)
接下來就是實質(zhì)性的工作了,由于vue-terminal-emulator還沒有文檔,所以這篇短文就算是文檔了,我會寫得盡量詳細一些。
目錄結(jié)構(gòu)按照慣例,先從目錄結(jié)構(gòu)開始吧:
├── build // 構(gòu)建相關(guān) ├── config // 配置相關(guān) ├── docs // 構(gòu)建輸出目錄 ├── src // 源代碼 │ ├── components // 組件 │ ├── plugins // 插件 │ │ ├── commandList.js // 命令列表 │ │ └── taskList.js // 任務列表 │ ├── App.vue // 入口頁面 │ └── main.js // 入口 加載組件 初始化等 ├── .babelrc // babel-loader 配置 ├── eslintrc.js // eslint 配置項 ├── .gitignore // git 忽略項 ├── favicon.ico // favicon圖標 ├── index.html // html模板 └── package.json // package.json
基本結(jié)構(gòu)就是vue-cli項目的默認結(jié)構(gòu),主要src目錄下的文件需要介紹一下:
components下是 VueTerminalEmulator 組件,主要的邏輯和樣式都封裝在這個文件中,你可以完全不管這個文件。
我們主要需要配置的文件是 plugins/commadnList.js 和 plugins/taskList.js 這兩個文件,這兩個文件的基本結(jié)構(gòu)是一致的,都 export一個對象,對象key是任務或者命令名稱,值是由 description 和 messages/task 組成的對象,基本的結(jié)構(gòu)如下所示:
{ commandOrTask:{ description:"", messagesOrTask:[]//(function) } }
VueTerminalEmulator 組件會import這兩個文件,根據(jù)其中的配置生成幫助項并執(zhí)行相應的指令,其中description即為"help"指令中各個命令的幫助信息。
// VueTerminalEmulator 中引入配置文件 import commandList from "./../plugins/commandList" import taskList from "./../plugins/taskList"
其中,commandList 中存放靜態(tài)的指令,指令執(zhí)行之后,直接列出所有 message,然后指令結(jié)束,無需等待。而taskList 中是異步的任務,指令執(zhí)行后組件會進入loading狀態(tài),任務完成后,通過resolve一個消息來通知VueTerminalEmulator 組件任務結(jié)束,解除loading狀態(tài)(關(guān)鍵詞:異步、promise、resolve)。以下是這兩種命令的例子:
異步任務:
help是典型的靜態(tài)指令:
靜態(tài)指令commandList 中的核心是messages數(shù)組,數(shù)組內(nèi)是多個message對象,執(zhí)行command時,會將command中的message顯示在Terminal窗口中,比較簡單,不多說,一個示例就解決了:
contact: { description: "How to contact author", messages: [ { message: "Website: http://xiaofeixu.cn" }, { message: "Email: [email protected]" }, { message: "Github: https://github.com/dongsuo" }, { message: "WeChat Offical Account: dongsuo" } ] }
就是這么簡單,不需要更多的語言。
異步任務taskList 的核心是名稱與任務名一致的函數(shù),該函數(shù)接受兩個參數(shù):一個函數(shù)(pushToList)和命令行(input)的輸入值。你可以根據(jù)input值來執(zhí)行具體的任務,然后將message作為參數(shù)調(diào)用pushToList().當任務結(jié)束時,需要返回一個promise,promise要resolve一個message對象通知組件任務結(jié)束,如有需要,也可以reject一個message對象通知組件任務出錯,示例代碼:
echo: { description: "Echoes input, Usage: echo", //echo將用戶的輸入原封不動地返回,顯示在terminal窗口中 echo(pushToList, input) { //解析用戶輸入 input = input.split(" ") input.splice(0, 1) const p = new Promise(resolve => { // 將message對象作為參數(shù)調(diào)用pushToList() pushToList({ time: generateTime(), label: "Echo", type: "success", message: input.join(" ") }); // 通過resolve一個message對象通知組件任務結(jié)束 resolve({ type: "success", label: "", message: "" }) }) // 返回 promise 對象 return p } }
好了,核心內(nèi)容就是這么多,下面介紹一下上文中提到多次的message對象:
message 對象{ time: generateTime(), type: "warning", label: "warning", message: "This is a Waning Message!" }
message對象目前支持如上四個字段:
time字段可省略,建議使用提供的 generateTime 方法,也可自己配置;
type可省略,目前支持5個值:info,warning,success,error,system,分別對應5種顏色,用于label字段的高亮;
label字段可省略,可隨意賦值,但是不建議太長,影響美觀;
message為必須字段就是純文本內(nèi)容;
部署當你已經(jīng)確認簡歷做好、沒有bug之后,就可以部署了,首先執(zhí)行npm run build命令,然后把你的代碼push到Github上,點擊settings, 找到Github Pages,將source設置為docs folder,點擊save就部署成功了。
That"s All以上就是做一個命令行簡歷所需要知道的全部內(nèi)容了,如果還有小伙伴有問題的話,歡迎issue或者pr.
https://github.com/dongsuo/vu...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89754.html
摘要:這應該是你見過的最全前端下載總結(jié)自己整理的一些項目中遇到過的關(guān)于上傳和下載的一些,大前端系列也就是純前端端完成的下載,只要獲取到數(shù)據(jù)下載工作全是前端來做,僅供給位看官參考,避免踩坑,即插即用,歡迎和 這應該是你見過的最全前端下載總結(jié)自己整理的一些項目中遇到過的關(guān)于上傳和下載的一些Demo,大前端系列(也就是純前端 + node端完成的下載,只要獲取到數(shù)據(jù)下載工作全是前端來做),僅供給位...
摘要:依云醬呢,是一名資深用戶已經(jīng)不會用現(xiàn)在的的,喜歡同時也屬蛇,看來是命中注定,最近喜歡上了不是那個黃褐色的鐵氧化合物哦。清蒸依云醬,我快死在你的標題上了。 showImg(https://segmentfault.com/img/bVRChj?w=900&h=385); 社區(qū)訪談的上期說到上帝有明是如何通過他的個人魅力撩得妹紙歸,回憶傳送門,不過逗得了妹紙笑,引得了漢紙拜(唔,崇拜的拜,...
摘要:依云醬呢,是一名資深用戶已經(jīng)不會用現(xiàn)在的的,喜歡同時也屬蛇,看來是命中注定,最近喜歡上了不是那個黃褐色的鐵氧化合物哦。清蒸依云醬,我快死在你的標題上了。 showImg(https://segmentfault.com/img/bVRChj?w=900&h=385); 社區(qū)訪談的上期說到上帝有明是如何通過他的個人魅力撩得妹紙歸,回憶傳送門,不過逗得了妹紙笑,引得了漢紙拜(唔,崇拜的拜,...
摘要:沒有任何意外,王小二的公司用來開發(fā)公司的主打產(chǎn)品。臃腫的著手開干吧小二打開熟悉的,找到提交訂單模塊的。要不再去請教下哥的煩惱小二找到哥,詳細的描述了他的問題。 流行的MVC架構(gòu)模式 如今的Web開發(fā),各種框架風起云涌,勢如破竹。 從國民第一的ThinkPhp到稱霸全球的Laravel,這些框架有一個共同特征,都采用了MVC的架構(gòu)模式。 showImg(https://segmentfa...
閱讀 3257·2021-11-11 11:00
閱讀 2574·2019-08-29 11:23
閱讀 1457·2019-08-29 10:58
閱讀 2339·2019-08-29 10:58
閱讀 2963·2019-08-23 18:26
閱讀 2520·2019-08-23 18:18
閱讀 2049·2019-08-23 16:53
閱讀 3424·2019-08-23 13:13