前端工程化 ---- 创建自己的脚手架工具
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);});});});});

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

相关内容

热门资讯

日常等车时看到的行业细节 干了五年户外广告投放,养成了一个职业病:但凡路过公交候车亭,总会多看两眼——不是看广告好不好看,而是...
黄金回收行业标准制定有哪些核心... 贵金属回购市场的需求背景 近年来随着黄金投资和消费市场的发展,黄金回收相关需求持续攀升。不同群体的诉...
全球黑色星期二!AI交易“崩盘... 【导读】AI交易为何“崩盘”? 中国基金报记者 泰勒 大家,你们今天还好吗?! AI交易在全球范围内...
原创 6... 年初抢金条的人还在站岗,如今金店柜台前冷冷清清 黄金又跌了。 6月23日,伦敦现货黄金价格日内急跌逾...
狂融294亿美元!SK海力士冲... 韩国股市再度迎来重磅消息。 周三,韩国存储芯片龙头SK海力士宣布,计划在7月10日登陆纳斯达克,通过...
比特币跌破6万!AI吸走资金、... 比特币正在为机构化转型付出代价。散户买盘萎缩、ETF资金持续外流、企业持仓者潜在抛售压力上升,加之A...
原创 默... 欧洲近期试图复刻1985年广场协议的剧本,德国总理默茨呼吁欧盟27国联合行动,要求中国签订类似协议以...
怎么选 泛娱乐赛道直播公司孵化... 泛娱乐直播创业的行业发展背景 近年来泛娱乐直播赛道持续保持增长态势,据公开数据资料显示,2024年国...
原创 腰... 最近黄金市场凉得彻底。各大品牌足金饰品克价跌破1300元关口,北京菜百6月21日报价已经掉到1260...
ST中装:公司主要银行账户已全... 证券之星消息,ST中装(002822)06月24日在投资者关系平台上答复投资者关心的问题。 投资者提...
2026年开窗机行业趋势与战略... 一、开篇引言:市场格局重塑下的选择逻辑 步入2026年,全球建筑智能化与绿色节能政策的叠加驱动,使开...
资金全面转向科技,传统消费企业... 近期 A 股出现明显风格切换,老牌消费资金持续流出,机构与传统上市公司纷纷加码半导体、算力赛道。 先...
合肥保利翡翠天奕具体交房时间是... 对于众多购房者而言,“合肥保利翡翠天奕具体交房时间是什么时候?能按时交房吗?”是心中最关切的问题。根...
港股风向标|恒指连续杀跌后企稳... 财联社6月24日讯(编辑 冯轶)今日港股短线企稳,三大指数集体收涨。截至收盘,恒生指数涨0.33%,...
瑞众人寿达州中支被罚17万,涉... 蓝鲸新闻6月24日讯,近日,国家金融监督管理总局达州监管分局发布行政处罚决定书,剑指瑞众人寿保险有限...
美国最担心的事还是来了,中国加... 最近这段时间,国际金融圈子里有一笔账,算得各家央行心里都不太踏实。 截至2026年春季,美国国债总规...
马斯克,不是万亿富豪了 资产历史性超过万亿美元不到两周,特斯拉、SpaceX掌门人埃隆·马斯克的身价近日快速下跌。 据中新经...
突发!金价跌破4000美元,近... 每经记者:杜宇 记者|杜宇 编辑|何小桃 杜恒峰 校对|金冥羽 金银价格大跳水。 6月24日晚,现货...
粗粮吃越多越好?很多糖友吃错升... 控糖圈一直流传多吃粗粮稳血糖,不少糖友直接三餐全吃粗粮、顿顿杂粮,不仅胃胀消化不良,餐后血糖反而不降...
持续大跌!刚刚,黄金跌破400... 潮新闻客户端 记者 吴恩慧 6月24日,贵金属再次大跌。 截至发稿时,现货黄金大跌近3%,跌破400...