frontengineerplugin
v0.1.31
Published
前端工程化脚手架.集成eslint,husky,prettier,eslint,npmrc,CICD,testCase,node_proxy,readme生成 9个主要功能
Downloads
116
Maintainers
Readme
Quickstart
begin
npm install frontengineerplugin -g
# 第一种方法,推荐:
npm run engineer
# 第二种方法:不推荐 项目根目录的package.json中输入
frontengineerplugin install prettier husky env eslint npm
# 第三种方法:命令行下面 输入
frontengineerplugin gui
Quesion
- 如果你遇到Error [ERR_REQUIRE_ESM]: require() of ES Module 的报错。在你的package.json中加入
"type": "module",
- This file is being treated as an ES module because it has a '.js' file extension and 'D:\cicd-test\package.json' contains "type": "module"
删掉 "type": "module", 加入 "type": "commonjs"
- 暂时没有适配pnpm的自动script写入,如果你是用这个你需要
# 项目根目录的package.json中添加
{
"engineer":"frontengineerplugin gui "
}
# 然后运行 npm run engineer
Contain
husky
限制了只能用如下参数进行提交
- feat: 新功能 (feature)
- fix:修补bug
- docs:文档 (documentation)
- style:格式(不影响代码运行的变动)
- refactor: 重构(即不是新增功能,也不是修改bug的代码变动)
- chore:构建过程或辅助工具的变动revert: 撤销,版本回退
- perf:性能优化
- test:测试
- improvement:改进
- update:
- build: 打包
- ci: 持续集成
prettier
module.exports = {
printWidth: 80,
// 使用单引号而非双引号;
singleQuote: true,
tabWidth: 2,
proseWrap: 'never',
// 在语句末尾添加分号;
Semicolons: true,
overrides: [{ files: '.prettierrc', options: { parser: 'json' } }],
};
more refer:https://www.prettier.cn/
env
cross-env ENV=production max dev
var proEnv = require('./config/production.env'); // 生产环境
var testEnv = require('./config/test.env'); // 测试环境
var devEnv = require('./config/development.env'); // 本地环境
const env = process.env.ENV;//当前环境
let URL_COMMON = '';//路径
let URL_RESOURCE = '';//路径
// 默认是本地环境
if (env === 'production') { // 生产环境
console.log("----------生产环境----------");
URL_COMMON = proEnv.URL_COMMON;
URL_RESOURCE = proEnv.URL_RESOURCE
} else if (env === 'test') { // 测试环境
console.log("----------测试环境----------");
URL_COMMON = testEnv.URL_COMMON;
URL_RESOURCE = testEnv.URL_RESOURCE
} else if( env ==='development') { // 开发环境
console.log("----------开发环境----------");
URL_COMMON = devEnv.URL_COMMON;
URL_RESOURCE = devEnv.URL_RESOURCE
}
eslint
// npm install babel-eslint --save
module.exports = {
root: true,
env: {
browser: true,
node: true,
},
extends: [
// 额外添加的规则可查看 https://vuejs.github.io/eslint-plugin-vue/rules/
// 'plugin:vue/essential', //加了这个才能当作vue来进行解析,不然只会当成js来进行解析 eslint-plugin-react
],
//不加这个会报错Parsing error: The keyword 'import' is reserved
parserOptions: {
// 指定解析器 parser
ecmaVersion: 8,
sourceType: 'module',
// "parser": 'babel-eslint',
// sourceType: 'module',
// ecmaVersion: 12,
// allowImportExportEverywhere: true, // 不限制eslint对import使用位置
},
settings: {},
// 取消没必要的校验 0 是 不报错 , 1是warn 2 是punishing
// "off"或者0 //关闭规则关闭
// "warn"或者1 //在打开的规则作为警告(不影响退出代码)
// "error"或者2 //把规则作为一个错误(退出代码触发时为1)
rules: {
// "camelcase": ["error", { "allow": ["aa_bb"] }], // 属性名
// "max-lines": ["error", {"max": 20, "skipComments": true}], // 每一个文件最多的行数
// "no-console": 2,//禁止使用console
// "no-mixed-spaces-and-tabs": [2, false],//禁止混用tab和空格
// "no-multiple-empty-lines": [1, {"max": 2}],//空行最多不能超过2行
// "no-multi-spaces": 1,//不能用多余的空格
// "indent": [1, 4],//缩进风格 缩进四个空格
// "max-lines-per-function": [0, { "max": 2 }], // 指定每个function最多多少行
'no-unused-vars': 2, //没被使用
'consistent-return': 0, // 有函数返回值
'no-underscore-dangle': 0, // 不允许有下划线
'no-plusplus': 1, // 不能用++
'no-eval': 0, // 不能用eval
'linebreak-style': [0, 'error', 'window'], // 换行风格
camelcase: 'warn', //像是xx_xx这种会报错
},
// 这里可以配置具体后缀的规则
overrides: [
{
files: ['*.js'],
// extends: ['alloy'],
rules: {
'no-unused-vars': 0, //没被使用
},
},
],
};
more refer:http://eslint.cn/
npm
指定.npmrc
cicd
目前这个文件夹是放置一些脚本的。
包括部署和项目结构优化的脚本
test
里面分成两个文件夹.主要使用jest做的
主要是有工具类js ,ts 的测试。
以及web-component之类的测试
node_proxy
集成了三种方法来做跨域。一般如果你做脚本的话,可以下载下来做插件的端口转发
standard_readme
帮助你生成标准 README.md 的 东西。
注意。提前要填写好你package.json 的name version homepage 三个字段
然后注意 如果项目中有 README.md 需要先删掉
默认会生成 author 和 packageName 的label(就是一开始下面并列的牌子)
如果你想要添加自己的label 可以在package.json中添加 如下格式字段
"label": [
{
"frontName": "Gitee",
"behindName": "Electrolux",
"src": "https://gitee.com/Electrolux",
"color": "red"
},
{
"frontName": "Bili",
"behindName": "Electrolux",
"src": "https://space.bilibili.com/286773126",
"color": "Pink"
}
],
Developer
一开始安装的时候会通过package.json的bin字段执行 install.js
如果你想添加你自己工程化的东西
--1.首先将你的文件放进file 文件夹
--2.修改project.js的 guiFn 方法和 增加 util/handleEvent.js导出的方法
--3.接下来的测试阶段请输入npm link
然后 npm run engineer
Example
COMMIT and CHANGELOG
# first
npm install frontengineerplugin -g
npm run engineer
# THEN
select CICD and husky
# THEN
GO to dir .husky/commit-msg
然后把 os.system("node CICD/CHANGELOG/changeLogAdd.js " + line) 前面的判断符号改成 true
# THEN
GO to dir CICD/CHANGELOG/changeLogAdd
然后 把 isAutoUpDate 改成 true
COMMIT and Update Readme.md
if you allow my readme.md script ,then you can
# first
npm install frontengineerplugin -g
npm run engineer
# THEN
select CICD
# THEN
GO to dir .husky/commit-msg
然后把 os.system("node CICD/readmeUpdate/readmeUpdate.js") 前面的判断符号改成 true
# THEN
GO to dir CICD/readmeUpdate/readmeUpdate.js
然后 把 line 和 resText 进行 替换
Badge
[![Size](https://img.shields.io/static/v1?label=plugin&message=frontEngineerPlugin&color=green)](https://gitee.com/Electrolux)
Support
frontEngineerPlugin is developed by me. Please use frontEngineerPlugin, star it on gitee or even become a sponsor to support us!