ホームページ >ウェブフロントエンド >jsチュートリアル >なぜ足場が必要なのでしょうか?ノードに足場を構築する手順の詳細な説明
なぜ足場が必要なのでしょうか?足場はどうやって建てるの?以下の記事でノード上に足場を構築する手順を紹介していますので、皆様のお役に立てれば幸いです。
新しい mycli
フォルダーを作成し (ファイル名はカスタマイズ可能)、その下に新しい bin
ファイルを作成し、新しい bin を作成します
ファイル index.js
、この index.js
がエントリ ファイルであり、index.js
がファイル # のヘッダーに追加されます!/usr/bin/env node
code
package.json
ファイルを生成します。この時点で、bin 構成オブジェクトが存在します。キー値はグローバル スキャフォールディング名、値はエントリ ファイル bin ファイルの index.js
path です。
npm init -y npm install
#スキャフォールディング グローバル コマンドをグローバル コマンドにリンクします。ターミナルに mycli
が出力された場合、リンクは成功しました。
//命令可以将一个任意位置的npm包链接到全局执行环境,从而在任意位置使用命令行都可以直接运行该npm包。 npm link
インストールの依存関係
npm install commander inquirer@8.2.5 download-git-repo chalk@4.1.2 ora@5.4.1 figlet handlebars
commander
: コマンド ライン ツール。これを使用して、コマンド ライン コマンドを実行し、ユーザーが何をしたいのかを把握する : ユーザーに美しいインターフェイスと質問する方法を提供する対話型コマンド ライン ツール
2.1 Commander.js は、ノードのコマンド ライン プログラムを構築するために使用されるツールであり、カスタム命令を使用してグローバル コマンド ラインでノード スクリプトを実行できるようになります。当初は、スクリプトが配置されているファイルのルート ディレクトリにある node xxx.js
を介してのみスクリプトを実行できましたが、コマンダーを使用してコマンド ライン プログラムをビルドした後は、任意のディレクトリで直接実行できるようになります。デスクトップなど、ユーザー ディレクトリなど、カスタム コマンドを入力してスクリプトを直接実行するほうが簡単です。 <pre class="brush:js;toolbar:false;">#!/usr/bin/env node
//就是解决了不同的用户node路径不同的问题,可以让系统动态的去查找node来执行你的脚本文件。
//node.js内置了对命令行操作的支持,在 package.json 中的 bin 字段可以定义命令名和关联的执行文件。
const program = require("commander")
program.version(&#39;1.1.0&#39;)
function getFramwork (val) {
console.log(val);
}
const myhelp = function (program) {
program.option(&#39;-f --framwork <framwork>&#39;, &#39;设置框架&#39;, getFramwork)
}
const createProgress = function (program) {
program.command(&#39;create <progress> [other...]&#39;)
.alias(&#39;crt&#39;)
.description(&#39;创建项目&#39;)
.action((progress, arg) => {
console.log(progress, arg);
})
}
myhelp(program);
createProgress(program);
program.parse(process.argv)
// 补充
.parse()
// 作用就是解析,参数就是要解析的字符串,一般使用时参数就是用process.argv,就是用户输入参数</pre>
グローバル コマンド
を実行してすべてのコマンドを出力します~~
##2.2 download-git-repo
download
repository
destination
options
callback<pre class="brush:js;toolbar:false;">#!/usr/bin/env node
const download = require(&#39;download-git-repo&#39;);
download(&#39;direct:https://gitlab.com/flippidippi/download-git-repo-fixture.git&#39;, "xxx", { clone: true }, (err) => {
console.log(err ? &#39;Error&#39; : &#39;Success&#39;)
})</pre>
## ファイルの下に
xxx
は、端末のさまざまな対話動作を簡単に実行できるようにするライブラリです。 inquirer は主に、質問の登録を容易にする 3 つのメソッドを提供します。
prompt(questions) => Promise
このメソッドは、端末対話の中核となるメソッドです。プロンプト メソッドは、端末に対話型コマンド インターフェイスを開始するように指示します。 - プロンプト メソッドは、#!/usr/bin/env node const inquirer = require("inquirer") function getUsername() { return inquirer .prompt([ { type: "input", name: "progress", message: "请输入项目名称", default: "progress", filter(input) { return input.trim() }, validate(input) { return input.length > 0 }, }, ]) .then((answer) => { console.log(answer) }) } function getFramework() { return inquirer .prompt([ { type: "list", name: "framework", choices: [ "express", new inquirer.Separator(), "koa", new inquirer.Separator(), "egg", ], message: "请选择你所使用的框架", }, ]) .then((answer) => { console.log(answer) }) } function getSelect() { return inquirer .prompt([ { type: "checkbox", name: "userndasde", choices: [ { name: "pr", disabled: true }, { name: "oa", checked: true }, "gg", ], message: "需要的验证格式", // default: ["oa"], }, ]) .then((answer) => { console.log(answer) }) } async function init() { await getSelect() await getUsername() await getFramework() } init()2.4 ora とチョーク (美化)
注: バージョンによって導入方法が異なることに注意してください。ここでは、ora
(バージョン 5.4.1)、
(バージョン 4.1.2) を使用します。<pre class="brush:js;toolbar:false;">const ora = require("ora")
const chalk = require("chalk")
const spinner = ora("Loading unicorns").start()
spinner.text = chalk.blue("下载中~~~~~~")
setTimeout(() => {
spinner.succeed(chalk.red("下载成功!"))
spinner.fail("下载失败!")
spinner.warn("警告!")
}, 2000)</pre><h4 data-id="heading-7">2.5 figlet(镂空文字)</h4>
<p>镂空文字调试器地址:<a href="https://www.php.cn/link/47f91db40efc6a22350eca5c953c4742" target="_blank" title="http://patorjk.com/software/taag/" ref="nofollow noopener noreferrer">地址</a></p>
<p><code>figle
t旨在完全实现JavaScript中的FIGfont
规范。它可以在浏览器和Node.js
中工作。
figlet.text( description,{options},callback(err,data){}) 这个是异步的会被
description:需要格式化的字符串
options:参数配置
Font
:字体,Default value:Standard
;horizontalLayout
:布局,Default value:default
; Values:{default
,full
,fitted
};verticalLayout
:垂直布局, Default value:default
; Values:{defalut
,full
,fitted
,controlled smushing
,universal smushing
};Width
:宽度;whitespaceBreak
:换行(Boolean); Default value:false
callback(err,data):回调
const figlet = require("figlet") const chalk = require("chalk") //简单函数 function handleAsync(params) { const JAVASCRIPT = figlet.textSync( "NODEJS", { font: "big", horizontalLayout: "fitted", verticalLayout: "controlled smushing", width: 600, whitespaceBreak: true, }, function (err, data) { if (err) { console.log("Something went wrong...") console.dir(err) return } console.log(data) } ) console.log(chalk.blue.bold(JAVASCRIPT)) } handleAsync()
bin/index.js
#!/usr/bin/env node console.log("adas"); require("../lib/commander/index.js")
lib/commonder/index.js
const program = require("commander") const init = require('../inquirer/index'); const downloadFun = require("../core/download.js"); program.version('1.1.0') function getFramwork (val) { console.log(val); } const myhelp = function (program) { program.option('-f --framwork <framork> [other...]', '设置框架', getFramwork) } const createProgress = function (program) { program.command('create <progress> [other...]') .alias('crt') .description('创建项目') .action((progress, arg) => { init(); }) } const downloadUrl = function (program) { program.command('download <url> [...other]') .description('下载内容') .action((url, ...args) => { console.log(args); downloadFun(url, args[1].args[1]) }) } myhelp(program); downloadUrl(program); createProgress(program) program.parse(process.argv)
lib/core/action.js
(package.json重写)const fs = require('fs'); const path = require("path"); const handlebars = require("handlebars"); function modifyPackageJson (options) { let downloadPath = options.projectName; const packagePath = path.join(downloadPath, 'package.json'); console.log(packagePath, "packagePath"); //判断是否存在package.json文件 if (fs.existsSync(packagePath)) { let content = fs.readFileSync(packagePath).toString(); //判断是否选择了eslint if (options.isIslint) { let targetContent = JSON.parse(content); content = JSON.stringify(targetContent); targetContent.dependencies.eslint = "^1.0.0"; console.log("content", content); } //写入模板 const template = handlebars.compile(content); const param = { name: options.projectName }; const result = template(param); //重新写入package.json文件 fs.writeFileSync(packagePath, result); console.log('modify package.json complate'); } else { throw new Error('no package.json'); } } module.exports = modifyPackageJson
lib/core/download.js
const download = require('download-git-repo'); const ora = require("ora"); const chalk = require("chalk"); const figlet = require("figlet"); const modifyPackageJson = require("./action") function handleAsync (params) { const JAVASCRIPT = figlet.textSync('JAVASCRIPT', { font: 'big', horizontalLayout: 'fitted', verticalLayout: 'controlled smushing', width: 600, whitespaceBreak: true }, function (err, data) { if (err) { console.log('Something went wrong...'); console.dir(err); return; } console.log(data); }); console.log(chalk.blue.bold(JAVASCRIPT)); } const downloadFun = (url, option) => { const spinner = ora("Loading unicorns").start() spinner.text = chalk.blue("下载中"); download(url, option.projectName, { clone: true }, function (err) { if (err) { spinner.fail("下载失败!"); handleAsync() } else { spinner.succeed(chalk.red("下载成功!")) console.log(chalk.blue(`cd ${option.projectName}`)) console.log(chalk.red("npm install")) console.log(chalk.yellow(`npm run dev`)) modifyPackageJson(option) handleAsync() } }) } module.exports = downloadFun;
inquire/index.js
注意frameworkConfig
写自己的gitlab
仓库地址const inquirer = require("inquirer"); const downloadFun = require("../core/download.js"); const frameworkConfig = { front: "https://gitlab.com/flippidippi/download-git-repo-fixture.git", manager: "https://gitlab.com/flippidippi/download-git-repo-fixture.git" } const config = {}; function getFramework () { return inquirer.prompt([ { type: 'list', name: 'framework', choices: ["front", "manager"], message: "请选择你所使用的框架" } ]).then((answer) => { return answer.framework; }) } function getProjectName () { return inquirer.prompt([ { type: 'input', name: 'projectName', message: '项目名称', filter (input) { return input.trim(); }, } ]).then((answer) => { console.log(answer, "FDsfs"); return answer.projectName; }) } function getIsEslint () { return inquirer.prompt([ { type: 'confirm', name: 'isIslint', message: '是否使用eslint校验格式?' } ]).then((answer) => { return answer.isIslint; }) } async function init () { config.projectName = await getProjectName(); config.framework = await getFramework(); config.isIslint = await getIsEslint(); let url = config.framework == "front" ? frameworkConfig.front : frameworkConfig.manager; downloadFun("direct:" + url, config); } module.exports = init;
更多node相关知识,请访问:nodejs 教程!
以上がなぜ足場が必要なのでしょうか?ノードに足場を構築する手順の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。