<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        使用yeoman構(gòu)建angular應(yīng)用的方法

        來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:32:57
        文檔

        使用yeoman構(gòu)建angular應(yīng)用的方法

        使用yeoman構(gòu)建angular應(yīng)用的方法:本文將介紹如何親手來完成一個yeoman的generator,以實現(xiàn)快速構(gòu)建最適合自己的項目。 本文將實現(xiàn)的generator起名為ngtimo,依照yeoman的命名規(guī)矩就叫做generator-ngtimo,是筆者這周末一晚上加一上午參考著yeoman官方給出的幾個generator(g
        推薦度:
        導讀使用yeoman構(gòu)建angular應(yīng)用的方法:本文將介紹如何親手來完成一個yeoman的generator,以實現(xiàn)快速構(gòu)建最適合自己的項目。 本文將實現(xiàn)的generator起名為ngtimo,依照yeoman的命名規(guī)矩就叫做generator-ngtimo,是筆者這周末一晚上加一上午參考著yeoman官方給出的幾個generator(g

        本文將介紹如何親手來完成一個yeoman的generator,以實現(xiàn)快速構(gòu)建最適合自己的項目。
        本文將實現(xiàn)的generator起名為ngtimo,依照yeoman的命名規(guī)矩就叫做generator-ngtimo,是筆者這周末一晚上加一上午參考著yeoman官方給出的幾個generator(generator-generator、generator-node)給強行催生出來的,目前也已經(jīng)在github上托管并發(fā)布到npm。

        實現(xiàn)效果

        首先確保已經(jīng)全局安裝了yeoman,然后再全局安裝generator-ngtimo:

        npm install -g generator-ngtimo

        安裝完成后即可使用yo命令來進行構(gòu)建:

        yo ngtimo

        然后順利的話yeoman會像下面這樣詢問一系列構(gòu)建的配置,這里筆者選擇輸入項目名稱為ng-test剩下的一路敲回車:

        順利的話如下圖這樣的項目結(jié)構(gòu)就誕生了,可以 cd 到項目目錄下(自動執(zhí)行的 npm install 失敗的話再手動
        npm install 一下),并運行 npm run server 啟動項目查看效果。

        如果只是想要使用yeoman來快速進行項目搭建的話,只需要找到一個喜歡的generator,像上文這樣全局安裝然后yo它就可以了!不過只是使用別人的generator會有些不自由而且考驗對方的維護能力,就像筆者這個一時興起的ngtimo就才剛剛有了一個主模板而已,還需要做很多改進和迭代。

        如果想要自己來編寫一個generator其實難度也非常小,yeoman官方甚至給出了一個generator-generator來幫助我們創(chuàng)建一個generator,筆者這個不成器的ngtimo也是yo generator給yo出來然后加以養(yǎng)成的 :)。

        yeoman generator基本項目結(jié)構(gòu)

        不想自己從零開始寫一個generator的話強烈推薦使用yeoman官方的generator-generator先把基本結(jié)構(gòu)構(gòu)建出來:

        npm install -g generator-generator
        yo generator

        yeoman的generator說白也只是一個npm包,主要依賴yeoman-generator包來制定構(gòu)建規(guī)則,這里給出ngtimo的基本目錄結(jié)構(gòu):

        構(gòu)建規(guī)則

        現(xiàn)在主要著眼于generators/app/index.js,此文件是最主要的角色,定義了ngtimo要如何處理模板,如何與用戶交互等。筆者目前也只是照著比較成熟的generator在使用,存在片面之處還請包涵。

        總覽index.js

        整個index.js將導出一個擴展了yeoman-generator的類,就像這樣:

        const Generator = require('yeoman-generator');
        // ...
        module.exports = class extends Generator {
         prompting() {
         // ...
         }
         default() {
         // ...
         }
         writing() {
         // ...
         }
         install() {
         // ...
         }
        }

        內(nèi)部的這四個方法各有用處。

        一、prompting方法

        用于與用戶進行交互,即在yo項目的時候,這老頭會啰啰嗦嗦問我們很多問題,這些問題就是在這里配置的。

        對于這個方法筆者選擇的套路是如下三部曲:

        先讓老頭向用戶問聲好

        const yosay = require('yosay');
        // ...
        this.log(yosay(
         'Welcome to the astonishing ' + chalk.red('generator-ngtimo') + ' generator!'
        ));

        以上代碼效果就是老頭會代我們問候(褒義)一下用戶:

        把一連串問題先配置好

        const prompts = [{
         type: 'input',
         name: 'appName',
         message: 'Your project name(你的項目名稱)',
         default: this.appname
        }, {
         type: 'confirm',
         name: 'addCommon',
         message: 'Would you like to add some common code(include CoreModule, SharedModule, Router)?\n(要自動創(chuàng)建額外的常用內(nèi)容嗎, 包含了核心模塊、共享模塊和路由能力)',
         default: true
        }];

        這里就列舉了兩類問題,一類是客觀題,讓用戶輸入要構(gòu)建的項目名稱,另一類是判斷題,詢問用戶是否添加一些額外的常用代碼,還有一類沒有使用到的是選擇題,還蠻有趣的。

        把這個問題數(shù)組返回給老頭

        問題數(shù)組配置好了,現(xiàn)在要把它交給老頭保管,做法如下:

        return this.prompt(prompts).then(props => {
         // 用戶交互完成后把得到的配置設(shè)置到參數(shù)中
         this.props = props;
        });

        效果就是當用戶做完這些題目后回答會配置給props變量,在后面的寫如內(nèi)容環(huán)節(jié)就可以根據(jù)用戶的答案來有選擇的創(chuàng)建項目了。

        二、default方法

        筆者一開始沒有配置這個方法,是在測試構(gòu)建時發(fā)現(xiàn)沒辦法給目標項目套一個頂層目錄時參考官方generator加上的,猜測是可以用來執(zhí)行一些默認行為,比如自動給目標項目創(chuàng)建一個頂層目錄,像這樣:

        const path = require('path');
        const mkdirp = require('mkdirp');
        // ...
        default() {
         if (path.basename(this.destinationPath()) !== this.props.appName) {
         this.log(
         '發(fā)現(xiàn)你不是在 ' + this.props.appName + ' 目錄下構(gòu)建\n' +
         '我將主動創(chuàng)建此目錄.(created folder with app name)'
         );
         mkdirp(this.props.appName);
         this.destinationRoot(this.destinationPath(this.props.appName));
         }
        }

        三、writing方法

        此方法即用來把實際項目按照指定規(guī)則給寫出來,主要有兩種寫法: 直接復制指定模板以及傳入?yún)?shù)渲染出目標文件。

        方式一: 直接拷貝

        this.fs.copy(
        this.templatePath('模板位置'),
        this.destinationPath('目標位置')
        );

        方式二: 傳入?yún)?shù)渲染模板

        this.fs.copyTpl(
        this.templatePath('模板位置'),
        this.destinationPath('目標位置'),
        {
        
        參數(shù)名: 值
        }
        );
        

        比如說,在index.js的同級目錄下的templates目錄下有一個文件叫text.txt, 使用方法一將模板位置和目標位置都寫text.txt,老頭就會直接復制這個text.txt作為輸出;而如果使用方法二,模板位置和目標位置不變,并傳入?yún)?shù){ hello: '你好啊'},在text.txt中就使用ejs語法寫上<%=hello%>,最終老頭同樣會輸出一個test.txt文件,不一樣的是里面的內(nèi)容被渲染成了"你好啊"。

        對此方法的總結(jié)就是根據(jù)需要使用copy或copyTpl進行輸出,其中copyTpl中的渲染使用ejs語法進行,而模板文件就都放在index.js的同級templates目錄里邊。

        四、install方法

        此方法即用來自動執(zhí)行依賴的安裝,沒什么特別的,就是在構(gòu)建完成后自動幫你npm install和bower install,也可以禁用其中一種:

        install() {
         this.installDependencies({bower: false});
        }

        效果就是下圖這句話了:

        發(fā)布generator到npm

        發(fā)布之前可以先使用npm link映射到本地進行測試:

        npm link
        yo ngtimo

        確認無誤后,發(fā)布流程就是一句代碼的事(記得定好版本,且更新發(fā)布時記得更新版本號):

        npm publish
        

        以上這篇使用yeoman構(gòu)建angular應(yīng)用的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        使用yeoman構(gòu)建angular應(yīng)用的方法

        使用yeoman構(gòu)建angular應(yīng)用的方法:本文將介紹如何親手來完成一個yeoman的generator,以實現(xiàn)快速構(gòu)建最適合自己的項目。 本文將實現(xiàn)的generator起名為ngtimo,依照yeoman的命名規(guī)矩就叫做generator-ngtimo,是筆者這周末一晚上加一上午參考著yeoman官方給出的幾個generator(g
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 四虎一区二区成人免费影院网址| 免费精品人在线二线三线区别| 国产婷婷成人久久Av免费高清| 成人免费午夜无码视频| 亚洲色婷婷综合开心网| 国产精品亚洲精品| 在线观看免费黄色网址| 免费网站看v片在线香蕉| 亚洲视频在线播放| 四虎影视在线看免费观看| 日本中文一区二区三区亚洲| 亚洲人6666成人观看| 精品国产污污免费网站| 亚洲免费视频网站| 2021国内精品久久久久精免费| 亚洲精品无码乱码成人| 亚洲AV无码一区二区大桥未久| 精品久久8x国产免费观看| 国产亚洲A∨片在线观看| 国产精成人品日日拍夜夜免费| 中文字幕亚洲图片| 免费观看四虎精品成人| 日韩成人在线免费视频| 精品亚洲国产成人| 性xxxxx免费视频播放| 亚洲国产精品久久久久| 亚洲视频免费在线看| 亚洲AV日韩综合一区| 亚洲乳大丰满中文字幕| 一级特级aaaa毛片免费观看| 国产一区二区三区免费看| 亚洲爆乳精品无码一区二区| 女人张开腿给人桶免费视频| 亚洲熟伦熟女专区hd高清| 最近中文字幕mv手机免费高清 | 免费一级毛片在线播放放视频 | 亚洲精品一品区二品区三品区 | 日韩成人在线免费视频| 青青操免费在线视频| 亚洲砖码砖专无区2023| 久久99国产亚洲高清观看首页|