[VueJsDev] 快速入门 - vue项目根目录配置文件
[VueJsDev] 目录列表
https://www.cnblogs.com/pengchenggang/p/17037320.html
vue项目根目录配置文件
::: details 目录
- vue项目根目录配置文件
- Part. 1: package.json - 入口文件
- Part. 2: jsconfig.json - 舒适度文件
- Part. 3: .eslintignore - 代码校验忽略
- Part. 4: .eslintrc.js - 代码校验配置
- Part. 5: .gitignore - git忽略
- Part. 6: .babelrc - 编译器
- Part. 7: .editorconfig - 统一编码风格
- Part. 8: .npmrc - 指定npm源
- Part. 9: .postcssrc.js - css加前缀
- Part. 10: .travis.yml - 自动构建
- Part. 11: alias.config.js - vue别名
- Part. 12: cypress.json - 测试配置
- Part. 13: .favorites.json - 收藏夹配置
- Part. 14: vue.config.js - vue2配置
- Proc. 15: 过程回溯
:::
根目录有很多常见的配置文件,这里重点强调下jsconfig.json
Part. 1: package.json - 入口文件
作用:package.json 是一个项目的入口,可以用
npm init -y创建
// jsconfig.json
{
"name": "projectName", // 项目名称
"version": "1.0.0", // 版本号
"author": "authorName<123456@qq.com>", // 作者
"private": false, // 是否可以打包发布,设置true就变成私有,就不允许打包发布
"type": "module", // 模块类型 是 CommonJS 还是 ES Module 默认不写是 CommonJS
"script": {}, // 执行命令脚本
"dependencies": {}, // 依赖库 --save 开发和打包后都带上的库
"devDependencies": {}, // 开发依赖库 --save-dev 只有开发的时候带上的库
"browserslist": [], // 根据浏览器环境,智能添加css前缀和js的polyfill垫片
"gitHooks": {}, // 钩子配置 经常会换成Husky
"lint-staged": {}, // 代码检查配置
}
Part. 2: jsconfig.json - 舒适度文件
作用:提高在写项目时舒适度的。如果是ts,文件名会是
tsconfig.json
jsconfig.json存在的目录表示本项目的根目录- vscode 会识别vue文件中的import export的变量,文件中的函数,可以自动跳转。
::: tip 坑中回忆
vscode 函数 变量 自动跳转的坑:
- 根目录没有
jsconfig.json有些会不起作用 - 根目录没有
jsconfig.json自动跳转的插件也会不起作用 - 自动跳转的插件 不要装重复了,导致冲突
:::
// jsconfig.json
{
"compilerOptions": {
"target": "ES6",
"module": "commonjs",
"allowSyntheticDefaultImports": true,
"baseUrl": "./",
"paths": {
"@/*": ["src/*"]
}
},
"include": [
"src/**/*"
],
"exclude": [
"node_modules"
]
}
Part. 3: .eslintignore - 代码校验忽略
作用: 哪些目录 文件 不进行 eslint校验
// .eslintignore
/public/pdfjs/
Part. 4: .eslintrc.js - 代码校验配置
作用: eslint校验
::: tip 坑中回忆
写代码的时候,你会发现eslint对你的各种报错,可以到这里将提示的报错配置都给关上。
:::
// .eslintrc.js
// http://eslint.org/docs/user-guide/configuring
module.exports = {
// 此项是用来告诉eslint找当前配置文件不能往父级查找
root: true,
// 此项是用来指定eslint解析器的,解析器必须符合规则,
// babel-eslint解析器是对babel解析器的包装使其与ESLint解析
parserOptions: {
parser: 'babel-eslint'
},
// 此项指定环境的全局变量,下面的配置指定为浏览器环境
env: {
browser: true
},
// https://github.com/feross/standard/blob/
// master/RULES.md#javascript-standard-style
// 此项是用来配置标准的js风格,就是说写代码的时候要规范的写,
// 如果你使用vs-code我觉得应该可以避免出错
extends: [
'plugin:vue/essential',
'@vue/standard'
],
// required to lint *.vue files
// 此项是用来提供插件的,插件名称省略了eslint-plugin-,
// 下面这个配置是用来规范html的
plugins: [
'vue',
'html'
],
// add your custom rules here
// 下面这些rules是用来设置从插件来的规范代码的规则,
// 使用必须去掉前缀eslint-plugin-
// 主要有如下的设置规则,可以设置字符串也可以设置数字,两者效果一致
// "off" -> 0 关闭规则
// "warn" -> 1 开启警告规则
//"error" -> 2 开启错误规则
// 了解了上面这些,下面这些代码相信也看的明白了
rules: {
'no-unused-vars': 'off',
'indent': ['off', 2],
'no-trailing-spaces': ['error', { 'skipBlankLines': true }],
'spaced-comment': ['error', 'always'],
'object-curly-spacing': ['error', 'always'],
// allow async-await
'generator-star-spacing': 'off',
// allow debugger during development
'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
'vue/no-parsing-error': [
2, {
'x-invalid-end-tag': false
}],
'no-undef': 'off'
}
}
Part. 5: .gitignore - git忽略
git提交会忽略哪些文件
// .gitignore 这里就是举个例子
# dependencies
/node_modules
Part. 6: .babelrc - 编译器
Babel编译器 主要作用是将高级的代码编译成低级的代码,使浏览器都能识别
{
"presets": [
"@vue/app"
]
}
Part. 7: .editorconfig - 统一编码风格
作用: 多人开发时候统一 项目编码风格
- vscode 需要装插件
EditorConfig for VS Code
::: tip 坑中回忆 存盘后git发现所有行都有变化 - 拉下来的老项目 一保存,所有行都变化了,但是代码没有变化
- 最后发现是回车换行的问题
.editorconfigend_of_line = lf 选择行尾序列- 老项目不动代码存盘 文件变动 CRLF 的问题
:::
// .editorconfig
root = true
[*]
charset = utf-8
indent_style = space
indent_size = 2
end_of_line = lf
insert_final_newline = true
trim_trailing_whitespace = true
Part. 8: .npmrc - 指定npm源
设置项目的npm源,这样就不使用全局的npm源
- 这样可以保证不论那个开发人员在安装的时候都指定项目的源,不受当前npm环境影响
registry=http://192.168.100.100:8081/nexus/content/groups/npm-all/
ELECTRON_MIRROR=https://repo.huaweicloud.com/electron/
Part. 9: .postcssrc.js - css加前缀
兼容各种浏览器css,给css加前缀
- 不用理,都帮你弄好了,vue项目默认创建
// .postcssrc.js
module.exports = {
plugins: {
autoprefixer: {}
}
}
Part. 10: .travis.yml - 自动构建
作用: Travis.yml是持续集成(Travis CI)的配置文件
- 不用理,谁用CI谁再配置
// .travis.yml
language: node_js
node_js: stable
script: npm run lint
notifications:
email: false
Part. 11: alias.config.js - vue别名
vue 配置别名用的
// alias.config.js
function resolve (dir) {
return path.join(__dirname, dir)
}
module.exports = {
resolve: {
alias: {
'@': resolve('src'),
'_c': resolve('src/components')
}
}
}
Part. 12: cypress.json - 测试配置
作用: Cypress是前端测试框架
- 不用理,前端一般没时间写测试用例,没时间test
// cypress.json
{
"pluginsFile": "tests/e2e/plugins/index.js"
}
Part. 13: .favorites.json - 收藏夹配置
作用:vscode文件收藏夹配置文件
- 扩展 Favorites 作者 kdcro101 配置文件自动生成
// .favorites.json
[
{} // 收藏的文件
]
Part. 14: vue.config.js - vue2配置
vue2 项目配置文件,webpack的配置可以写在这里
// vue.config.js
const path = require('path')
const resolve = dir => {
return path.join(__dirname, dir)
}
// 项目部署基础
// 默认情况下,我们假设你的应用将被部署在域的根目录下,
// 例如:https://www.my-app.com/
// 默认:'/'
// 如果您的应用程序部署在子路径中,则需要在这指定子路径
// 例如:https://www.foobar.com/my-app/
// 需要将它改为'/my-app/'
const BASE_URL = process.env.NODE_ENV === 'production'
? 'yourname_web/'
: 'yourname_web/'
const getTimeStamp = () => {
let ret = ''
const date = new Date()
ret += date.getFullYear()
ret += '-' + (date.getMonth() + 1)
ret += '-' + date.getDate()
ret += '_' + date.getHours()
ret += '-' + date.getMinutes()
ret += '-' + date.getSeconds()
return ret
}
module.exports = {
outputDir: 'yourname_web',
// outputDir: `dist/js_${getTimeStamp()}`,
baseUrl: BASE_URL,
configureWebpack: {
output: { // 输出重构 打包编译后的 文件名称 【模块名称.版本号.时间戳】
filename: `js/[name].${getTimeStamp()}.js`,
chunkFilename: `js/[name].${getTimeStamp()}.js`
}
},
// tweak internal webpack configuration.
// see https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md
// 如果你不需要使用eslint,把lintOnSave设为false即可
lintOnSave: true,
chainWebpack: config => {
// key,value自行定义,比如.set('@@', resolve('src/components'))
config.resolve.alias
.set('@', resolve('src'))
.set('_c', resolve('src/components'))
},
// 设为false打包时不生成.map文件
productionSourceMap: false,
// 这里写你调用接口的基础路径,来解决跨域,如果设置了代理,
// 那你本地开发环境的axios的baseUrl要写为 '' ,即空字符串
devServer: {
sockHost: 'http://localhost:8080/',
disableHostCheck: true
// proxy: 'localhost:3000'
}
}
Proc. 15: 过程回溯
这里粗略的写了下常用配置文件的作用,如果需要深入,可以自行网上查找资料
- 主要目的是在看项目目录的时候,心中对每个文件都清晰明了
- 很多时候,并不太需要深入每个配置文件
[VueJsDev] 快速入门 - vue项目根目录配置文件的更多相关文章
- 快速搭建Vue项目
快速搭建Vue项目 第一次安装vue项目Vue推荐开发环境Node.js 6.2.0.npm 3.8.9.webpack 1.13.vue-cli 2.5.1.webstrom2016 安装环境: 安 ...
- 08Vue.js快速入门-Vue综合实战项目
8.1. 前置知识学习 npm 学习 官方文档 推荐资料 npm入门 npm介绍 需要了解的知识点 package.json 文件相关配置选项 npm 本地安装.全局安装.本地开发安装等区别及相关命令 ...
- 利用vue-cli3快速搭建vue项目详细过程
一.介绍 Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.有三个组件: CLI:@vue/cli 全局安装的 npm 包,提供了终端里的vue命令(如:vue create .vue ...
- 快速创建 Vue 项目
转载:https://www.jianshu.com/p/c7df292915e7 为了便于 Vue 项目的管理, Vue 团队官方开发了 vue-cli 工具. 本文将带您使用 vue-cli 快速 ...
- 如何快速把 Vue 项目升级到 webpack3
由于 webpack3升级后,新增了 Scope Hositing(作用域提升) 功能,据说是对 js的性能提升很大.因此,我们做了一个测试对比,就是 webpack3和 webpack1/2 的性能 ...
- python 全栈开发,Day88(csrf_exempt,ES6 快速入门,Vue)
BBS项目内容回顾 1. 登陆页面 1. 验证码 1. PIL(Pillow) 2. io 2. ORM 1. 增删改查 3. AJAX $.ajax({ url: '', type: '', dat ...
- 使用nodeJs安装Vue-cli并用它快速构建Vue项目
部分摘自:http://www.cnblogs.com/wisewrong/p/6255817.html(已在本地测试) 前提:nodeJs本地已安装. 一.安装 vue-cli 1.使用nodeJs ...
- vue-cli快速构建Vue项目
vue-cli是什么? vue-cli 是vue.js的脚手架,用于自动生成vue.js模板工程的. vue-cli怎么使用? 安装vue-cli之前,需要先装好vue 和 webpack npm i ...
- vue-cli快速构建vue项目模板
vue-cli 是vue.js的脚手架,用于自动生成vue.js模板工程的. 1.使用npm安装vue-cli 需要先装好vue 和 webpack(前提是已经安装了nodejs,否则连npm都用不了 ...
- 快速创建vue 项目
随着VUE 技术的不断更新,越来越多的开发者开始使用vue编写前端界面,今天我就和大家分享一下 ,如何快速创建一个vue项目. 前提: 安装了node.js 首先: 全局安装vue-cli 使用命令: ...
随机推荐
- 火遍外网的Keychron测评,带你入坑;ps马上5.20了送一个给你的心爱的她/他。
那些年用过的机械键盘 如果你经常上YouTube或Instagram,然后你又对键盘感兴趣,我相信你肯定看到过他--Keychron K2,他真的是一款曝光量很高的键盘. 1.键盘keychron k ...
- PaddleNLP--UIE(二)--小样本快速提升性能(含doccona标注)
相关文章: 1.快递单中抽取关键信息[一]----基于BiGRU+CR+预训练的词向量优化 2.快递单信息抽取[二]基于ERNIE1.0至ErnieGram + CRF预训练模型 3.快递单信息抽取[ ...
- 图像列表组件(TImageList)
TImageList 组件是一组同样尺寸的图像列表,每一个图像由它的Index值查询. 1.TImageList组件的典型用法 图形列表用于建立和管理大量的图像,主要是配合菜单或者工具栏按钮的使用.图 ...
- IIS创建和管理虚拟网站
实验介绍: 本文会详细介绍创建虚拟站点的三种方法 一:IP地址建立站点 1.打开安装了IIS的windows,进入ip配置页面. 添加几个ip,我这里添加的是192.168.1.209,192.168 ...
- 推荐一款id生成器: Hashids
唯一 id 生成的方式有很多种,比较常见的有以下几种方式: 语言自带功能,如 Java 中的 UUID,常用于后端 第三方工具提供,如 npm 中的 nanoid,常用于前端 Twitter 开源的 ...
- 两台redhat7虚拟机配置ssh免密访问
说明 有时候为了方便搭建各种集群环境,需要配置多台虚拟机之间可以互相免密码访问.本文就介绍一下这个知识点,希望所帮助的朋友给老徐点个赞:) 两台虚拟机环境配置如下: 虚拟机1:192.168.56.1 ...
- Shiro实战1-介绍
什么是 Shiro 官网:http://shiro.apache.org/ shiro是一款主流的 Java 安全框架,不依赖任何容器,可以运行在 Java SE和 Java EE 项目中,它的主要作 ...
- Spring Boot图书管理系统项目实战-3.用户登录
导航: pre: 2.项目搭建 next:4.基础信息管理 只挑重点的讲,具体的请看项目源码. 1.项目源码 需要源码的朋友,请捐赠任意金额后留下邮箱发送:) 2.登录页设计 <!DOCTYP ...
- 一个简单的Dockerfile多阶段构建go项目
From golang:1.16-alpine3.13 AS builder WORKDIR /app COPY . . RUN go build -o main main.go From alpin ...
- VUE 腾讯云 web端上传视频SDK 上传进度无法显示
上传视频官方文档:https://cloud.tencent.com/document/product/266/9239 错误信息 在本地调试可以显示视频上传进度,也可以打印到浏览器控制台.但是,发布 ...