vlambda博客
学习文章列表

从零开发一套完整的vue项目开发环境

关注 Vue社区,回复“加群

汤小梦

juejin.im/post/5e0cba76f265da5d4e27480c

仓库地址

目标

彻底 Vue 官方脚手架 Cli 帮我们初始化做了那些事,通过 webpack4.x 帮我们完成了哪些常见功能:

  1. ES6/7/8/9等高级语法转换成ES5

  2. stylus/less/scss等css预处理器转换成css

  3. 解析字体font、图片(jpg、png...)等静态资源

  4. 压缩js、css等文件

  5. 自动添加css各大浏览器厂商前缀

  6. 定义环境变量

  7. 抽离公共代码

  8. 项目热更新和懒加载

  9. 区别生产环境和开发环境

  10. 每次打包删除上一次打包记录

  11. ...

项目初始化

1、检查 node 环境配置
node -v npm -v
从零开发一套完整的vue项目开发环境
版本号
2、初始化项目目录
在命令行依次输入:
mkdir my-vue-cli 新建项目目录cd my-vue-cli/ 切换到项目目录npm init 生成项目的一些信息,最终会生成一个package.json文件。注意:可以输入npm init -y可以不用按回车
从零开发一套完整的vue项目开发环境
操作效果图

3、安装 webpack

webpack 是一个模块打包机,自动分析项目依赖的模块以及一些浏览器不能直接转换的高级语法等转换成浏览器可以解析的 jscss文件等。在项目根目录本地安装webpack, 本项目将使用webpack4.x版本

npm install webpack webpack-cli -D

从零开发一套完整的vue项目开发环境

安装效果图
4、初始化项目目录和文件

在项目根目录新建一下文件:

src: 存放项目源码的目录index.js: 需要被 webpack 编译的文件build:存放项目的 webpack 配置文件webpack.config.js 项目的webpack核心配置文件index.html: 项目打包后自动将打包的文件添加在该文件里面
从零开发一套完整的vue项目开发环境
目录效果图
  • 添加webpack配置文件的基本信息

  1. mode: 模式, development开发环境、production生产环境

  2. entry: 项目的打包的入口文件

  3. output: 项目的打包后输出文件

  4. module: 模块, 在webpack中所有文件皆模块, 解析css、js、图片以及字体图标等

  5. plugins: 插件, 用来扩展webpack功能

  6. ...

  • 在package.json文件 scripts 属性中添加 运行 npm run build 即可打包

"build": "webpack --config ./build/webpack.config.js"
  • 在index.js中添加测试代码验证webpack打包是否正确

function sum(a, b) { return a + b;}var sum = sum(1, 2)console.log(sum)

如果项目dist目录生成了一个bundle.js文件,说明webpack打包正确.

从零开发一套完整的vue项目开发环境

测试效果图

配置核心功能

1、ES6/7/8/9等高级语法转换成ES5
  • 在index.js中添加ES6/7/8等高级语法的代码测试代码验证webpack是否能将其转换为ES5等让浏览器能够解析的低级语法

1.安装相关依赖

npm install babel-loader @babel/core @babel/preset-env -D    babel-loader是将ES6等高级语法转换为能让浏览器能够解析的低级语法 @babel/core是babel的核心模块,编译器。提供转换的API@babel/preset-env 可以根据配置的目标浏览器或者运行环境来自动将ES2015+的代码转换为es5

2.修改核心配置文件webpack.config.js

从零开发一套完整的vue项目开发环境
修改效果图

然后运行npm run build,就可以看到我们输入的ES6+等高级语法被转换为ES5了。注意:babel-loader只会将 ES6/7/8等高级语法转换为ES5语法,但是对新api并不会转换。比如Promise、Iterator、Set、Proxy、Symbol等全局对象,以及一些定义在全局对象上的方法(比如Object.assign)都不会转码。此时,我们必须使用babel-polyfill,为当前环境提供一个垫片。

npm install @babel/polyfill -S babel-polyfill是解决babel-loader不能对新的api进行转换为当前环境添加一个垫片

重点:当我们执行打包后,打包的文件里含有大量的重复代码,那么我们需要提供统一的模块化的helper来减少这些helper函数的重复输出。

npm install @babel/runtime @babel/plugin-transform-runtime -D @babel/runtime就是提供统一的模块化的helper, 使用能大大减少打包编译后的体积@babel/plugin-transform-runtime它会帮我自动动态require @babel/runtime中的内容注意:还有一些常见的babel:@babel/plugin-proposal-decorators将es6+中更高级的特性转化---装饰器@babel/plugin-proposal-class-propertieses6中更高级的API进行转化---类

从零开发一套完整的vue项目开发环境

修改效果图

3. 在index.js中编写ES6+等高级语法


let fn = () => { console.log('箭头函数')}fn()
let promise = new Promise((resolve, reject) => { setTimeout(() => { resolve(123) }, 1000)})promise.then(res => { console.log(res);})
从零开发一套完整的vue项目开发环境
代码运行效果图
2、stylus/less/scss等css预处理器转换成css
  • 在项目src目录中添加index.less文件,并在index.js文件中引入其文件

以下就以less预处理器为例,详细介绍下其用法,其余两种类似:

  1. 安装相关依赖

    npm install stylus stylus-loader less less-loader sass-loader node-sass css-loader style-loader -D  css-loader主要的作用是解析css文件, 像@import等动态语法 style-loader主要的作用是解析的css文件渲染到html的style标签内 stylus、less、sass是CSS的常见预处理器 stylus-loader、less-loader、sass-loader主要是将其对应的语法转换成css语法
  2. 修改核心配置文件webpack.config.js

    从零开发一套完整的vue项目开发环境

    修改配置效果图
  3. 添加index.less文件

    @color: red;#div1 { color: @color; font-size: 36px;}

从零开发一套完整的vue项目开发环境

打包效果图

注意:CSS3 的许多特性来说,需要添加各种浏览器兼容前缀,开发过程中,这样加太麻烦,postcss 帮你自动添加各种浏览器前缀

npm install postcss-loader autoprefixer -D postcss-loader autoprefixer 处理浏览器兼容,自动为CSS3的某些属性添加前缀

从零开发一套完整的vue项目开发环境

修改配置效果图
3、解析字体font、图片(jpg、png...)等静态资源
  • 项目中通常会使用图片、字体等静态资源,不使用对应的loader项目会报错

1.安装相关依赖

npm install file-loader url-loader -D file-loader可以用来帮助webpack打包处理一系列的图片文件;比如:.png 、 .jpg 、.jepg等格式的图片。打包的图片会给每张图片都生成一个随机的hash值作为图片的名字url-loader封装了file-loader,它的工作原理:1.文件大小小于limit参数,url-loader将会把文件转为Base64;2.文件大小大于limiturl-loader会调用file-loader进行处理,参数也会直接传给file-loader

2.修改核心配置文件webpack.config.js

从零开发一套完整的vue项目开发环境

修改配置效果图
4、压缩打包后的js、css
  • 由于项目打包后会生成很多js文件,代码之间有很多空格、引号等,如果我们将其去掉,这样会大大减少打包的体积

1.安装相关依赖

npm install mini-css-extract-plugin -D// ornpm install extract-text-webpack-plugin@next -D // 不推荐使用npm install optimize-css-assets-webpack-plugin -Dnpm install uglifyjs-webpack-plugin -D// 扩展 消除未使用的cssnpm install purify-webpack purify-css -D

注意:在生产模式下,webpack自动将JS进行压缩。MiniCssExtractPlugin 推荐只用于生产环境,因为该插件在开发环境下会导致HMR功能缺失,所以日常开发中,还是用style-loader。2. 修改核心配置文件webpack.config.js

从零开发一套完整的vue项目开发环境

修改配置效果图
5、常用选项以及插件的使用方法
  • 大家都习惯的Ctrl+S保存代码后就想浏览器自动刷新来更新我们的页面

1.安装相关依赖

npm install webpack-dev-server -D

2.修改核心配置文件webpack.config.js


从零开发一套完整的vue项目开发环境
修改配置效果图
  • 通过html-webpack-plugin插件来创建html文件,并自动引入打包后的js文件

1.安装相关依赖

npm install html-webpack-plugin -D html-webpack-plugin主要有两个作用: 1、为html文件中引入的外部资源如script、link动态添加每次compile后的hash,防止引用缓存的外部文件问题。2、可以生成创建html入口文件

2.在项目根目录新建index.html文件

 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body>  </body> </html>

3.修改核心配置文件webpack.config.js

从零开发一套完整的vue项目开发环境
修改配置效果图
  • 通过clean-webpack-plugin插件来自动删除上一次打包的文件

1.安装相关依赖

npm install clean-webpack-plugin -D
clean-webpack-plugin是删除webpack打包后的文件夹以及文件

2.修改核心配置文件webpack.config.js

从零开发一套完整的vue项目开发环境
修改配置效果图

webpack识别.vue文件

目前绝大多数的vue项目里核心业务代码都是.vue文件结尾的,但浏览器不支持对.vue文件的解析,故需webpack将.vue文件转换为浏览器能识别的js文件。

  1. 安装相关依赖

    npm install vue-loader vue-template-compiler cache-loader thread-loader -Dnpm install vue -S vue-loader 作用解析.vue文件vue-template-compiler 作用编译模板cache-loader 作用缓存loader编译的结果thread-loader 作用使用 worker 池来运行loader,每个 worker 都是一个 node.js 进程vue 一个用于构建用户界面渐进式的MVVM框架
  2. 修改核心配置文件webpack.config.js


    修改配置效果图
  3. 在项目根目录新建App.vue文件

    <template> <div> 测试123 </div></template><script>export default { }</script>
  4. 修改index.js

    import Vue from 'vue';import App from './App.vue';
    new Vue({ render: h => h(App)}).$mount('#app')

通过以上操作后执行npm run build,则可以看到webpack将.vue文件解析为浏览器可以识别的js语法。也可以通过运行npm run dev看到浏览器页面上会渲染出123。

Vue集成VueRouter和Vuex

  1. 安装相关依赖

    npm install vue-router vuex -S vue-routerVue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌vuex是一个专为 Vue.js 应用程序开发的状态管理模式
  2. 集成vue-router

  • 新建Home.vue和About.vue两个组件

    // Home.vue<template> <div> home1231 </div></template><script>export default { name: 'Home'}</script><style lang="scss" scoped></style>

    // About.vue<template> <div> about </div></template><script>export default { name: 'About'}</script><style lang="scss" scoped></style>
  • 新增路由的配置文件 在项目的src目录里,新建/src/router/index.js。注意:在加载路由时,可以使用路由懒加载的方式进行加载组件

    import Vue from 'vue';import VueRouter from 'vue-router';// import Home from '../views/Home.vue';// import About from '../views/About.vue';Vue.use(VueRouter); // 向Vue再注册路由export default new VueRouter({ mode: 'hash', routes: [ { path: '/Home', name: 'Home', // component: Home component: () => import(/* webpackChunkName: "Home" */ '../views/Home.vue') // 路由懒加载方式 }, { path: '/about', name: 'About', // component: About component: () => import(/* webpackChunkName: 'About' */ '../views/About.vue') }, { path: '*', // 匹配任何路由 redirect: '/Home' } ]})
  • 修改index.js文件

    import Vue from 'vue'import App from './App.vue'import router from './router'
    new Vue({ router, // 新增 render: h => h(App)}).$mount('#app')

扩展

  • 引入Element UI

  • 添加管理系统常见的布局(左右布局+上面导航)

  • ...

❤️ 看完两件事

如果你觉得这篇内容对你挺有启发,我想邀请你帮我两个小忙:

  1. 点个「在看」,让更多的人也能看到这篇内容(喜欢不点在看,都是耍流氓 -_-)

  2. 回复「100」免费获取 100本 最棒的前端电子书!