欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue組件與復用詳解

 更新時間:2018年04月08日 14:25:34   作者:柴小智  
組件 (Component) 是 Vue.js 最強大的功能之一。組件可以擴展 HTML 元素,封裝可重用的代碼。這篇文章主要介紹了vue組件與復用,需要的朋友可以參考下

一、什么是組件

組件 (Component) 是 Vue.js 最強大的功能之一。組件可以擴展 HTML 元素,封裝可重用的代碼。

二、組件用法

組件需要注冊后才可以使用,注冊有全局注冊和局部注冊兩種方式。

2.1 全局注冊后,任何V ue 實例都可以使用。如:      

 <div id="app1">
      <my-component></my-component>
    </div>
Vue.component('my-component',{
  template: '<div>這里是組件的內容</div>'
});
var app1 = new Vue({
  el: '#app1'
});

 要在父實例中使用這個組件,必須要在實例創(chuàng)建前注冊,之后就可以用<my-component></my- component> 的形式來使用組件了

template的DOM結構必須被一個元素包含, 如果直接寫成“這里是組件的內容”, 不帶“<div></ div >”是無法渲染的。(而且最外層只能有一個根的<div>標簽)

2.2 在Vue 實例中,使用component選項可以局部注冊組件,注冊后的組件只有在該實例作用域下有效。如:

    <div id="app2">
      <my-component1></my-component1>
    </div>
var app2 = new Vue({
  el: '#app2',
  components:{
   'my-component1': {
     template: '<div>這里是局部注冊組件的內容</div>'
   }
  }
}); 

2.3 data必須是函數

除了template選項外,組件中還可以像Vue實例那樣使用其他的選項,比如data 、computed 、methods等。但是在使用data時,和實例稍有區(qū)別, data 必須是函數,然后將數據return 出去。

    <div id="app3">
      <my-component3></my-component3>
    </div>
Vue.component('my-component3',{
  template: '<div>{{message}}</div>',
  data: function(){
    return {
      message: '組件內容'
    }
  }
});
var app3 = new Vue({
  el: '#app3'
});

 一般return的對象不要引用外部的對象,因為如果return 出的對象引用了外部的一個對象, 那這個對象就是共享的, 任何一方修改都會同步。

所以一般給組件返回一個新的獨立的data對象。

補充:vue-router 組件復用問題

組件系統(tǒng)是Vue的一個重要組成部分,它可以將一個復雜的頁面抽象分解成許多小型、獨立、可復用的組件,通過組合組件來組成應用程序,結合vue-router的路由功能將各個組件映射到相應的路由上,通過路由的變化來告訴Vue要在哪里渲染他們,實現各個組件、各個頁面之間的跳轉導航。

問題

使用vue-router切換路由時會觸發(fā)組件樹的更新,根據定義的路由渲染一個新的組件樹,大致的切換過程是這樣的:

- 停用并移除不需要的組件
- 驗證切換的可行性
- 復用沒有進行更新的組件
- 啟用并激活新的組件

具體路由切換控制流程請參考官方文檔:切換控制流水線

那vue-router是怎么判斷某一個組件可以復用的呢? 我們看一下下面這條路由配置:

{
  path: 'post/:postId',
  name: 'post',
  component: resolve => require(['./components/Post.vue'],resolve)
}

這是通過文章ID加載對應文章頁面的路由,第一次訪問時,Post.vue這個組件會被渲染到組件樹中,mounted安裝組件時通過文章ID獲取文章內容展示到頁面上,當我們訪問另一篇文章時,路由參數:postId發(fā)生改變,按照我們的預期應該會展示新文章的內容,但是事與愿違。

我們看到的還是之前的文章,雖然路由參數已發(fā)生更改,但是vue-router會以為你訪問的是Post.vue這個組件,由于之前已經渲染過該組件,所以會直接復用之前的組件,并且不會執(zhí)行組件中的任何操作包括mounted之類的生命周期函數。

所以我們最終看到的還是原來組件的內容。

那要怎么才能實現我們期望的效果呢?下面介紹一種有效的解決方法

解決方法

我們可以使用watch偵聽器來監(jiān)聽路由的變化情況,根據路由參數的變化來響應相應的數據,具體實現過程是這樣的:

定義數據獲取方法

首先定義一個獲取文章的方法,根據文章ID從后臺獲取對應的文章信息。

methods: {
  getPost(postId) {
    this.$http.get(`/post/get_post/${postId}`).then((response) => {
      if(response.data.code === 0){
        this.post = response.data.post;
      }
    });
  }
}

監(jiān)聽路由

接著是在路由切換的時候判斷目標組件是否是Post.vue組件,這里可以根據定義的路由名稱name實現,如果是,我們就可以從路由信息中獲取目標文章ID來更新組件內容。

watch: {
  '$route' (to, from) {
    if(to.name === 'post'){
      this.getPost(to.params.postId);
    }
  }
}

組件初始化

這里需要注意的是,當組件首次被掛載到組件樹上時,對路由的監(jiān)聽是無效的,這時我們需要在生命周期鉤子mounted對組件進行初始化工作:

mounted() {
  this.getPost(this.$route.params.postId);
}

寫在最后

通過上面的方法就可以實現組件內容隨路由參數的變化而更新了,有效解決了vue-router組件復用導致路由參數失效的問題。

總結

以上所述是小編給大家介紹的vue組件與復用詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • UniApp中實現類似錨點定位滾動效果

    UniApp中實現類似錨點定位滾動效果

    一個uniapp小程序的項目,我們需要實現一個非常實用的功能——類似于錨點定位的交互效果,即在首頁中有多個tab(分類標簽),每個tab對應著不同的模塊,當用戶點擊某個分類的tab時,需要流暢地滾動到對應的內容位置,提供更好的用戶體驗,
    2023-10-10
  • Vue2.x中的父子組件相互通信的實現方法

    Vue2.x中的父子組件相互通信的實現方法

    這篇文章主要介紹了Vue2.x中的父子組件相互通信,需要的朋友可以參考下
    2017-05-05
  • vue項目中路徑使用@和~的區(qū)別及說明

    vue項目中路徑使用@和~的區(qū)別及說明

    這篇文章主要介紹了vue項目中路徑使用@和~的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • ant-design-vue動態(tài)表格合并案例

    ant-design-vue動態(tài)表格合并案例

    這篇文章主要介紹了ant-design-vue動態(tài)表格合并案例,文章圍繞主題通過案例詳解展開相關內容,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • 在Vue 中使用Typescript的示例代碼

    在Vue 中使用Typescript的示例代碼

    這篇文章主要介紹了在Vue 中使用Typescript的示例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • vue使用csp的簡單示例

    vue使用csp的簡單示例

    Vue是一套用于構建用戶界面的漸進式框架,與其它大型框架不同的是,Vue被設計為可以自底向上逐層應用,下面這篇文章主要給大家介紹了關于vue使用csp的相關資料,需要的朋友可以參考下
    2022-08-08
  • Vue分頁組件的封裝方法

    Vue分頁組件的封裝方法

    這篇文章主要為大家詳細介紹了Vue分頁組件的封裝方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue中$set()的使用方法場景分析

    Vue中$set()的使用方法場景分析

    由于 Vue 會在初始化實例時進行雙向數據綁定,使用Object.defineProperty()對屬性遍歷添加 getter/setter 方法,所以屬性必須在 data 對象上存在時才能進行上述過程 ,這樣才能讓它是響應的,這篇文章主要介紹了Vue中$set()的使用方法場景分析,需要的朋友可以參考下
    2023-02-02
  • Vue3中各種靈活傳遞數據的方式小結

    Vue3中各種靈活傳遞數據的方式小結

    Vue 3 提供了多種數據傳遞的方式,讓我們的組件之間可以盡情地交流,接下來,我們就直接一個個來看,這些方式都是怎么工作的,感興趣的小伙伴跟著小編一起來看看吧
    2024-07-07
  • vue中v-model對select的綁定操作

    vue中v-model對select的綁定操作

    這篇文章主要介紹了vue中v-model對select的綁定操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08

最新評論