詳解一個基于react+webpack的多頁面應(yīng)用配置
簡單介紹
首先本文不會對webpack代碼進行解釋,其所有配置都可以在文檔上找到。
平時工作中會寫一些多頁面應(yīng)用,因為習(xí)慣了react的開發(fā)模式,故此寫了一個簡單的配置,跟大家一起分享。如果你也喜歡,對你的開發(fā)有所幫助,希望給點鼓勵(start)
github地址:https://github.com/ivan-GM/Gm-cli
項目目錄介紹:

打包后文件目錄:

打包成cli如果你厭煩了新項目的復(fù)制、粘貼,也可以構(gòu)建成cli
1,首先創(chuàng)建個文件夾,npm init初始化項目;
2, 創(chuàng)建bin目錄,touch index.js 編寫配置文件;
const commander = require('commander');
const inquirer = require('inquirer');
const download = require('download-git-repo')
const ora = require('ora');
const questions = [
{
type: 'input',
name: 'projectName',
message: 'project name:',
filter: function (val) {
return val;
}
}
]
commander
.option('init', 'create project')
.version('1.0', '-v, --version')
commander
.command('init')
.description('')
.action(() => {
inquirer.prompt(questions).then(answers => {
const { projectName } = answers;
const spinner = ora('Loading unicorns').start();
spinner.color = 'green';
spinner.text = 'downloading template...';
download('direct:https://github.com/ivan-GM/live', projectName, { clone: true }, (err) => {
if (err) {
console.log(err)
} else {
spinner.stop()
console.log('sucess')
}
})
})
});
commander.parse(process.argv);
3,添加命令:打開package.json
"bin": {
"my-cli": "./bin/index.js"
},
4,發(fā)布npm
*上面代碼只是對打包成cli進行了簡單的說明,如果感興趣了,可以深入研究
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React報錯Type '() => JSX.Element[]&apos
這篇文章主要為大家介紹了React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
React Native AsyncStorage本地存儲工具類
這篇文章主要為大家分享了React Native AsyncStorage本地存儲工具類,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
ReactQuery系列之?dāng)?shù)據(jù)轉(zhuǎn)換示例詳解
這篇文章主要為大家介紹了ReactQuery系列之?dāng)?shù)據(jù)轉(zhuǎn)換示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
react-redux中connect的裝飾器用法@connect詳解
這篇文章主要介紹了react-redux中connect的裝飾器用法@connect詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01

