创建前端简易脚手架
2021/5/6 18:26:41
本文主要是介绍创建前端简易脚手架,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.初始化 yarn init
2.在package.json 添加入口 "bin": "cli.js"
{ "name": "sample-scaffolding", "version": "1.0.0", "main": "index.js", "bin": "cli.js", "license": "MIT", "dependencies": { "ejs": "^3.1.6", "inquirer": "^8.0.0" } }
3.根目录创建 cli.js
#!/usr/bin/env node //node CLI应用如空文件必须要有这样一个文件头 //如果是Linux 或者 macOs 系统下还需要修改此文件的读写权限为 755 //具体就是通过 chmod 755 cli.js 实现修改 // console.log("cli") //脚手架的工作过程: //1. 通过命令行交互询问用户问题 inquirer工具实现(发起命令行询问) //2. 根据用户的回答的结果生成文件 const inquirer = require("inquirer") const fs = require('fs') const path = require('path') const ejs = require('ejs') inquirer.prompt([ { type: "input", name: "name", message: "project name?" } ]) .then(anwsers => { // console.log(anwsers) //根据提示生成文件 //模板文件 const tmplDir = path.join(__dirname, "templates") console.log('tmplDir----',tmplDir) //目标文件 const destDir = process.cwd() console.log('destDir---', destDir) // fs.readdir(tmplDir, (err, files) => { if(err) throw err files.forEach(file => { // console.log(file) //通过模板引擎渲染 ejs 模板引擎 ejs.renderFile(path.join(tmplDir, file), anwsers, (err, result) =>{ if(err) throw err console.log(result) //写入到目标文件 fs.writeFileSync(path.join(destDir, file), result) }) }) }) })
4.创建模板文件及对应文件夹 templates/index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title><%=name%></title> </head> <body> </body> </html>
5.将项目资源放在内存当中 随时调用 根目录下执行 yarn link
6. 执行名称生成文件在当前目录下 sample-scaffolding
注:需要引入的的包
yarn add inquirer //发起命令行询问
yarn add ejs //模板引擎 读写文件
这篇关于创建前端简易脚手架的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23实现OSS直传,前端怎么实现?-icode9专业技术文章分享
- 2024-11-22在 HTML 中怎么实现当鼠标光标悬停在按钮上时显示提示文案?-icode9专业技术文章分享
- 2024-11-22html 自带属性有哪些?-icode9专业技术文章分享
- 2024-11-21Sass教程:新手入门及初级技巧
- 2024-11-21Sass学习:初学者必备的简单教程
- 2024-11-21Elmentplus入门:新手必看指南
- 2024-11-21Sass入门:初学者的简单教程
- 2024-11-21前端页面设计教程:新手入门指南
- 2024-11-21Elmentplus教程:初学者必备指南
- 2024-11-21SASS教程:从入门到实践的简单指南