《vue3从零搭建一个后台》(三)、第三方配置

第三方的配置文件

其实有些配置是默认了,但是这些文件优先级会较高,起到覆盖作用

至于为什么么还需要配置,主要是适应我们的编程习惯。而vuecli配置的这些一般都适应大部分人的编程习惯。包括我。

.browserslistrc (浏览器的适配)

Browserslist 的数据都是来自Can I Use的。

其他参数可参考他的官网

.editorconfig

编辑器的配置

以下是vscode支持的规则

# 匹配全部文件
[*]
# 结尾换行符,可选"lf"、"cr"、"crlf"
end_of_line = lf
# 在文件结尾插入新行
insert_final_newline = true
# 删除一行中的前后空格
trim_trailing_whitespace = true
# 匹配js和py结尾的文件
[*.{js,py}]
# 设置字符集
charset = utf-8

# 匹配py结尾的文件
[*.py]
# 缩进风格,可选"space"、"tab"
indent_style = space
# 缩进的空格数
indent_size = 4

# 以下匹配,类同
[Makefile]
indent_style = tab
# tab的宽度
tab_width = 4

# 以下匹配,类同
[lib/**.js]
indent_style = space
indent_size = 2

[{package.json,.travis.yml}]
indent_style = space
indent_size = 2

.eslintrc.js (代码校验的配置)

由于我们创建项目的时候选择了使用这个插件。所以这里就有了这个配置文件,它是针对与代码风格的校验。这个主要体现在团队协作时强制统一编码风格。当然,如果只是你一个人的项目大可不必用它,用它的最大好处就是提高自己的编码风格和出错率。不用为缺少分号抓耳挠腮。因为它可以定位错误。


默认配置

我个人的配置如下

module.exports = {
  root: true,
  parserOptions: {
    parser: 'babel-eslint',
    sourceType: 'module' // js的导入方式,这里指以模块方式导入
  },
  env: {
    browser: true,
    node: true,
    es6: true,
  }, //eslint:recommended:表示引入eslint的核心功能,并且报告一些常见的共同错误。
  extends: ['plugin:vue/recommended', 'eslint:recommended'],

  rules: {
   // 设置每行最大属性数
    'vue/max-attributes-per-line': [2, {
    'singleline': 10, // 标签为单行时,每行最大属性数值为 10,默认值为 1
    'multiline': {
    'max': 1, // 标签为多行时,每行最大属性数字为 1,默认值为 1
    'allowFirstLine': false // 不允许属性与该标记名称位于同一行,默认值为 false
    }
    }],
    // 禁用单行标签内容需换行的校验
    'vue/singleline-html-element-content-newline': 'off',
    // 禁用多行标签内容需换行的校验
    'vue/multiline-html-element-content-newline':'off',
    // 组件 name 属性值必须使用帕斯卡命名法(单词首字母大写)
    'vue/name-property-casing': ['error', 'PascalCase'],
    // 禁用禁止使用 v-html 的校验
    'vue/no-v-html': 'off',
    // 对象必须使用 getter / setter 对,即:每个已定义 setter 的属性都需有一个 getter
    'accessor-pairs': 2,
    // 箭头函数 => 前后必须有空格
    'arrow-spacing': [2, {
    'before': true,
    'after': true
    }],
    // 单行代码块花括号打开块之后和关闭块之前,至少一个空格
    'block-spacing': [2, 'always'],
    // 强制执行标准大括号风格样式(关键字要与花括号保持在同一行)
    'brace-style': [2, '1tbs', {
    'allowSingleLine': true // 允许同一行上打开和关闭括号
    }],
    // 关闭驼峰命名规则校验(变量命名时,名称之间不允许下划线,常量(全部大写)除外)
    'camelcase': [0, {
    'properties': 'always' // 属性名称强制执行驼峰命名法样式
    }],
    // 在对象或数组中不允许尾随逗号
    'comma-dangle': [2, 'never'],
    // 变量声明,数组文字,对象文字,函数参数和序列中的逗号前后加上一致的间距
    'comma-spacing': [2, {
    'before': false, // 在逗号前不允许有空格
    'after': true // 在逗号后需要一个或多个空格
    }],
    // 使用标准逗号样式,逗号位于当前行的末尾。在数组元素,对象属性或变量声明在同一行之后和同一行需要逗号
    'comma-style': [2, 'last'],
    // 子类构造函数必须使用 super()调用父类构造函数。非子类的构造函数不得调用
    'constructor-super': 2,
    // 当一个块只包含一条语句时,if,else if,else,for,while,或 do 允许省略花括号
    'curly': [2, 'multi-line'],
    // 表达式中点"."要求与属性位于同一行
    'dot-location': [2, 'property'],
    // 强制文件以换行符结束(文件以一空行结束)
    'eol-last': 2,
    // 强制使用 === 和 !== 但不将此规则应用于 null
    'eqeqeq': ['error', 'always', {'null': 'ignore'}],
    // 使用生成器时关键字 * 前后均须有空格
    'generator-star-spacing': [2, {
    'before': true,
    'after': true
    }],
    // 回调模式需处理 err 或 error,报告所有未处理的错误
    'handle-callback-err': [2, '^(err|error)$'],
    // 使用两个空格进行缩进,
    'indent': [2, 2, {
    'SwitchCase': 1 // case 针对 switch 语句使用 2 个空格缩进
    }],
    // 在 JSX 属性中强制使用单引号
    'jsx-quotes': [2, 'prefer-single'],
    // 对象字面量属性中强制在冒号后放置空格,冒号前不允许空格
    'key-spacing': [2, {
    'beforeColon': false, // 不允许在对象文字中的键和冒号之间使用空格
    'afterColon': true // 需要在冒号和对象文字中的值之间至少有一个空格
    }],
    // 关键字前后至少有一个空格
    'keyword-spacing': [2, {
    'before': true,
    'after': true
    }],
    // 构造函数名需以大写字母开头,以下内置标识符可免除此规则:Array、Boolean、 Date、Error、Function、Number、Object、RegExp、String、Symbol
    'new-cap': [2, {
    'newIsCap': true, // new 方式调用的函数需以大写开头
    'capIsNew': false // 允许直接调用大写开头的函数,无需使用 new
    }],
    // 使用 new 关键字调用无参构造函数,函数名后强制使用括号
    'new-parens': 2,
    // 禁止使用数组构造函数,
    'no-array-constructor': 2,
    // 禁止使用 arguments.caller 和 arguments.callee
    'no-caller': 2,
    // 关闭 console 检验规则
    'no-console': 'off',
    // 禁止给类赋值
    'no-class-assign': 2,
    // 禁止在条件语句中使用赋值运算符
    'no-cond-assign': 2,
    // 禁止修改 const 关键字声明的变量
    'no-const-assign': 2,
    // 关闭正则表达式中的控制字符校验规则
    'no-control-regex': 0,
    // 不允许对变量使用 delete 操作符
    'no-delete-var': 2,
    // 不允许在函数声明或表达式中使用重复的参数名称
    'no-dupe-args': 2,
    // 不允许在类的声明中出现重复名称
    'no-dupe-class-members': 2,
    // 不允许在对象中使用重复键
    'no-dupe-keys': 2,
    // 不允许在 switch 语句的 case 子句中使用重复的 case 分支
    'no-duplicate-case': 2,
    // 不允许在正则表达式中使用空字符
    'no-empty-character-class': 2,
    // 对象和数组使用解构时,不允许空模式
    'no-empty-pattern': 2,
    // 禁止使用 eval()函数
    'no-eval': 2,
    // 禁止给 catch 语句中的异常参数赋值
    'no-ex-assign': 2,
    // 不允许直接修改内置原生对象
    'no-extend-native': 2,
    // 避免不必要的函数绑定 bind()
    'no-extra-bind': 2,
    // 禁止不必要的布尔转换
    'no-extra-boolean-cast': 2,
    // 在使用函数表达式时,禁止使用不必要的括号
    'no-extra-parens': [2, 'functions'],
    // 禁止 switch 穿透,需使用 break 中断
    'no-fallthrough': 2,
    // 禁止省略浮点数中的 0
    'no-floating-decimal': 2,
    // 不允许重新分配 function 声明
    'no-func-assign': 2,
    // 禁止使用隐式 eval(),即:始终使用函数作为 setTimeout()、setInterval()和execScript()的第一个参数
    'no-implied-eval': 2,
    // 禁止在块中声明 function
    'no-inner-declarations': [2, 'functions'],
    // 不允许 RegExp 构造函数中使用无效的正则表达式字符串
    'no-invalid-regexp': 2,
    // 禁止使用无效空格(不是正常的制表符和空格),但允许在字符串中使用任何空格字符
    'no-irregular-whitespace': 2,
    // 禁止使用该__iterator__属性
    'no-iterator': 2,
    // label 标签名不能与变量名相同
    'no-label-var': 2,
    // 禁止使用标签语句
    'no-labels': [2, {
    'allowLoop': false,
    'allowSwitch': false
    }],
    // 禁止使用不必要的嵌套块
    'no-lone-blocks': 2,
    // 不允许使用混合空格和制表符进行缩进
    'no-mixed-spaces-and-tabs': 2,
    // 禁止在逻辑表达式,条件表达式,声明,数组元素,对象属性,序列和函数参数周围使用多个空格
    'no-multi-spaces': 2,
    // 禁止使用斜线(\)进行换行
    'no-multi-str': 2,
    // 禁止多个连续空行,最大连续空行数为 1
    'no-multiple-empty-lines': [2, {
    'max': 1
    }],
    // 不允许修改只读全局变量
    'no-native-reassign': 2,
    // 不允许否定 in 表达式中的左操作数
    'no-negated-in-lhs': 2,
    // 不允许使用 Object 构造函数
    'no-new-object': 2,
    // 不允许使用 new require
    'no-new-require': 2,
    // 禁止使用 Symbol 构造器
    'no-new-symbol': 2,
    // 禁止使用原始包装器,new String,new Number 或 new Boolean
    'no-new-wrappers': 2,
    // 禁止将全局对象作为函数调用,即不允许调用 Math,JSON 和 Reflect 对象作为函数
    'no-obj-calls': 2,
    // 不允许使用八进制
    'no-octal': 2,
    // 不允许字符串中的八进制转义序列
    'no-octal-escape': 2,
    // node 中避免使用__dirname 和__filename 全局变量进行路径字符串拼接
    'no-path-concat': 2,
    // 使用方法 getPrototypeOf 替换__proto__属性
    'no-proto': 2,
    // 不允许同一作用域内声明相同变量名称
    'no-redeclare': 2,
    // 正则表达式文字中不允许有多个空格
    'no-regex-spaces': 2,
    // return 语句中的赋值必需有括号包裹
    'no-return-assign': [2, 'except-parens'],
    // 不允许将变量自我赋值
    'no-self-assign': 2,
    // 禁止变量与自己进行比较操作
    'no-self-compare': 2,
    // 禁止使用逗号运算符,除非在 for 语句的初始化或更新部分,表达式序列显式包含在圆括号中
    'no-sequences': 2,
    // 禁止对全局对象赋值
    'no-shadow-restricted-names': 2,
    // 功能标识符与其应用程序之间不允许有间距
    'no-spaced-func': 2,
    // 禁止使用稀疏数组,不适用于最后一个元素之后的尾随逗号
    'no-sparse-arrays': 2,
    // 使用 this 前请确保 super() 已调用
    'no-this-before-super': 2,
    // 用 throw 抛错时,抛出 Error 对象而不是字符串
    'no-throw-literal': 2,
    // 禁止在行尾添加尾随空白(空格,制表符和其他 Unicode 空白字符)
    'no-trailing-spaces': 2,
    // 禁止引用未声明的变量
    'no-undef': 2,
    // 禁止使用 undefined 来初始化变量
    'no-undef-init': 2,
    // 禁止混淆多行表达式
    'no-unexpected-multiline': 2,
    // 检查循环条件内的引用是否在循环中被修改
    'no-unmodified-loop-condition': 2,
    // 当存在更简单的选择时,此规则不允许三元运算符
    'no-unneeded-ternary': [2, {
    'defaultAssignment': false // 不允许将条件表达式作为默认的分配模式
    }],
    // return,throw,continue,和 break 语句后不允许跟代码
    'no-unreachable': 2,
    // 不允许 return,throw,break,和 continue 语句使用 finally 块,即:finally 代码块中不要再改变程序执行流程,但它允许间接使用
    'no-unsafe-finally': 2,
    // 不允许存在声明但未使用的变量,函数和函数的参数
    'no-unused-vars': [2, {
    'vars': 'all', // 检查全局范围内的变量
    'args': 'none' // 不检查参数
    }],
    // 禁止使用.call()和.apply()
    'no-useless-call': 2,
    // 禁止不必要的计算属性键作对象属性
    'no-useless-computed-key': 2,
    // 禁止不必要的构造函数
    'no-useless-constructor': 2,
    // 关闭不必要的转义检测规则
    'no-useless-escape': 0,
    // 对象的属性在同一行上时禁止在属性前使用空格,当对象和属性位于单独的行上时,此规则允许使用空格,因为通常在较长的属性链中添加换行符
    'no-whitespace-before-property': 2,
    // 禁止使用 with
    'no-with': 2,
    // 一个变量关键字(var,let 或 const)只声明一个变量
    'one-var': [2, {
    'initialized': 'never' // 每个作用域要求多个变量声明用于初始化变量
    }],
    // 使用一致的换行符样式,将换行符放置在运算符之后
    'operator-linebreak': [2, 'after', {
    'overrides': {
    '?': 'before', // 三元运算换行符置于 ? 前
    ':': 'before' // 三元运算换行符置于 : 前
    }
    }],
    // 在 block 语句和类的开头和结尾处不允许出现空行
    'padded-blocks': [2, 'never'],
    // 字符串尽可能使用单引号
    'quotes': [2, 'single', {
    'avoidEscape': true, // 允许字符串使用单引号或双引号,只要字符串包含必须被转义的引号即可
    'allowTemplateLiterals': true // 允许字符串使用反引号
    }],
    // 禁止使用分号结尾
    'semi': [2, 'never'],
    // 分号后强制使用空格,并在分号前禁止使用空格
    'semi-spacing': [2, {
    'before': false,
    'after': true
    }],
    // 代码块前至少有一个空格
    'space-before-blocks': [2, 'always'],
    // 函数名称或 function 关键字与开头括号之间不允许有空格
    'space-before-function-paren': [2, 'never'],
    // 禁止在括号内使用空格
    'space-in-parens': [2, 'never'],
    // 中缀运算符周围需有空格
    'space-infix-ops': 2,
    // 一元运算词后须有空格,一元运算符后不允许有空格
    'space-unary-ops': [2, {
    'words': true,
    'nonwords': false
    }],
    // 注释//和/*后必须跟一个空格
    'spaced-comment': [2, 'always', {
    'markers': ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!', ',']
    }],
    // 模板字符串${}中不允许有空格
    'template-curly-spacing': [2, 'never'],
    // 不允许 NaN 值得直接比较,需使用 isNaN()
    'use-isnan': 2,
    // typeof 比较需使用有效字符串("undefined","object","boolean","number","string","function","symbol",和"bigint")
    'valid-typeof': 2,
    // 自调用匿名函数 (IIFEs) 使用括号包裹
    'wrap-iife': [2, 'any'],
    // yield 表达式前后都要有空格
    'yield-star-spacing': [2, 'both'],
    // 禁止 Yoda 条件(条件的字面值排在第一,而变量排在第二)
    'yoda': [2, 'never'],
    // 使用 const 声明初始赋值后永远不重新赋值的变量
    'prefer-const': 2,
    // 生产环境中禁止使用 debugger 调试器
    'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0,
    // 花括号内需要空格({}除外)
    'object-curly-spacing': [2, 'always', {
    objectsInObjects: false // 以对象元素开始或结束的花括号间不允许有空格
    }],
    // 数组方括号内不允许使用空格
    'array-bracket-spacing': [2, 'never']
  }
}

配置校验忽略文件 .eslintignore


内容为忽略的路径和文件,符合规则的文件不会被校验

.gitignore(git忽略文件)

和.eslintignore 一样,配置一些git 管理不需要 管理的 文件

.DS_Store
node_modules
/dist

# local env files
.env.local
.env.*.local

# Log files
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*

# Editor directories and files
.idea
.vscode
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

babel.config.js

Babel 可以通过 babel.config.js 进行配置。
它包含了 babel-preset-env、JSX 支持以及为最小化包体积优化过的配置。通过它的文档可以查阅到更多细节和 preset 选项。

这里vueCli专用的

package.json

引第三包需要注意它的性质,因为打包上线depend里的包都会被打包,会影响打包体积

vue.config.js

vue.config.js 是一个可选的配置文件,如果项目的 (和 package.json 同级的) 根目录中存在这个文件,那么它会被 @vue/cli-service 自动加载。你也可以使用 package.json 中的 vue 字段,但是注意这种写法需要你严格遵照 JSON 的格式来写。
参数具体参考:文档

const path = require('path')

function resolve(dir) {
  return path.join(__dirname, dir)
}

module.exports = {
  publicPath: '/',  //公共路径
  outputDir: 'dist',  //打包到xx文件夹,没有会自动生成
  assetsDir: 'static',  // 打包后的静态资源存放xx文件夹,css.js等
  lintOnSave: process.env.NODE_ENV === 'development',
  productionSourceMap: false, //静态资源打包时是否生成.map文件。本地true,线上false
  devServer: {
    port: 7779, //运行端口
    open: true, //npm run serve完是否在浏览器打开 localhost:7771
    overlay: {  //警告和错误提示
      warnings: false,
      errors: true
    },
  },
  configureWebpack: {
    name: 'dkyadmin',
    resolve: {
      alias: { //还可以配置一些特定的文件夹。看个人爱好
        '@': resolve('src') // 简化路径匹配 @/views == 项目路径/src/views 
      }
    }
  }
}

至此 配置结束,

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容