Vue项目总结(1)-基本概念+Nodejs+VUE+VSCode

一个现代JS Web项目开发环境其实就是一个Nodejs应用,通过使用一系列工具完成开发过程中的各种任务,所以,现在完成一个项目的开发不能只是敲代码,还必须掌握一些现代的工程方法和工具。本文对于常用的一些工具和方法进行简单整理。

基础工具和概念

包管理

通常JS项目的开发都是从安装依赖包开始的,就是执行npm i xxx命令。实际使用中,最好使用cnpm代替npm,速度快很多,出错情况也少。安装时要区分3中情况:dependencies(-S--save),devDependencies(-D--save-dev),peerDependencies�。这3种方式都会把包安装在node_modules目录下,但是在package.json中在相应字段对象中。

dependencies是生产环境依赖的包,devDependencies是开发环境依赖的包。如果开发的项目是最终的应用,其实看不出这两种方式有什么区别,但是如果开发的是会被其他项目依赖的库,执行install时,只有dependencies被安装,devDependencies不被安装。

如果自己做的库需要依赖某个包A,但是又不想在被其他项目引用时在自己的目录下安装包A,而是使用项目中的包A,那么就把这个包放在peerDependencies里。这中方式主要是为了解决版本一致性和静态初始化的问题。这个和Nodejs查找node_modules的规则有关,在寻找NPM模块包时,会从当前目录出发,向上搜索各级当中的node_modules文件夹当中的文件,但若有两个同名文件,则遵循就近原则。这样就可能会导致整个应用使用某个包的版本不一致。如果包A里有静态初始化的代码(例如:创建一个全局对象),这样会导致多次执行,产生冲突。

参考:https://docs.npmjs.com/files/package.json

参考:https://nodejs.org/dist/latest-v10.x/docs/api/modules.html

Babel

Babel是一个Javascript编译器,通过插件( plugin)对处理代码。Babel的插件非常多,用preset代表插件的集合。

插件是npm里的一个包,在Babel的配置文件中直接指定包名。

{
  "plugins": ["babel-plugin-myPlugin"]
}

插件的名称如果以babel-plugin-开头,可以省略。

{
  "plugins": ["myPlugin"]
}

如果设置了多个插件或preset,执行的顺序是:

  1. 插件优先于预制;
  2. 插件按从前到后执行;
  3. 预制按从后到前执行。

插件和预制都可以指定参数。

{
  "plugins": [["pluginA", {}]]
}

参考:https://babeljs.io/docs/en/babel-cli/

prettier

prettier是一个代码格式化工具,可以设置行宽度、缩进空格数、结尾分号等。

参考:https://prettier.io/docs/en/options.html

ESLint

ESLint是一个插件话的Javascript代码检查工具,可以辅助发现代码的语法和格式问题。

cnpm i eslint -D # 安装
eslint --init # 初始化

ESLint 默认使用Espree作为其解析器,你可以在配置文件中指定一个不同的解析器,例如:Babel-ESLint

{
    "parser": "esprima",
    "rules": {
        "semi": "error"
    }
}

一个环境定义了一组预定义的全局变量。

{
    "env": {
        "browser": true,
        "node": true
    }
}

ESLint 附带有大量的规则。你可以使用注释或配置文件修改你项目中要使用的规则。要改变一个规则设置,你必须将规则 ID 设置为下列值之一:

  • "off" 或 0 - 关闭规则
  • "warn" 或 1 - 开启规则,使用警告级别的错误:warn (不会导致程序退出)
  • "error" 或 2 - 开启规则,使用错误级别的错误:error (当被触发的时候,程序会退出)
{
    "rules": {
        "eqeqeq": "off",
        "curly": "error",
        "quotes": ["error", "double"]
    }
}

设置信息可以放在.eslintrc.js文件或者package.json文件中的eslintConfig部分。

参考:https://eslint.bootcss.com/docs/user-guide/configuring/

webpack

webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。

loader让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript),例如:style-loader,css-loader,file-loader等。loader 可以将所有类型的文件转换为 webpack 能够处理的有效模块,然后你就可以利用 webpack 的打包能力,对它们进行处理。

插件目的在于解决 loader 无法实现的其他事,例如生成html文件(HtmlWebpackPlugin),限制chunk的大小,进行资源替换等。

从 webpack v4.0.0 开始,可以不用引入一个配置文件。

参考:https://webpack.js.org

从头设置新项目

从0开始

创建项目目录。

mkdir try-vscode

初始化,创建默认的package.json文件。

npm init -y

在项目目录下创建.vscode/settings.json文件,用于vscode的项目本地化设置。

{
  "editor.detectIndentation": false,
  "editor.tabSize": 2
}

设置代码格式化

安装插件Prettier - Code formatter

创建.prettierrc文件

{
  "tabWidth": 2,
  "semi": false,
  "singleQuote": true,
  "printWidth": 120
}

也可以将这些设置放在.vscode/settings.json中。

{
  "prettier.semi": false,
  "prettier.singleQuote": true,
  "prettier.printWidth": 120,
  "prettier.tabWidth": 2
}

代码检查

安装(如果已经进行了全局安装可以不进行本地安装)

cnpm i eslint -S

初始化配置文件.eslintrc.js

npx eslint --init

按提示进行选择

? How would you like to use ESLint? To check syntax and find problems
? What type of modules does your project use? JavaScript modules (import/export)
? Which framework does your project use? None of these
? Where does your code run? (Press <space> to select, <a> to toggle all, <i> to invert selection)Browser, Node
? What format do you want your config file to be in? JavaScript

设置完成后,在VSCode的代码窗口和problem窗口中就会提示发现的错误。

发布npm包

需要在npmjs.com注册账号,然后通过npm adduser命令添加账号到本地。

在项目根目录下执行命令。

npm publish

发布包的内容在package.json文件中定义,主要的字段包括:name,version,files,main,module等。如果package.json中存在 module 字段,会优先使用,如果没找到对应的文件,则会使用 main 字段,并按照 CommonJS 规范打包。每一次发布包必须升级版本号,不能直接更新已有版本。

VUE项目

如果VUE的前端项目,最好直接用vue-cli创建项目,这样就不用单独安装依赖包了。

vue-cli create try-vscode

项目创建成功后,会生成package.jsonvue.config.js文件(创建项目过程中可以将其他设置指定为独立的文件)。

如果项目的目录结构比较复杂,引用代码的层级较深,可以考虑在vue.config.js文件中设置别名。

chainWebpack: config => {
    config.resolve.alias.set('@', resolve('./'))
  }

jest.config.js

{
  moduleNameMapper: {
        '^@/(.*)$': '<rootDir>/$1'
    }
}

本系列其他文章

Vue项目总结(2)-前端独立测试+VUE

Vue项目总结(3)-前后端分离导致的跨域问题分析

Vue项目总结(4)-API+token处理流程

Vue项目总结(5)-表单组件基础

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

推荐阅读更多精彩内容

  • babel官网 babel 介绍 Babel 是一个通用的多用途 JavaScript 编译器。通过 Babel ...
    锋享前端阅读 1,815评论 0 10
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,285评论 4 31
  • 作者:小 boy (沪江前端开发工程师)本文原创,转载请注明作者及出处。原文地址:https://www.smas...
    iKcamp阅读 2,754评论 0 18
  • 1. 新建一个文件夹,命名为 webpack-cli , webpack-cli 就是你的项目名,项目名建议使用小...
    鲁大师666阅读 1,472评论 1 3
  • 这是一个关于自我认知的问题。 首先,明确自己想成为一个什么样的人? 其次,成为这样的一个人,需要做到哪几点? 最后...
    小马宇阳阅读 351评论 0 0