1.安装nodejs服务器。
java 项目可以运行在 tomcat 服务器,开始完成前后端完全分离。前端有自己独立的工程。我们需 要把前端独立的工程运行起来。 --- 运行在 nodejs 服务器下。 理解为 tomcat 服务器data:image/s3,"s3://crabby-images/11f0e/11f0e5dc5d160d6dfc749ee1573fc7fd78bb50b8" alt=""
data:image/s3,"s3://crabby-images/b224e/b224e26a6447bd1e68bf2dea36764957fea38b23" alt=""
1.1 安装npm
java 项目需要依赖 jar ,安装 maven 。 前端项目需要依赖第三方的插件。比如 axios elementui echarts 前端也需要一个管理组件的软件。 npm. 如果 package.json 文件 类似于 pom.xml 文件。 npm 通过该文件 package.json 文件安装依赖的插件。 如果安装了 node 默认 安装了 npm. 验证 : npm -vdata:image/s3,"s3://crabby-images/ebcae/ebcae8431a9c9f8cdcd3b916cf5d4ec76ea539ce" alt=""
2. 安装vue cli的脚手架
帮你创建前端项目工程。它的安装需要依赖上面的npm
2.1 安装vue cli
npm install -g @vue/cli -g: global 全局 验证是否安装成功 : vue --versiondata:image/s3,"s3://crabby-images/ce3f5/ce3f537fcc0c6ab9eb6fda0b2860ff8f637da16d" alt=""
3. 使用vuecli搭建vue前端项目
第一种使用命令 : vue create 第二种使用图形化界面: vue uidata:image/s3,"s3://crabby-images/0bb57/0bb5780fa5fcba3164804ca83216e56721729f07" alt=""
data:image/s3,"s3://crabby-images/d849a/d849af25f0adc50acecb073bf80a49994cc59b6c" alt=""
data:image/s3,"s3://crabby-images/96751/967516237ea7073c4977834e7ba8f8de7518177d" alt=""
data:image/s3,"s3://crabby-images/4a544/4a54434dc0466ae1c1abbd1a62a86b89aa8882c1" alt=""
data:image/s3,"s3://crabby-images/1abb8/1abb88e4e448e73ad259439b171bc4e37cc0cf10" alt=""
3.1 安装相应的插件--elementui
安装插件有两种方式 : 第一种使用命令 : npm i element-ui -S 第二种使用图形化 :data:image/s3,"s3://crabby-images/595da/595daa242f7259e0efdc30a0cf25e663e8b71790" alt=""
2.2 安装axios依赖
发送异步请求的。 第一种命令 : npm i -S axios 第二种图形化 : 如下data:image/s3,"s3://crabby-images/550e0/550e0185ba9da4f25a7e1b7b31611fa9b19be4fd" alt=""
4. 使用客户端软件打开vue工程
vscode [ 专业的前端工具 ] webstorm [idea 团队开发的软件 -- 只要会使用 idea 那么也会使用该工具 ] hbuilder [ 适合前端 ]data:image/s3,"s3://crabby-images/e93dc/e93dca8711906e816fed8b6da40a24b686321877" alt=""
data:image/s3,"s3://crabby-images/89d1a/89d1ab1ef2b8953985b76830ff181edc1d9fdf6b" alt=""
data:image/s3,"s3://crabby-images/b22b0/b22b0e936d52fb59fe4b60f0f6e83103ab17a9ef" alt=""
5. 组件化开发
组件化:一个页面可以拆分成一个个组件,每个组件有着自己独立的结构 [html] 、样式 [css] 、行为 [js] 。 好处:便于维护,利于复用 → 提升开发效率。 组件分类:普通组件、根组件。 比如:下面这个页面,可以把所有的代码都写在一个页面中,但是这样显得代码比较混乱,难易维 护。咱们可以按模块进行组件划分data:image/s3,"s3://crabby-images/506a2/506a2b12ad6936f473508f027b8a5a1b603cd847" alt=""
6. 根组件 App.vue
1. 根组件介绍 整个应用最上层的组件,包裹所有普通小组件data:image/s3,"s3://crabby-images/d202a/d202aab745a97e681af9dfa650091016c871dffe" alt=""
7. 普通组件的注册使用
普通组件的注册有两种方式。 ( 1 )局部注册: ( 2 )全局注册 普通组件的注册使用 - 局部注册 1. 特点: 只能在注册的组件内使用 2. 步骤: 1. 创建 .vue 文件(三个组成部分) 2. 在使用的组件内先导入再注册,最后使用 3. 使用方式: 当成 html 标签使用即可 < 组件名 ></ 组件名 > 4. 注意: 组件名规范 —> 大驼峰命名法, 如 AAAHeader 5. 语法:// 导入需要注册的组件// import 组件对象 from '.vue文件路径'import AAAHeader from './components/AAAHeader'export default {• // 局部注册components: {'组件名': 组件对象,AAAHeader:AAAHeader,AAAHeader}}
普通组件的注册使用 - 全局注册 1. 特点: 全局注册的组件,在项目的 任何组件 中都能使用 2. 步骤 1. 创建 .vue 组件(三个组成部分) 2. main.js 中进行全局注册 3. 使用方式 当成 HTML 标签直接使用 < 组件名 ></ 组件名 > 4. 注意 组件名规范 —> 大驼峰命名法, 如 AAAHeader 5. 语法 Vue.component(' 组件名 ', 组件对象 ) 8. 组件通信
1. 什么是组件通信? 组件通信,就是指 组件与组件 之间的 数据传递 组件的数据是独立的,无法直接访问其他组件的数据。 想使用其他组件的数据,就需要组件通信 2. 组件之间如何通信data:image/s3,"s3://crabby-images/e3d86/e3d8604e226fd795aa71bbb0717fbd4d04385652" alt=""
data:image/s3,"s3://crabby-images/2ba76/2ba76ae37f03ecadc1d1ae608df4fc646b540c7a" alt=""
data:image/s3,"s3://crabby-images/90ad4/90ad461462a4df1f438724de144549f8b9cba02e" alt=""
data:image/s3,"s3://crabby-images/bdeaa/bdeaae990d4b802b08943b52f2fc3a3384a12875" alt=""
9.路由介绍
9.1.思考
单页面应用程序,之所以开发效率高,性能好,用户体验好 最大的原因就是: 页面按需更新data:image/s3,"s3://crabby-images/830ae/830aec452aad9311e1a679855c04ee5a50c38328" alt=""
9.2 vue中如何使用路径
我们刚才演示了路由的基本使用。 --- 通过在地址栏输入路由地址,在根据路由配置找到对应的组 件,并渲染该组件。 ( 1 )第一种 : 声明式路径<router-link to="/login">登录</router-link>
( 2 )第二种 : 编码式路径 methods:{my(){//路由跳转---编码式路由this.$router.push("/register")}}
9.3. 路由传递
9.3.1 声明路由--查询参数
类似于之前 路由也是这种模式 对应的组件接受查询参数。 this.$route.query. 参数名9.3.2 声明路由--动态路由参数
2. 路由配置时 : { path="/ 路由路径 /: 参数名 "} 3. 相应的组件中接受参数值 this.$route.params. 参数名9.3.3 查询参数和动态路由参数
1. 查询参数传参 ( 比较适合传 多个参数 ) 1. 跳转: to="/path? 参数名 = 值 & 参数名 2= 值 " 2. 获取: this.$route.query. 参数名 2. 动态路由传参 ( 优雅简洁 ,传单个参数比较方便 ) 1. 配置动态路由: path: "/path/: 参数名 " 2. 跳转: to="/path/ 参数值 " 3. 获取: this.$route.params. 参数名 <router-link to="/login"> 登录 </router-link> 1 methods:{ my(){ // 路由跳转 --- 编码式路由 this.$router.push("/register") } } const originalPush = VueRouter.prototype.push // 修改原型对象中的 push 方法 VueRouter.prototype.push = function push(location) { return originalPush.call(this, location).catch(err => err) } 5 注意:动态路由也可以传多个参数,但一般只传一个 准备传递参数 --- 查询参数和动态路由参数9.3.4 编码路由--查询参数
my(){//路由跳转---编码式路由//简写版://this.$router.push("/my?name=ldh&age=18")//完整版this.$router.push({path: "/my",query:{name:"张嘉琪",age:88},})}
接受: created() {this.name=this.$route.query.name;this.age=this.$route.query.age;}
9.3.5 编码路由--动态路由参数
//动态路由参数--简介版// this.$router.push("/my/zcj")this.$router.push({// path:"/my", //表示路由的path的值name:"My", //表示路由的名称params:{key:"wzy"}})//path不能和params配合使用。 name可以和params配合使用
接受参数 //create()created() {this.name=this.$route.params.key;// this.name=this.$route.query.name;// this.age=this.$route.query.age;}
当出现NavigationDuplicated: Avoided redundant navigation to current location: "/register".问题时
解决方案 : /router/index.js 添加如下代码 Vue-Router3.0const originalPush = VueRouter.prototype.push//修改原型对象中的push方法VueRouter.prototype.push = function push(location) {return originalPush.call(this, location).catch(err => err)}