<template> <div> <MyHeader></MyHeader> <div> <h1>省份</h1> <button @click="forward()">前进</button> <button @click="back()">后退</button> <button @click="forwardTwo()">前进2步</button> <button @click="backTwo()">后退2步</button> <ul> <!-- 如果使用的是路由方式,就不能使用a标签超链接了 --> <!-- 需要使用vue-router提供的标签router-link --> <!-- <li><a href="/hebei">河北省</a></li> --> <!-- <li><a href="/henan" class="selected">河南省</a></li> --> <!-- router-link将来会被自动编译为a标签 --> <!-- active-class点中激活,点中的时候激活这个样式 --> <li><router-link to="/hebei" active-class="selected">河北省</router-link></li> <li><router-link to="/henan" active-class="selected">河南省</router-link></li> </ul> </div> <!-- 路由视图,起到一个占位的作用 --> <router-view></router-view> </div> </template> <script> import MyHeader from "./components/MyHeader"; export default { name : "App", components : {MyHeader}, methods : { forward(){ this.$router.forward(); }, back(){ this.$router.back(); }, forwardTwo(){ this.$router.go(2); }, backTwo(){ this.$router.go(-2); } } } </script> <style> .s1{ margin-left: 100px; } .s2{ margin-left: 100px; } .selected{ background-color: aqua; } </style>
<template>
<div>
<MyHeader></MyHeader>
<div>
<h1>省份</h1>
<button @click="forward()">前进</button>
<button @click="back()">后退</button>
<button @click="forwardTwo()">前进2步</button>
<button @click="backTwo()">后退2步</button>
<ul>
<!-- 如果使用的是路由方式,就不能使用a标签超链接了 -->
<!-- 需要使用vue-router提供的标签router-link -->
<!-- <li><a href="/hebei">河北省</a></li> -->
<!-- <li><a href="/henan" class="selected">河南省</a></li> -->
<!-- router-link将来会被自动编译为a标签 -->
<!-- active-class点中激活,点中的时候激活这个样式 -->
<li><router-link to="/hebei" active-class="selected">河北省</router-link></li>
<li><router-link to="/henan" active-class="selected">河南省</router-link></li>
</ul>
</div>
<!-- 路由视图,起到一个占位的作用 -->
<router-view></router-view>
</div>
</template>
<script>
import MyHeader from "./components/MyHeader";
export default {
name : "App",
components : {MyHeader},
methods : {
forward(){
this.$router.forward();
},
back(){
this.$router.back();
},
forwardTwo(){
this.$router.go(2);
},
backTwo(){
this.$router.go(-2);
}
}
}
</script>
<style>
.s1{
margin-left: 100px;
}
.s2{
margin-left: 100px;
}
.selected{
background-color: aqua;
}
</style>
// 导入vue-router对象 import VueRouter from "vue-router"; import Hebei from "../pages/hebei.vue"; import Henan from "../pages/henan.vue"; import City from "../pages/city.vue"; // 创建路由器对象(在这个路由器对象中配置路由) const router = new VueRouter({ // 在这里配置所有的路由规则 routes : [ // 这就是一个路由 { // 路由由path和component组成 // 这个看作key // 只要路径检测到的是/hebei就切换到这个组件 path : "/hebei", // 这个就是路由的value,路由的value是一个组件 component : Hebei, // children子路由 children : [ // 配置子路由 { // 对于子路由来说,path不用添加/,以/开始 // 系统会自动添加 // path : "/hebei/shijiazhuang", name : "shi", path : "sjz/:a1/:a2/:a3", // :形式可以将后续的内容视为数据 component : City, // 在路由中进行的配置 // props : { // x : 'Jack', // y : 'Rose' // } // props含有函数式写法 // props($route){ // // 当前路由对象会被自动传递过来 // // 将来取值时会自动调用函数 // // 调用这个函数对象会获取到当前路由对象 // return { // a1 : $route.params.a1, // a2 : $route.params.a2, // a3 : $route.params.a3 // } // // 需要在方法最后返回对象 // } // 这种方式只支持params方式的传参,不支持query方式 // 原理是将params直接内部转为props对象 props : true }, { // 可以给路由起名字,用来防止过长导致path写一大串 name : "han", // 数据是动态传过来的,我们只负责接收,所以两个子路由可以共享一个组件 path : "hd/:a1/:a2/:a3", component : City, // props($route){ // return { // a1 : $route.params.a1, // a2 : $route.params.a2, // a3 : $route.params.a3 // } // } props : true } ] }, { path : "/henan", component : Henan } ] }); // 导出路由器对象 export default router;
// 导入vue-router对象
import VueRouter from "vue-router";
import Hebei from "../pages/hebei.vue";
import Henan from "../pages/henan.vue";
import City from "../pages/city.vue";
// 创建路由器对象(在这个路由器对象中配置路由)
const router = new VueRouter({
// 在这里配置所有的路由规则
routes : [
// 这就是一个路由
{
// 路由由path和component组成
// 这个看作key
// 只要路径检测到的是/hebei就切换到这个组件
path : "/hebei",
// 这个就是路由的value,路由的value是一个组件
component : Hebei,
// children子路由
children : [
// 配置子路由
{
// 对于子路由来说,path不用添加/,以/开始
// 系统会自动添加
// path : "/hebei/shijiazhuang",
name : "shi",
path : "sjz/:a1/:a2/:a3",
// :形式可以将后续的内容视为数据
component : City,
// 在路由中进行的配置
// props : {
// x : 'Jack',
// y : 'Rose'
// }
// props含有函数式写法
// props($route){
// // 当前路由对象会被自动传递过来
// // 将来取值时会自动调用函数
// // 调用这个函数对象会获取到当前路由对象
// return {
// a1 : $route.params.a1,
// a2 : $route.params.a2,
// a3 : $route.params.a3
// }
// // 需要在方法最后返回对象
// }
// 这种方式只支持params方式的传参,不支持query方式
// 原理是将params直接内部转为props对象
props : true
},
{
// 可以给路由起名字,用来防止过长导致path写一大串
name : "han",
// 数据是动态传过来的,我们只负责接收,所以两个子路由可以共享一个组件
path : "hd/:a1/:a2/:a3",
component : City,
// props($route){
// return {
// a1 : $route.params.a1,
// a2 : $route.params.a2,
// a3 : $route.params.a3
// }
// }
props : true
}
]
},
{
path : "/henan",
component : Henan
}
]
});
// 导出路由器对象
export default router;
<template> <div> <!-- 组件分为普通组件和路由组件 --> <div class="s2"> <h2>县区</h2> <ul> <!-- query形式接收 --> <!-- <li>{{ $route.query.a1 }}</li> <li>{{ $route.query.a2 }}</li> <li>{{ $route.query.a3 }}</li> --> <!-- params形式接收 --> <li>{{ a1 }}</li> <li>{{ a2 }}</li> <li>{{ a3 }}</li> <!-- 遍历query的方式 --> <!-- <li v-for="propertyValue,propertyName in $route.query" :key="propertyName">{{ propertyValue }}</li> --> <!-- 遍历params的方式 --> <!-- <li v-for="propertyValue,propertyName in $route.params" :key="propertyName">{{ propertyValue }}</li> --> </ul> </div> </div> </template> <script> export default { name : "City", // 因为我们的组件是通过路由唤醒的,因此路由会把这个配置props传递过来 // 我们就可以在这里拿到props props : ['a1','a2','a3'], mounted(){ // 所有的路由组件都有一个$route,通过这个属性可以获取到路由组件关联的路由对象 console.log(this.$route); // 路由对象中有一个query属性,通过这个query属性可以接收到query方式传过来的数据 console.log(this.$route.query); // 接收的params数据 console.log(this.$route.params); }, // 使用计算属性的方式 computed : { params(){ return this.$route.params; } } } </script> <style> </style>
<template>
<div>
<!-- 组件分为普通组件和路由组件 -->
<div class="s2">
<h2>县区</h2>
<ul>
<!-- query形式接收 -->
<!-- <li>{{ $route.query.a1 }}</li>
<li>{{ $route.query.a2 }}</li>
<li>{{ $route.query.a3 }}</li> -->
<!-- params形式接收 -->
<li>{{ a1 }}</li>
<li>{{ a2 }}</li>
<li>{{ a3 }}</li>
<!-- 遍历query的方式 -->
<!-- <li v-for="propertyValue,propertyName in $route.query" :key="propertyName">{{ propertyValue }}</li> -->
<!-- 遍历params的方式 -->
<!-- <li v-for="propertyValue,propertyName in $route.params" :key="propertyName">{{ propertyValue }}</li> -->
</ul>
</div>
</div>
</template>
<script>
export default {
name : "City",
// 因为我们的组件是通过路由唤醒的,因此路由会把这个配置props传递过来
// 我们就可以在这里拿到props
props : ['a1','a2','a3'],
mounted(){
// 所有的路由组件都有一个$route,通过这个属性可以获取到路由组件关联的路由对象
console.log(this.$route);
// 路由对象中有一个query属性,通过这个query属性可以接收到query方式传过来的数据
console.log(this.$route.query);
// 接收的params数据
console.log(this.$route.params);
},
// 使用计算属性的方式
computed : {
params(){
return this.$route.params;
}
}
}
</script>
<style>
</style>
<template> <div> <!-- 组件分为普通组件和路由组件 --> <div class="s1"> <!-- 栈数据结构 --> <!-- stack栈一种数据结构,当我们的元素进入称为入栈,或压栈push --> <!-- 进入的第一个元素在栈底部的我们称之为栈底元素 --> <!-- 默认情况下,栈当中是一个指针的,这个指针在默认情况下指向栈顶元素 --> <!-- 每次有新的元素入栈后,栈的指针都会自动向上移动指向栈顶的那个元素 --> <!-- 栈顶元素先出栈,出栈,弹栈pop --> <!-- 栈数据结构特点,遵循先进后出,后进先出原则 --> <h2>市区</h2> <ul> <li>洛阳</li> <li>开封</li> <li>安阳</li> <li>郑州</li> </ul> <!-- 浏览器的历史记录就是存在栈这种数据结构里面的 --> <!-- 历史记录存放到栈有两种不同的模式 --> <!-- 第一种,push模式 --> <!-- 以追加的方式入栈 --> <!-- 第二种,replace模式 --> <!-- 以替换栈顶元素的方式入栈 --> <!-- 浏览器默认的模式是push模式 --> <!-- 操作浏览器上的前进后退并不会删除栈当中的历史记录,只是向前和向后移动指针 --> <!-- 只是移动了指针指向的元素 --> <!-- 栈内的元素没有发生变化,变化的只有指针位置 --> </div> <router-view></router-view> </div> </template> <script> export default { name : "Henan" } </script> <style> </style>
<template>
<div>
<!-- 组件分为普通组件和路由组件 -->
<div class="s1">
<!-- 栈数据结构 -->
<!-- stack栈一种数据结构,当我们的元素进入称为入栈,或压栈push -->
<!-- 进入的第一个元素在栈底部的我们称之为栈底元素 -->
<!-- 默认情况下,栈当中是一个指针的,这个指针在默认情况下指向栈顶元素 -->
<!-- 每次有新的元素入栈后,栈的指针都会自动向上移动指向栈顶的那个元素 -->
<!-- 栈顶元素先出栈,出栈,弹栈pop -->
<!-- 栈数据结构特点,遵循先进后出,后进先出原则 -->
<h2>市区</h2>
<ul>
<li>洛阳</li>
<li>开封</li>
<li>安阳</li>
<li>郑州</li>
</ul>
<!-- 浏览器的历史记录就是存在栈这种数据结构里面的 -->
<!-- 历史记录存放到栈有两种不同的模式 -->
<!-- 第一种,push模式 -->
<!-- 以追加的方式入栈 -->
<!-- 第二种,replace模式 -->
<!-- 以替换栈顶元素的方式入栈 -->
<!-- 浏览器默认的模式是push模式 -->
<!-- 操作浏览器上的前进后退并不会删除栈当中的历史记录,只是向前和向后移动指针 -->
<!-- 只是移动了指针指向的元素 -->
<!-- 栈内的元素没有发生变化,变化的只有指针位置 -->
</div>
<router-view></router-view>
</div>
</template>
<script>
export default {
name : "Henan"
}
</script>
<style>
</style>
<template> <div> <!-- 组件分为普通组件和路由组件 --> <div class="s1"> <!-- router-link被称为声明式的路由导航,只适合超链接一种形式 --> <h2>市区</h2> <ul> <!-- 写死信息方式传递 --> <!-- <li><router-link to="/hebei/city?a1=新华区&a2=裕华区&a3=长安区" active-class="selected">石家庄</router-link></li> <li><router-link to="/hebei/city?a1=邯山区&a2=丛台区&a3=复兴区" active-class="selected">邯郸</router-link></li> --> <!-- 动态拼接字符串形式传递 --> <!-- <li><router-link :to="`/hebei/city?a1=${sjz[0]}&a2=${sjz[1]}&a3=${sjz[2]}`" active-class="selected">石家庄</router-link></li> <li><router-link :to="`/hebei/city?a1=${hd[0]}&a2=${hd[1]}&a3=${hd[2]}`" active-class="selected">邯郸</router-link></li> --> <!-- <li> // 对象形式传参实现 <router-link active-class="selected" :to="{ // name的形式不支持字符串拼接,只支持对象形式 // 因为子组件有了名字,就可以写名字而不是path地址嵌套了 name : 'shi', // path : '/hebei/sjz', query : { a1 : sjz[0], a2 : sjz[1], a3 : sjz[2] } }">石家庄 </router-link> </li> --> <!-- 写死的形式 --> <!-- <li> <router-link active-class="selected" to="/hebei/sjz/裕华区/新华区/长安区"> 石家庄 </router-link> </li> --> <!-- 拼接的形式 --> <!-- <li> <router-link active-class="selected" :to="`/hebei/sjz/${sjz[0]}/${sjz[1]}/${sjz[2]}`"> 石家庄 </router-link> </li> --> <!-- 对象形式params传参 --> <li> <!-- 当我们在router-link中设置replace=true的时候,就可以开启replace模式 --> <!-- 实际上是push加replace模式 --> <!-- 这个带有replace标签的route-link会替代栈顶部的标签元素 --> <router-link :replace="true" active-class="selected" :to="{ // params形式传参,不能有path // 这里只能使用name // path : '/hebei/sjz', name : 'shi', params : { a1 : sjz[0], a2 : sjz[1], a3 : sjz[2] } }"> 石家庄 </router-link> <button @click="goSjz()">石家庄</button> </li> <!-- <li> <router-link active-class="selected" :to="{ // 全都用名字来代替 name : 'han', // path : '/hebei/hd', query : { a1 : hd[0], a2 : hd[1], a3 : hd[2] } }">邯郸 </router-link> </li> --> <!-- 字符串拼接形式 --> <!-- <li> <router-link active-class="selected" to="/hebei/hd/邯山区/丛台区/复兴区">邯郸 </router-link> </li> --> <!-- params字符串拼接方式实现 --> <!-- <li> <router-link active-class="selected" :to="`/hebei/hd/${hd[0]}/${hd[1]}/${hd[2]}`">邯郸 </router-link> </li> --> <!-- params对象形式实现 --> <li> <router-link replace active-class="selected" :to="{ name : 'han', params : { a1 : hd[0], a2 : hd[1], a3 : hd[2] } }">邯郸 </router-link> <button @click="goHD()">邯郸</button> </li> <li>保定</li> <li>唐山</li> </ul> </div> <!-- 区组件 --> <router-view></router-view> </div> </template> <script> export default { name : "Hebei", data(){ return { sjz : ["新华区","裕华区","长安区"], hd : ["邯山区","丛台区","复兴区"] } }, methods : { goSjz(){ // 在这里编写代码完成组件的切换 // 这种通过编程的方式完成组件切换被称为:编程式路由导航 // 调用现有的api就可以完成路由组件的切换 // 首先我们需要获取路由器对象,不是路由对象this.$route是路由对象 // this.$router这样就可以获取到共享的路由器对象,一般一个项目只有一个 this.$router.push({ // params形式传参,不能有path // 这里只能使用name // path : '/hebei/sjz', name : 'shi', params : { a1 : this.sjz[0], a2 : this.sjz[1], a3 : this.sjz[2] } // 正常来说需要编写这两个函数,一个是成功一个是失败 },() => {},() => {}); }, goHD(){ // 这个为replace模式 // 同级的我们考虑使用replace切换 this.$router.replace({ name : 'han', // 在我们使用编程式的路由导航的时候 // push或者promise会返回一个Promise对象 // Promise对象期望你能通过参数的方式给它两个回调函数,一个是成功的回调函数 // 一个是失败的回调函数 // 如果没有给出这两个回调函数,则会爆出这个错误 // 在参数上给出两个回调函数即可 params : { a1 : this.hd[0], a2 : this.hd[1], a3 : this.hd[2] } },() => {},() => {}); } } } </script> <style> </style>
<template>
<div>
<!-- 组件分为普通组件和路由组件 -->
<div class="s1">
<!-- router-link被称为声明式的路由导航,只适合超链接一种形式 -->
<h2>市区</h2>
<ul>
<!-- 写死信息方式传递 -->
<!-- <li><router-link to="/hebei/city?a1=新华区&a2=裕华区&a3=长安区" active-class="selected">石家庄</router-link></li>
<li><router-link to="/hebei/city?a1=邯山区&a2=丛台区&a3=复兴区" active-class="selected">邯郸</router-link></li> -->
<!-- 动态拼接字符串形式传递 -->
<!-- <li><router-link :to="`/hebei/city?a1=${sjz[0]}&a2=${sjz[1]}&a3=${sjz[2]}`" active-class="selected">石家庄</router-link></li>
<li><router-link :to="`/hebei/city?a1=${hd[0]}&a2=${hd[1]}&a3=${hd[2]}`" active-class="selected">邯郸</router-link></li> -->
<!-- <li>
// 对象形式传参实现
<router-link active-class="selected" :to="{
// name的形式不支持字符串拼接,只支持对象形式
// 因为子组件有了名字,就可以写名字而不是path地址嵌套了
name : 'shi',
// path : '/hebei/sjz',
query : {
a1 : sjz[0],
a2 : sjz[1],
a3 : sjz[2]
}
}">石家庄
</router-link>
</li> -->
<!-- 写死的形式 -->
<!-- <li>
<router-link active-class="selected" to="/hebei/sjz/裕华区/新华区/长安区">
石家庄
</router-link>
</li> -->
<!-- 拼接的形式 -->
<!-- <li>
<router-link active-class="selected" :to="`/hebei/sjz/${sjz[0]}/${sjz[1]}/${sjz[2]}`">
石家庄
</router-link>
</li> -->
<!-- 对象形式params传参 -->
<li>
<!-- 当我们在router-link中设置replace=true的时候,就可以开启replace模式 -->
<!-- 实际上是push加replace模式 -->
<!-- 这个带有replace标签的route-link会替代栈顶部的标签元素 -->
<router-link :replace="true" active-class="selected" :to="{
// params形式传参,不能有path
// 这里只能使用name
// path : '/hebei/sjz',
name : 'shi',
params : {
a1 : sjz[0],
a2 : sjz[1],
a3 : sjz[2]
}
}">
石家庄
</router-link>
<button @click="goSjz()">石家庄</button>
</li>
<!-- <li>
<router-link active-class="selected" :to="{
// 全都用名字来代替
name : 'han',
// path : '/hebei/hd',
query : {
a1 : hd[0],
a2 : hd[1],
a3 : hd[2]
}
}">邯郸
</router-link>
</li> -->
<!-- 字符串拼接形式 -->
<!-- <li>
<router-link active-class="selected" to="/hebei/hd/邯山区/丛台区/复兴区">邯郸
</router-link>
</li> -->
<!-- params字符串拼接方式实现 -->
<!-- <li>
<router-link active-class="selected" :to="`/hebei/hd/${hd[0]}/${hd[1]}/${hd[2]}`">邯郸
</router-link>
</li> -->
<!-- params对象形式实现 -->
<li>
<router-link replace active-class="selected" :to="{
name : 'han',
params : {
a1 : hd[0],
a2 : hd[1],
a3 : hd[2]
}
}">邯郸
</router-link>
<button @click="goHD()">邯郸</button>
</li>
<li>保定</li>
<li>唐山</li>
</ul>
</div>
<!-- 区组件 -->
<router-view></router-view>
</div>
</template>
<script>
export default {
name : "Hebei",
data(){
return {
sjz : ["新华区","裕华区","长安区"],
hd : ["邯山区","丛台区","复兴区"]
}
},
methods : {
goSjz(){
// 在这里编写代码完成组件的切换
// 这种通过编程的方式完成组件切换被称为:编程式路由导航
// 调用现有的api就可以完成路由组件的切换
// 首先我们需要获取路由器对象,不是路由对象this.$route是路由对象
// this.$router这样就可以获取到共享的路由器对象,一般一个项目只有一个
this.$router.push({
// params形式传参,不能有path
// 这里只能使用name
// path : '/hebei/sjz',
name : 'shi',
params : {
a1 : this.sjz[0],
a2 : this.sjz[1],
a3 : this.sjz[2]
}
// 正常来说需要编写这两个函数,一个是成功一个是失败
},() => {},() => {});
},
goHD(){
// 这个为replace模式
// 同级的我们考虑使用replace切换
this.$router.replace({
name : 'han',
// 在我们使用编程式的路由导航的时候
// push或者promise会返回一个Promise对象
// Promise对象期望你能通过参数的方式给它两个回调函数,一个是成功的回调函数
// 一个是失败的回调函数
// 如果没有给出这两个回调函数,则会爆出这个错误
// 在参数上给出两个回调函数即可
params : {
a1 : this.hd[0],
a2 : this.hd[1],
a3 : this.hd[2]
}
},() => {},() => {});
}
}
}
</script>
<style>
</style>