Vue router-view和router-link的實現原理
更新時間:2021年03月09日 09:24:24 作者:mengyuhang4879
這篇文章主要介紹了Vue router-view和router-link的實現原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
使用
<div id="app"> <router-link to='home'>首頁</router-link> <router-link to='about'>關于</router-link> <router-view a=1><router-view/> </div>
router-view組件
export default {
//函數式組件沒有this 不能new 沒有雙向數據綁定,通常用的比較少,比較適用于展示詳情頁因為詳情頁只展示不進行修改等操作,函數式組件比有狀態(tài)的組件更加輕量級。
functional:true,
render(h,{parent,data}){
parent表示的父組件 app
data 是行間屬性(上面代碼a=1) 也可以使用prop傳遞
let route = parent.$route;
let depth = 0;
data.routerView = true;
while(parent){
//$vnode指的是虛擬dom 如果app上有虛擬dom并且這個虛擬dom上的routerView為true
if (parent.$vnode && parent.$vnode.data.routerView){
depth++;
}
parent = parent.$parent;
}
let record = route.matched[depth];
if(!record){
return h();
}
return h(record.component, data);
}
}
router-link的實現
export default {
props:{
to:{
type:String,
required:true
},
tag:{
type:String
}
},
render(h){
let tag = this.tag || 'a';
let handler = ()=>{
this.$router.push(this.to);
}
return <tag onClick={handler}>{this.$slots.default}</tag>
}
}
到此這篇關于Vue router-view和router-link的實現原理的文章就介紹到這了,更多相關Vue router-view和router-link內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue封裝一個TodoList的案例與瀏覽器本地緩存的應用實現
這篇文章主要介紹了Vue封裝一個TodoList的案例與瀏覽器本地緩存的應用實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04

