Vue学习总结(三):webpack和vue | 您所在的位置:网站首页 › vue项目集成webpack › Vue学习总结(三):webpack和vue |
webpack
Webpack 是一个前端资源的打包工具,它可以将js、image、css等资源当成一个模块进行打包。 中文官方网站:https://www.webpackjs.com/ 打包的好处: 将许多碎小文件打包成一个整体,减少单页面内的衍生请求次数,提高网站效率。将ES6的高级语法进行转换编译,以兼容老版本的浏览器。将代码打包的同时进行混淆,提高代码的安全性。1、安装 webpack支持全局安装和本地安装,官方推荐是本地安装 输入命令:npm install webpack --save-dev webpack 4+ 版本,还需要安装 CLI ,输入命令:npm install webpack webpack-cli --save-dev 我们注意下项目中文件夹下package.json文件,打开文件,可以看到我们之前用npm安装过的文件都会出现在这里: // 运行时依赖,使用npm --save命令安装会出现在这里,会随项目打包 "dependencies": { "npm": "^6.9.0", "vue": "^2.6.10", "vue-router": "^3.0.3" }, // 开发时依赖,一般是开发的工具,使用npm --dev命令安装会出现在这里,不随项目一起打包 "devDependencies": { "webpack": "^4.29.6", "webpack-cli": "^3.3.0" }2、核心概念 学习Webpack,需要先理解四个核心概念: 入口(entry) webpack打包的起点,可以有一个或多个,一般是js文件。webpack会从起点文件开始,寻找起点直接或间接依赖的其它所有的依赖,包括JS、CSS、图片资源等,作为将来打包的原始数据输出(output) 出口一般包含两个属性:path和filename。用来告诉webpack打包的目标文件夹,以及文件的名称。目的地也可以有多个。加载器(loader) webpack本身只识别Js文件,如果要加载非JS文件,必须指定一些额外的加载器(loader),例如css-loader。然后将这些文件转为webpack能处理的有效模块,最后利用webpack的打包能力去处理。插件(plugins) 插件可以扩展webpack的功能,让webpack不仅仅是完成打包,甚至各种更复杂的功能,或者是对打包功能进行优化、压缩,提高效率。3、编写webpack配置 编写一个webpack的配置,来指定一些打包的配置项。配置文件的名称,默认就webpack.config.js,放到hello-vue的根目录,配置文件中就是要指定上面说的四个核心概念,入口、出口、加载器、插件。不过,加载器和插件是可选的。我们先编写入口和出口 ① 入口 webpack打包的起点,可以有一个或多个,一般是js文件。我们所有的东西都集中在index.html,不是一个js,那怎么办? 答案是新建一个js,把index.html中的部分内容进行集中,然后在index.html中引用这个js 然后把原来index.html中的js代码全部移动到index.js中 // 使用es6的语法导入js模块 import Vue from '../node_modules/vue/dist/vue'; import VueRouter from '../node_modules/vue-router/dist/vue-router'; import loginForm from './user/login'; import registerForm from './user/register'; Vue.use(VueRouter);// install的组件需要use // 创建vue对象 const router = new VueRouter({ routes: [ // 编写路由规则 // path: 路由请求路径;component:组件名称 {path: "/login", component: loginForm}, {path: "/register", component: registerForm} ] }); var vm = new Vue({ el: "#app", components: { loginForm, registerForm }, router });原来的index.html中引入了很多其它js,在这里我们使用es6的import语法进行导入。 注意,要使用import,就需要在login.js和register.js中添加export导出语句: const loginForm={ template: '\ \ 登陆页\ 用户名:\ 密 码:\ ', } export default loginForm; const registerForm = { template:'\ \ 注册页 \ 用 户 名:\ 密 码:\ 确认密码:\ \ ' } export default registerForm;vue-router使用模块化加载后,必须增加一句:Vue.use(VueRouter) 这样,index.js就成了我们整个配置的入口了。 在webpack.config.js中添加以下内容: module.exports={ entry:'./src/index.js', //指定打包的入口文件 }② 出口 出口,就是输出的目的地。一般我们会用一个dist目录,作为打包输出的文件夹: 然后,编写webpack.config.js,添加出口配置: module.exports={ entry:'./src/main.js', //指定打包的入口文件 output:{ // path: 输出的目录,__dirname是相对于webpack.config.js配置文件的绝对路径 path : __dirname+'/dist', filename:'build.js' //输出的js文件名 } }4、执行打包 在控制台输入以下命令:npx webpack --config webpack.config.js 随后,查看dist目录下会出现一个build.js文件,尝试打开,你根本看不懂:所有的js合并为1个,并且对变量名进行了随机打乱,这样就起到了 压缩、混淆的作用。 5、测试运行 在index.html中引入刚刚生成的build.js文件:效果跟之前写在里面的一样 Title 登录 注册6、打包CSS 编写一段CSS代码,对index的样式做一些美化: ① 安装加载器 webpack默认只支持js加载。要加载CSS文件,必须安装加载器:命令:npm install style-loader css-loader --save-dev "devDependencies": { "css-loader": "^2.1.1", "style-loader": "^0.23.1", "webpack": "^4.29.6", "webpack-cli": "^3.3.0" }② index.js引入css文件 import './css/main.css'③ 配置加载器 在webpack.config.js配置文件中配置css的加载器 module.exports = { entry: './src/main.js', //指定打包的入口文件 output: { path: __dirname + '/dist', // 注意:__dirname表示webpack.config.js所在目录的绝对路径 filename: 'build.js' //输出文件 }, module: { rules: [ { test: /\.css$/, // 通过正则表达式匹配所有以.css后缀的文件 use: [ // 要使用的加载器,这两个顺序一定不要乱 'style-loader', 'css-loader' ] } ] } }④ 重新打包 输入打包指令:npx webpack --config webpack.config.js 效果图: 8、打包HTML 之前的打包过程中,除了HTML文件外的其它文件都被打包了,当在线上部署时,我们还得自己复制HTML到dist,然后手动添加生成的js到HTML中,这非常不友好。 webpack中的一个插件:html-webpack-plugin,可以解决这个问题。 ① 安装插件:npm install html-webpack-plugin --save-dev 需要在webpack.config.js中添加插件: const HtmlWebpackPlugin = require('html-webpack-plugin'); module.exports = { entry: './src/main.js', //指定打包的入口文件 output: { path: __dirname + '/dist', // 注意:__dirname表示webpack.config.js所在目录的绝对路径 filename: 'build.js' //输出文件 }, module: { rules: [ { test: /\.css$/, // 通过正则表达式匹配所有以.css后缀的文件 use: [ // 要使用的加载器,这两个顺序一定不要乱 'style-loader', 'css-loader' ] } ] }, plugins:[ new HtmlWebpackPlugin({ title: '首页', //生成的页面标题首页 filename: 'index.html', // dist目录下生成的文件名 template: './src/index.html' // 我们原来的index.html,作为模板 }) ] }② 将原来HTML中的引入js代码删除: ③ 再次打包:npm run build ④ 查看dist目录: 9、热更新的web服务 刚才的案例中,每次修改任何js或css内容,都必须重新打包,非常麻烦。 webpack给我们提供了一个插件,可以帮我们运行一个web服务,加载页面内容,并且修改js后不需要重新加载就能看到最新结果: ① 安装插件:npm install webpack-dev-server --save-dev ② 添加启动脚本:在package.json中配置script "scripts": { "dev": "webpack-dev-server --inline --hot --open --port 8080 --host 127.0.0.1" }, inline:自动刷新hot:热加载port:指定端口open:自动在默认浏览器打开host:可以指定服务器的 ip,不指定则为127.0.0.1③ 运行脚本:npm run dev vue-cli在开发中,需要打包的东西不止是js、css、html。还有更多的东西要处理,这些插件和加载器如果我们一一去添加就会比较麻烦。 vue官方提供了一个快速搭建vue项目的脚手架:vue-cli,使用它能快速的构建一个web工程模板。 官网:https://github.com/vuejs/vue-cli 安装命令:npm install -g vue-cli 1、快速上手 新建一个module: 而单文件组件中包含三部分内容: template:模板,支持html语法高亮和提示script:js脚本,这里编写的就是vue的组件对象,还可以有data(){}等style:样式,支持CSS语法高亮和提示每个组件都有自己独立的html、JS、CSS,互不干扰,真正做到可独立复用。 4、运行 看看生成的package.json: 我们执行npm run dev 或者 npm start 都可以启动项目: |
CopyRight 2018-2019 实验室设备网 版权所有 |