不管是工作需要还是面试加分,vue技术栈已经成为了前端开发工程师必备的技术点。接下来,我将从零开发一套完整的vue项目开发环境,提供给需要的同行小伙伴观看也方便自己以后复习。
最美的自己
项目源码地址:github.com/tangmengche…
彻底 Vue 官方脚手架 Cli 帮我们初始化做了那些事,通过 webpack4.x 帮我们完成了哪些常见功能:
- 检查 node 环境配置
先本地全局安装node环境,vue的运行是依赖于node
的npm
的管理工具来实现的,node下载地址。下载好node之后,打开cmd管理工具,输入node -v
,回车,查看node版本号,出现版本号则说明安装成功
node -v npm -v
复制代码
版本号
- 初始化项目目录
在命令行依次输入:
mkdir my-vue-cli 新建项目目录
cd my-vue-cli/ 切换到项目目录
npm init 生成项目的一些信息,最终会生成一个package.json文件。注意:可以输入npm init -y可以不用按回车
复制代码
操作效果图
- 安装 webpack
webpack 是一个模块打包机,自动分析项目依赖的模块以及一些浏览器不能直接转换的高级语法等转换成浏览器可以解析的 js、css文件等。在项目根目录本地安装webpack, 本项目将使用webpack4.x版本
npm install webpack webpack-cli -D
复制代码
安装效果图
- 初始化项目目录和文件
在项目根目录新建一下文件:
src: 存放项目源码的目录
index.js: 需要被 webpack 编译的文件
build:存放项目的 webpack 配置文件
webpack.config.js 项目的webpack核心配置文件
index.html: 项目打包后自动将打包的文件添加在该文件里面
复制代码
目录效果图
npm run build
即可打包"build": "webpack --config ./build/webpack.config.js"
复制代码
function sum(a, b) {
return a + b;
}
var sum = sum(1, 2)
console.log(sum)
复制代码
如果项目dist目录生成了一个bundle.js文件,说明webpack打包正确.
测试效果图
- ES6/7/8/9等高级语法转换成ES5
npm install babel-loader @babel/core @babel/preset-env -D
babel-loader是将ES6等高级语法转换为能让浏览器能够解析的低级语法
@babel/core是babel的核心模块,编译器。提供转换的API
@babel/preset-env 可以根据配置的目标浏览器或者运行环境来自动将ES2015+的代码转换为es5
复制代码
修改效果图
然后运行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-properties将es6中更高级的API进行转化---类
复制代码
修改效果图
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);
})
复制代码
代码运行效果图
- stylus/less/scss等css预处理器转换成css
以下就以less预处理器为例,详细介绍下其用法,其余两种类似:
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语法
复制代码
@color: red;
#div1 {
color: @color;
font-size: 36px;
}
复制代码
打包效果图
注意:CSS3 的许多特性来说,需要添加各种浏览器兼容前缀,开发过程中,这样加太麻烦,postcss 帮你自动添加各种浏览器前缀
npm install postcss-loader autoprefixer -D
postcss-loader autoprefixer 处理浏览器兼容,自动为CSS3的某些属性添加前缀
复制代码
修改配置效果图
- 解析字体font、图片(jpg、png...)等静态资源
npm install file-loader url-loader -D
file-loader可以用来帮助webpack打包处理一系列的图片文件;比如:.png 、 .jpg 、.jepg等格式的图片。打包的图片会给每张图片都生成一个随机的hash值作为图片的名字
url-loader封装了file-loader,它的工作原理:1.文件大小小于limit参数,url-loader将会把文件转为Base64;2.文件大小大于limit,url-loader会调用file-loader进行处理,参数也会直接传给file-loader
复制代码
- 压缩打包后的js、css
npm install mini-css-extract-plugin -D
// or 或
npm install extract-text-webpack-plugin@next -D // 不推荐使用
npm install optimize-css-assets-webpack-plugin -D
npm install uglifyjs-webpack-plugin -D
// 扩展 消除未使用的css
npm install purify-webpack purify-css -D
复制代码
注意:在生产模式下,webpack自动将JS进行压缩。MiniCssExtractPlugin 推荐只用于生产环境,因为该插件在开发环境下会导致HMR功能缺失,所以日常开发中,还是用style-loader。 2. 修改核心配置文件webpack.config.js
修改配置效果图
- 常用选项以及插件的使用方法
npm install webpack-dev-server -D
复制代码
npm install html-webpack-plugin -D
html-webpack-plugin主要有两个作用: 1、为html文件中引入的外部资源如script、link动态添加每次compile后的hash,防止引用缓存的外部文件问题。2、可以生成创建html入口文件
复制代码
Document
复制代码
npm install clean-webpack-plugin -D
clean-webpack-plugin是删除webpack打包后的文件夹以及文件
复制代码
目前绝大多数的vue项目里核心业务代码都是.vue文件结尾的,但浏览器不支持对.vue文件的解析,故需webpack将.vue文件转换为浏览器能识别的js文件。
npm install vue-loader vue-template-compiler cache-loader thread-loader -D
npm install vue -S
vue-loader 作用解析.vue文件
vue-template-compiler 作用编译模板
cache-loader 作用缓存loader编译的结果
thread-loader 作用使用 worker 池来运行loader,每个 worker 都是一个 node.js 进程
vue 一个用于构建用户界面渐进式的MVVM框架
复制代码
测试123
复制代码
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。
npm install vue-router vuex -S
vue-router是 Vue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌
vuex是一个专为 Vue.js 应用程序开发的状态管理模式
复制代码
// Home.vue
home1231
复制代码
// About.vue
about
复制代码
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'
}
]
})
复制代码
import Vue from 'vue'
import App from './App.vue'
import router from './router'
new Vue({
router, // 新增
render: h => h(App)
}).$mount('#app')
复制代码