이 글에서는 주로 컴포넌트 간의 점프와 매개변수 전송 방법을 자세히 소개합니다. 관심 있는 친구들이 참고하면 도움이 될 것입니다.
VueRouter를 사용하여 구성요소 간 점프 구현: 매개변수 전송, 구체적인 내용은 다음과 같습니다
login ---사용자 이름--->main
①송신자와 수신자를 삭제합니다
②수신자 구성 라우팅 주소
{ path:'/myTest',comComponent:TestComponent}
-->
{path:'/myTest/:id',comComponent:TestComponent}
③수신자는 전달된 데이터를 가져옵니다
this .$route.params.id
4점프할 때 매개변수 전송
this.$router.push('/myTest/20')
19d3af23565312fe4d07b10b3f01a61cJumpd625018d6d57dc2163f3a71531b24864
코드:
<!doctype html> <html> <head> <meta charset="UTF-8"> <title>传参</title> <script src="js/vue.js"></script> <script src="js/vue-router.js"></script> </head> <body> <p id="container"> <p>{{msg}}</p> <!--指定容器 --> <router-view></router-view> </p> <script> //创建主页面组件 var myMain = Vue.component("main-component",{ //保存登录传递过来的数据 data:function(){ return { uName:'' } }, template:` <p> <h1>主页面用户名:{{uName}}</h1> </p> `, //挂载该组件时自动拿到数据 beforeMount:function(){ //接收参数 console.log(this.$route.params); this.uName = this.$route.params.myName ; } }) //创建登录页面组件 var myLogin = Vue.component("login-component",{ //保存用户输入的数据 data:function(){ return { userInput:"" } }, methods:{ toMain:function(){ //跳转到主页面,并将用户输入的名字发送过去 this.$router.push("/main/"+this.userInput); console.log(this.userInput); } }, template:` <p> <h1>登录页面</h1> <input type="text" v-model="userInput" placeholder="请输入用户名"> <button @click="toMain">登录到主页面</button> <br> <router-link :to="'/main/'+userInput">登录到主页面</router-link> </p> ` }) var NotFound = Vue.component("not-found",{ template:` <p> <h1>404 Page Not Found</h1> <router-link to="/login">返回登录页</router-link> </p> ` }) //配置路由词典 const myRoutes = [ {path:"",component:myLogin}, {path:"/login",component:myLogin}, //注意冒号,不用/否则会当成地址 {path:"/main/:myName",component:myMain}, //没有匹配到任何页面则跳转到notfound页面 {path:"*",component:NotFound} ] const myRouter = new VueRouter({ routes:myRoutes }) new Vue({ router:myRouter, el:"#container", data:{ msg:"Hello VueJs" } }) // 注意,路由地址 </script> </body> </html>
<!doctype html> <html> <head> <meta charset="UTF-8"> <title>传参练习</title> <script src="js/vue.js"></script> <script src="js/vue-router.js"></script> </head> <body> <p id="container"> <p>{{msg}}</p> <!-- --> <router-view></router-view> </p> <script> //创建产品列表组件 var myList = Vue.component("product-list",{ //保存产品列表的数据 data:function(){ return{ productList:["苹果","华为","三星","小米","vivo"] } }, template:` <p> <h4>这是列表页</h4> <ul> <li v-for="(tmp,index) in productList"> //将index传递过去 <router-link v-bind:to="'/detail/'+index">{{tmp}}</router-link> </li> </ul> </p> ` }) //详情页组件 var myDetail = Vue.component("product-detail",{ //保存传递过来的index data:function(){ return{ myIndex:"" } }, //在挂载完成后,将接收到的index赋值给myIndex mounted:function(){ this.myIndex = this.$route.params.id; }, template:` <p> <h4>这是详情页</h4> <p>这是id为:{{myIndex}}的产品</p> </p> ` }) //页面找不到的时候 var NotFound = Vue.component("not-found",{ template:` <p> <h1>404 Page Not Found</h1> </p> ` }) // 配置路由词典 const myRoutes = [ {path:"",component:myList}, {path:"/list",component:myList}, {path:"/detail/:id",component:myDetail}, {path:"*",component:NotFound}, ] const myRouter = new VueRouter({ routes:myRoutes }) new Vue({ router:myRouter, el:"#container", data:{ msg:"Hello VueJs" } }) </script> </body> </html>
vue.js 학습 튜토리얼을 보려면 특별한 vue.js 구성 요소 학습 튜토리얼, Vue.js 프론트 엔드 구성 요소를 클릭하여 학습하세요.
관련 권장사항:
컴포넌트 간 점프를 위한 세 가지 Vue-Router 방법
vue-router 라우팅 및 페이지 간 탐색에 대한 자세한 설명
vue-router 라우팅 매개변수 새로 고침 문제에 대한 자세한 솔루션 그리고 실종
위 내용은 컴포넌트 간 점프 매개변수 전송을 구현하는 vue-router 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!