ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

创建前端简易脚手架

2021-05-06 18:05:05  阅读:152  来源: 互联网

标签:console log err 前端 简易 inquirer const 脚手架 ejs


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  //模板引擎 读写文件

标签:console,log,err,前端,简易,inquirer,const,脚手架,ejs
来源: https://www.cnblogs.com/faint33/p/14736160.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有