1、应用场景
在同一路由的情况下,不同的参数之间进行切换
注意:别忘记初始化路由页面
2、用法
a、定义方法
b、实现方法
c、初始化路由页面
3、案例
<template> <div> <div> <p>{{details.courses}}</p> <p>{{details.img}}</p> <p>{{details.level}}</p> <p>{{details.slogan}}</p> <p>{{details.title}}</p> <p>{{details.why}}</p> <div> <ul v-for="item in details.chapter"> <li>{{item.name}}</li> </ul> </div> <h4>推荐课程</h4> <div> <ul v-for="item in details.recommend_courses"> <li @click="changeDetail(item.id)">{{item.title}}</li> </ul> </div> </div> </div> </template> <script> export default { name: "Detail", data(){ return { msg: "细节", details: { chapter: [], courses: null, id: null, img: null, recommend_courses: [], slogan: "", title: "", why: "" } , } }, mounted() { // console.log(this.$route.params.id); let id = this.$route.params.id; this.initDetail(id); }, methods:{ // 初始化detail路由页面 initDetail(id){ // console.log(id); let that = this; let url = `http://127.0.0.1:8000/api/v1/course/${id}/`; console.log(url); this.$axios.get(url) .then(function (response) { console.log(response.data); if (response.data.code === 1000){ that.details = response.data.data; } }) .catch(function (error) { console.log(error); }); }, changeDetail(id){ // 导航式路由 this.$router.push({name: 'detail', params: {id: id}}); // 初始detail路由页面 this.initDetail(id); } }, } </script> <style scoped> </style>