前端工程化 ---- 创建自己的脚手架工具
admin
2024-01-20 06:16:42
0

一,前端工程化是什么?

所谓工程: 工程就是一个项目(一个网站或APP)

一个工程的生命周期:

  • 工程立项
  • 需求分析
  • 产品原型
  • 开发实施
  • 测试部署
  • 上线运行

什么是前端工程化

  • 前端工程化就是通过各种工具和技术,提升前端开发效率的过程.
    • 前端工程化的内容: 各种工具和技术
    • 前端工程化的作用: 通过使用工具,提升开发效率

前端工程化解决的问题

  • 项目代码上线前,代码需要压缩
    • bootstrap.js/bootstrap.min.js
  • 想要使用ES6+CSS3新特性,要解决兼容性问题
    • 使用工具去解决兼容性问题
  • 想要使用Less去增强CSS的编程性,但是浏览器不能直接支持less
    • 进行编译
  • 多人协作开发,代码风格无法统一
    • eslint格式化

工程化!==某个工具

node.js

二,脚手架

脚手架分类

  • 通用脚手架
    • yeoman
  • 专用脚手架
    • vue-cli
    • create-react-app
    • angular-cli

yeoman

yeoman的基本概念

  • yeoman是一款脚手架工具
    • 可以帮助开发人员创建项目的基础结构代码
  • yo是yeoman的命令行管理工具
    • 可以在命令行运行的yeoman的命令
  • 生成器:yeoman中具体的脚手架
    • 针对不同项目有不同的脚手架(例如: 网站 ,app 小程序 等)

yeoman使用说明

  • 全局安转yo
npm install --global yo
  • 安装generator
npm install --global generator-webapp
  • 通过yo运行generator
mkdir project-name
cd project-name
yo webapp
  • 启动应用
npm run start

构建自己的脚手架工具

自定义Generator

首先配置Generator需要有严格的文件结构

|_ generators/     ............................. 生成器目录
|   |_ app/        ............................. 默认生成器目录
|      |_ index.js ............................. 默认生成器实现
|_  package.json   ............................. 模块包配置文件

使用yeoman实现自己的脚手架

  1. 创建文件结构并且初始化项目

    创建文件夹名字必须是generator-xxx

npm init -y //初始化项目
配置文件结构注意:文件结构名字不能改变
  1. 安装yeoman-generator
npm install yeoman-generator
  1. 编写index.js文件
const Generator = require("yeoman-generator");const path = require("path");
const fs = require("fs");module.exports = class extends Generator {prompting() {// promisereturn this.prompt([{type: "input",name: "title",message: "Project name:",default: this.appname,},]).then((answers) => {this.answers = answers;});}writing() {// // 创建单个文件// this.fs.write(//     this.destinationPath("temp.txt"),//     Math.random().toString()//     );// // 创建模板文件// const tmpl = this.templatePath("index.html");// const output = this.destinationPath("index.html");// const context = this.answers;// this.fs.copyTpl(tmpl, output, context);//创建多个模板文件const tmpDir = path.join(__dirname, "templates");fs.readdir(tmpDir, (err, files) => {if (err) throw err;files.forEach((file) => {console.log(file);const tmpl = this.templatePath(file);const output = this.destinationPath(file);const context = this.answers;this.fs.copyTpl(tmpl, output, context);});});}
};
  1. 挂载全局供其他文件夹去使用命令
npm link//挂载
npm unlink//卸载
这一块 可以使用yarn去挂载 
yarn link//挂载
yarn unlink//卸载
  1. 向目标文件夹写文件
yo xxx//这里的xxx是你最外层定义的generator-xxx文件名
到此即可创建成功!!!

脚手架的原理

  1. 初始化项目
npm init -y
  1. 安装依赖并配置package.json
安装命令提示符交互 inquirer
ejs模板npm i ejs inquirer
//配置bin
{"name": "ncl","version": "1.0.0","description": "","main": "index.js","bin": {"ncl": "`./cli.js`"},"scripts": {"test": "echo \"Error: no test specified\" && exit 1"},"keywords": [],"author": "","license": "ISC","dependencies": {"ejs": "^3.1.8","inquirer": "^8.0.0"}
}
  1. cli.js中
#!/usr/bin/env node  //这一块必须写 因为这个文件当成脚本去执行,写在第一行
const fs = require("fs");
const path = require("path");
const inquirer = require("inquirer");
const ejs = require("ejs");inquirer.prompt([{type: "input",name: "title",message: "Project name:",},]).then((answers) => {console.log(answers);// 获取模板路径const tmpDir = path.join(__dirname, "templates");// console.log(tmpDir);// 获取命令符窗口的路径const destDir = process.cwd();// console.log(destDir);fs.readdir(tmpDir, (err, files) => {if (err) throw err;files.forEach((file) => {ejs.renderFile(path.join(tmpDir, file), answers, (err, result) => {if (err) throw err;fs.writeFileSync(path.join(destDir, file), result);});});});});

总结:脚手架其实就是通过读写文件,来实现的

相关内容

热门资讯

FXGT:平台监管合规与全球市... 本文探讨FXGT平台的核心优势,重点分析其监管合规性和全球市场连接的整合价值。通过严格的合规框架,F...
原创 1... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
原创 美... 2026 年 1 月 13 日,美国多家媒体集中披露两条重磅消息,中国美债持仓降至 6887 亿美元...
融资保证金比例重回100%:A... "两融余额突破2.67万亿!"当这个数字刷屏各大财经媒体时,监管层的一纸通知瞬间引爆市场——融资保证...
靠中式精酿9个月狂卖11亿,河... 不到两年时间,一群“微醺女孩”把一家成立44年的河南地方啤酒厂推到IPO门口。 1月13日,河南金星...
原创 黄... 哈喽大家好,今天小无带大家聊聊最近刷屏的抢金热潮!金饰价格飙涨不停,一条项链一夜涨1.5万还被疯抢,...
原创 虚... 小睿就来深扒“纸上黄金”的IPO迷局,Suplay冲刺港股欲成“收藏卡第一股”,靠米哈游IP赚足利润...
北京CBD千亿规模国际级商圈初... 央广网北京1月14日消息(记者 王进文)1月14日,记者从北京市朝阳区两会新闻发布会上了解到,北京商...
原创 9... 什么样的酒能赢得市场? 2026年开年,A股市场的“分裂感”格外清晰。一边,是上证指数稳步站上410...
北方稀土设备供应商,广泰真空上... 来源丨时代商业研究院 作者丨陆烁宜 编辑丨郑琳 时隔3个月,“超长验收”项目披露的数量却翻倍,沈阳广...
热点城市启动新年“第一拍” 民... 来源:21世纪经济报道 21世纪经济报道记者 张敏 1月14日,青岛2026年首场宅地拍卖落锤。在市...
啤酒卖不动了,中式精酿能救金星... 在中国啤酒行业,已经很久没有出现真正意义上的 " 新故事 " 了。 过去十余年,这个一度被视为现金牛...
小组第二出线!U23亚洲杯-李... 北京时间1月14日消息,2026年U23亚洲杯小组赛继续进行,在D组最后一轮争夺中,中国U23男足迎...
原创 反... 当地时间1月12日,一场不简单的会议在美国悄然召开,G7成员国的财长们、欧盟的代表、还有来自澳大利亚...
创尔生物再次折戟IPO:股东股... 近日,深耕胶原蛋白领域二十余年的广州创尔生物技术股份有限公司(以下简称“创尔生物”)在全国中小企业股...
仓储物流巨头普洛斯中国迎来女C... 1月14日,普洛斯集团(GLP Pte Ltd,简称“GLP”)宣布任命公司创始成员、中国物流仓储与...
耐心资本赋能新质生产力 成都高... 活动现场 图片来源:成都高新区提供 发布“双清单”,进行主题分享、项目路演等,搭建资本与产业精准对接...
40多年来广东制造爆款频出,董... “质量关乎两个生命:消费者的生命和企业的生命,广货的底气正是来自这份刻进骨子里的质量意识。”1月14...
世界经济论坛年度风险报告:全球... 财联社1月14日讯(编辑 史正丞)世界经济论坛周三发布的全球风险报告显示,涵盖关税、制裁等工具的地缘...
原创 果... 当地时间1月12日,特朗普在“真实社交”上甩出一记经贸重拳,宣称对所有与伊朗有商业往来的国家加征25...