本项目的笔记和资料的Download,请点击这一句话自行获取。javascript
day01-springboot(理论篇) ;day01-springboot(实践篇)css
day02-springcloud(理论篇一) ;day02-springcloud(理论篇二) ;day02-springcloud(理论篇三) ;day02-springcloud(理论篇四) ;html
day03-springcloud(Hystix,Feign) ;day03-springcloud(Zuul网关)前端
day04-项目搭建(一) ; day04-项目搭建(二); day04-ES6语法入门vue
day05-Vue入门学习java
day06-了解vue-router和webpack的使用 ; day06-初识Vuetify框架UI框架和使用域名访问本地项目 ; day06-使用nginx反向代理并掌握cors解决跨域 node
0.学习目标webpack
效果:nginx
咱们期待的是,当点击登陆或注册按钮,分别显示登陆页或注册页,而不是一块儿显示。es6
可是,如何才能动态加载组件,实现组件切换呢?
虽然使用原生的Html5和JS也能实现,可是官方推荐咱们使用vue-router模块。
使用vue-router和vue能够很是方便的实现 复杂单页应用的动态路由功能。
官网:https://router.vuejs.org/zh-cn/
https://nodejs.org/en/download/
(1)安装cnpm
以管理员身份打开cmd窗口,使用cnpm的获取国内镜像
npm install -g cnpm --registry=https://registry.npm.taobao.org
(2) 输入cnpm -v看看是否正常
cnpm -v在win10环境变量的系统变量path下添加该路径便可正常使用cnpm
(3)修改npm的资源镜像连接
npm config set registry http://registry.npm.taobao.org(4)全局安装webpack
npm install webpack -g安装完成以后能够输入webpack -v
(5)全局安装vue-cli,命令行中输入:
npm install --g vue-cli
安装完成以后cd到本身刚才新建的项目,好比进入的是:cd myvuedemo
进入以后输入命令:npm install ,这个命令会自动下载项目中全部用到的依赖
使用npm安装:
npm install vue-router --save
在index.html中引入依赖:
<script src="../node_modules/vue-router/dist/vue-router.js"></script>
新建vue-router对象,而且指定路由规则:
// 建立VueRouter对象 const router = new VueRouter({ routes:[ // 编写多个路由规则 { path:"/login", // 请求路径 component:loginForm // 组件名称 }, {path:"/register",component:registerForm}, ] })
在父组件中引入router对象:
var vm = new Vue({ el:"#app", components:{// 引用登陆和注册组件 loginForm, registerForm }, router // 引用上面定义的router对象 })
页面跳转控制:
<div id="app"> <!--router-link来指定跳转的路径--> <span><router-link to="/login">登陆</router-link></span> <span><router-link to="/register">注册</router-link></span> <hr/> <div> <!--vue-router的锚点--> <router-view></router-view> </div> </div>
<router-view>
来指定一个锚点,当路由的路径匹配时,vue-router会自动把对应组件放到锚点位置进行渲染<router-link>
指定一个跳转连接,当点击时,会触发vue-router的路由功能,路径中的hash值会随之改变效果:
注意:单页应用中,页面的切换并非页面的跳转。仅仅是地址最后的hash值变化。
事实上,咱们总共就一个HTML:index.html
Webpack 是一个前端资源的打包工具,它能够将js、image、css等资源当成一个模块进行打包。
中文官方网站:https://www.webpackjs.com/
官网给出的解释:
为何须要打包?
学习Webpack,你须要先理解四个核心概念:
入口(entry)
webpack打包的启点,能够有一个或多个,通常是js文件。webpack会从启点文件开始,寻找启点直接或间接依赖的其它全部的依赖,包括JS、CSS、图片资源等,做为未来打包的原始数据
输出(output)
出口通常包含两个属性:path和filename。用来告诉webpack打包的目标文件夹,以及文件的名称。目的地也能够有多个。
加载器(loader)
webpack自己只识别Js文件,若是要加载非JS文件,必须指定一些额外的加载器(loader),例如css-loader。而后将这些文件转为webpack能处理的有效模块,最后利用webpack的打包能力去处理。
插件(plugins)
插件能够扩展webpack的功能,让webpack不只仅是完成打包,甚至各类更复杂的功能,或者是对打包功能进行优化、压缩,提升效率。
webpack支持全局安装和本地安装,官方推荐是本地安装,咱们按照官方的来。
输入命令:npm install webpack webpack-cli --save-dev
此时,咱们注意下项目中文件夹下,会有一个package.json文件。
打开文件,能够看到咱们以前用npm安装过的文件都会出如今这里:
接下来,咱们编写一个webpack的配置,来指定一些打包的配置项。配置文件的名称,默认就是webpack.config.js,咱们放到hello-vue的根目录:
配置文件中就是要指定上面说的四个核心概念,入口、出口、加载器、插件。
不过,加载器和插件是可选的。咱们先编写入口和出口
webpack打包的启点,能够有一个或多个,通常是js文件。如今思考一下咱们有没有一个入口?貌似没有,咱们全部的东西都集中在index.html,不是一个js,那怎么办?
咱们新建一个js,把index.html中的部份内容进行集中,而后在index.html中引用这个js不就OK了!
而后把原来index.html中的js代码所有移动到main.js中
// 使用es6的语法导入js模块 import Vue from '../node_modules/vue/dist/vue'; import VueRouter from '../node_modules/vue-router/dist/vue-router' import loginForm from './js/login' import registerForm from './js/register' Vue.use(VueRouter) // 建立VueRouter对象 const router = new VueRouter({ routes:[ // 编写多个路由规则 { 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:` <div> <h2>登陆页</h2> 用户名:<input type="text"><br/> 密码:<input type="password"><br/> </div> ` } export default loginForm;
register.js:
const registerForm = { template:` <div> <h2>注册页</h2> 用户名:<input type="text"><br/> 密码:<input type="password"><br/> 确认密码:<input type="password"><br/> </div> ` } export default registerForm;
这样,main.js就成了咱们整个配置的入口了。
咱们在webpack.config.js中添加如下内容:
module.exports={ entry:'./src/main.js', //指定打包的入口文件 }
出口,就是输出的目的地。通常咱们会用一个dist目录,做为打包输出的文件夹。
而后,编写webpack.config.js,添加出口配置:
module.exports={ entry:'./src/main.js', //指定打包的入口文件 output:{ // path: 输出的目录,__dirname是相对于webpack.config.js配置文件的绝对路径 path : __dirname+'/dist', filename:'build.js' //输出的js文件名 } }
在控制台输入如下命令:
npx webpack --config webpack.config.js
随后,查看dist目录:
尝试打开build.js,你根本看不懂:
全部的js合并为1个,而且对变量名进行了随机打乱,这样就起到了 压缩、混淆的做用。
在index.html中引入刚刚生成的build.js文件,
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <!--router-link来指定跳转的路径--> <span><router-link to="/login">登陆</router-link></span> <span><router-link to="/register">注册</router-link></span> <hr/> <div> <!--vue-router的锚点--> <router-view></router-view> </div> </div> <script src="../dist/build.js"></script> </body> </html>
而后运行:
咱们来编写一段CSS代码,对index的样式作一些美化:
内容:
#app a{ display: inline-block; width: 150px; line-height: 30px; background-color: dodgerblue; color: white; font-size: 16px; text-decoration: none; } #app a:hover{ background-color: whitesmoke; color: dodgerblue; } #app div{ width: 300px; height: 150px; } #app{ width: 305px; border: 1px solid dodgerblue; }
前面说过,webpack默认只支持js加载。要加载CSS文件,必须安装加载器:
命令:
npm install style-loader css-loader --save-dev
此时,在package.json中能看到新安装的:
由于入口在main.js,所以css文件也要在这里引入。依然使用ES6 的模块语法:
import './css/main.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
效果:
咱们每次使用npm安装,都会在package.json中留下痕迹,事实上,package.json中不只能够记录安装的内容,还可编写脚本,让咱们运行命令更加快捷。
咱们能够把webpack的命令编入其中:
之后,若是要打包,就能够直接输入:npm run build
便可。
npm run
:执行npm脚本,后面跟的是脚本的名称build
以前的打包过程当中,除了HTML文件外的其它文件都被打包了,当在线上部署时,咱们还得本身复制HTML到dist,而后手动添加生成的js到HTML中,这很是不友好。
webpack中的一个插件:html-webpack-plugin,能够解决这个问题。
1)安装插件:npm install --save-dev html-webpack-plugin
须要在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: '首页', //生成的页面标题<head><title>首页</title></head> filename: 'index.html', // dist目录下生成的文件名 template: './src/index.html' // 咱们原来的index.html,做为模板 }) ] }
2)将原来HTML中的引入js代码删除:
3)再次打包:npm run build
4)查看dist目录:
打开index.html,发现已经自动添加了当前目录下的build.js
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <!--router-link来指定跳转的路径--> <span><router-link to="/login">登陆</router-link></span> <span><router-link to="/register">注册</router-link></span> <div> <!--vue-router的锚点--> <router-view></router-view> </div> </div> <script type="text/javascript" src="build.js"></script></body> </html>
刚才的案例中,每次修改任何js或css内容,都必须从新打包,很是麻烦。
webpack给咱们提供了一个插件,能够帮咱们运行一个web服务,加载页面内容,而且修改js后不须要从新加载就能看到最新结果:
1)安装插件:
npm install webpack-dev-server --save-dev
2)添加启动脚本
在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
3)运行脚本:
npm run dev
4)效果:
==================================================
参考资料:
若是你用vue-cli脚手架来搭建项目,配置过程会选择是否用到路由,若是选择y,后面下载依赖会自动下载vue-router。
end