這次帶給大家vue組件與復用使用詳解,vue組件與復用使用的注意事項有哪些,下面就是實戰案例,一起來看一下。
一、什麼是元件
元件 (Component) 是 Vue.js 最強大的功能之一。元件可以擴充 HTML 元素,封裝可重複使用的程式碼。
二、元件用法
元件在註冊後才可以使用,註冊有全域註冊和局部註冊兩種方式。
2.1 全域註冊後,任何V ue 實例都可以使用。如:
<p> <my-component></my-component> </p> Vue.component('my-component',{ template: '<p>这里是组件的内容</p>' }); var app1 = new Vue({ el: '#app1' });
要在父親實例中使用這個元件,必須在實例建立前註冊,之後就可以用<my-component>component> 的形式來使用元件了
template的DOM結構必須被一個元素包含, 如果直接寫成“這裡是組件的內容”, 不含“
p >”是無法渲染的。 (而且最外層只能有一個根的
標籤)
2.2 在Vue 實例中,使用component選項可以局部註冊元件,註冊後的元件只有在這個實例作用域下才有效。如:
<p> <my-component1></my-component1> </p> var app2 = new Vue({ el: '#app2', components:{ 'my-component1': { template: '<p>这里是局部注册组件的内容</p>' } } });
2.3 data必須是函數
除了template選項外,元件中還可以像Vue實例一樣使用其他的選項,例如data 、computed 、methods等。但是使用data時,和實例稍有區別, data 必須是函數,然後將資料return 出去。
<p> <my-component3></my-component3> </p> Vue.component('my-component3',{ template: '<p>{{message}}</p>', data: function(){ return { message: '组件内容' } } }); var app3 = new Vue({ el: '#app3' });
一般return的對像不要引用外部的對象,因為如果return 出的對象引用了外部的一個對象, 那這個對象就是共享的, 任何一方修改都會同步。
所以一般會給元件傳回一個新的獨立的data物件。
補充:vue-router 元件重複使用問題
#元件系統是Vue的重要組成部分,它可以將一個複雜的頁面抽象分解成許多小型、獨立、可重複使用的元件,透過組合元件來組成應用程序,結合vue-router的路由功能將各個元件對應到對應的路由上,透過路由的變化來告訴Vue要在哪裡渲染他們,實現各個元件、各個頁面之間的跳躍導航。
問題
使用vue-router切換路由時會觸發元件樹的更新,根據定義的路由渲染一個新的元件樹,大致的切換過程是這樣的:
- 停用並移除不需要的元件
- 驗證切換的可行性
- 復用沒有進行更新的元件
- 啟用並啟動新的元件
具體路由切換控制流程請參考官方文件:切換控制管線
那vue-router是怎麼判斷某一個元件可以重複使用的呢?我們來看看下面這條路由設定:
{ path: 'post/:postId', name: 'post', component: resolve => require(['./components/Post.vue'],resolve) }
這是透過文章ID載入對應文章頁面的路由,第一次造訪時,Post.vue這個元件會被渲染到元件樹中,mounted安裝元件時透過文章ID取得文章內容展示到頁面上,當我們訪問另一篇文章時,路由參數:postId發生改變,按照我們的預期應該會展示新文章的內容,但是事與願違。
我們看到的還是之前的文章,雖然路由參數已發生更改,但是vue-router會以為你訪問的是Post.vue這個組件,由於之前已經渲染過該組件,所以會直接復用之前的元件,並且不會執行元件中的任何操作包括mounted之類的生命週期函數。
所以我們最後看到的還是原來元件的內容。
那要怎麼才能實現我們期望的效果呢?以下介紹一個有效的解決方法
解決方法
#我們可以使用watch偵聽器來監聽路由的變化情況,根據路由參數的變化來回應對應的數據,具體實作過程是這樣的:
定義資料擷取方法
首先定义一个获取文章的方法,根据文章ID从后台获取对应的文章信息。
methods: { getPost(postId) { this.$http.get(`/post/get_post/${postId}`).then((response) => { if(response.data.code === 0){ this.post = response.data.post; } }); } }
监听路由
接着是在路由切换的时候判断目标组件是否是Post.vue组件,这里可以根据定义的路由名称name实现,如果是,我们就可以从路由信息中获取目标文章ID来更新组件内容。
watch: { '$route' (to, from) { if(to.name === 'post'){ this.getPost(to.params.postId); } } }
组件初始化
这里需要注意的是,当组件首次被挂载到组件树上时,对路由的监听是无效的,这时我们需要在生命周期钩子mounted对组件进行初始化工作:
mounted() { this.getPost(this.$route.params.postId); }
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上是vue組件與復用使用詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

C++中的众数函数详解在统计学中,众数指的是一组数据中出现次数最多的数值。在C++语言中,我们可以通过编写一个众数函数来找到任意一组数据中的众数。众数函数的实现可以采用多种不同的方法,下面将详细介绍其中两种常用的方法。第一种方法是使用哈希表来统计每个数字出现的次数。首先,我们需要定义一个哈希表,将每个数字作为键,出现次数作为值。然后,对于给定的数据集,我们遍

C++中的取余函数详解在C++中,取余运算符(%)用于计算两个数相除的余数。它是一种二元运算符,其操作数可以是任何整数类型(包括char、short、int、long等),也可以是浮点数类型(如float、double)。取余运算符返回的结果与被除数的符号相同。例如,对于整数的取余运算,我们可以使用以下代码来实现:inta=10;intb=3;

Vue.nextTick函数用法详解及在异步更新中的应用在Vue开发中,经常会遇到需要进行异步更新数据的情况,比如在修改DOM后需要立即更新数据或者在数据更新后需要立即进行相关操作。而Vue提供的.nextTick函数就是为了解决这类问题而出现的。本文就会详细介绍Vue.nextTick函数的用法,并结合代码示例来说明它在异步更新中的应用。一、Vue.nex

在Web应用程序中,缓存通常是用来优化性能的重要手段。Django作为一款著名的Web框架,自然也提供了完善的缓存机制来帮助开发者进一步提高应用程序的性能。本文将对Django框架中的缓存机制进行详解,包括缓存的使用场景、建议的缓存策略、缓存的实现方式和使用方法等方面。希望对Django开发者或对缓存机制感兴趣的读者有所帮助。一、缓存的使用场景缓存的使用场景

PHP-FPM是一种常用的PHP进程管理器,用于提供更好的PHP性能和稳定性。然而,在高负载环境下,PHP-FPM的默认配置可能无法满足需求,因此我们需要对其进行调优。本文将详细介绍PHP-FPM的调优方法,并给出一些代码示例。一、增加进程数默认情况下,PHP-FPM只启动少量的进程来处理请求。在高负载环境下,我们可以通过增加进程数来提高PHP-FPM的并发

在PHP开发中,有时我们需要判断某个函数是否可用,这时我们便可以使用function_exists()函数。本文将详细介绍function_exists()函数的用法。一、什么是function_exists()函数?function_exists()函数是PHP自带的一个内置函数,用于判断某个函数是否被定义。该函数返回一个布尔值,如果函数存在返回True,

Gin框架是目前非常流行的Go语言Web框架之一。作为一个轻量级的框架,Gin提供了丰富的功能和灵活的架构,使得它在Web开发领域中备受欢迎。其中一个特别重要的功能是模板渲染。在本文中,我们将介绍Gin框架的模板渲染功能,并深入了解它的实现原理。一、Gin框架的模板渲染功能Gin框架使用了多种模板渲染引擎来构建Web应用程序。目前,它支持以下几种模板引擎:

ORM(Object-RelationalMapping)框架是一种用于将面向对象编程语言中的对象模型与关系型数据库之间映射的技术。它使开发人员能够使用面向对象的方式操作数据库,而不需要直接操作SQL语言。在PHP开发领域中,ORM框架也得到了广泛的应用。本文将详细介绍PHP中的ORM框架使用方法。一、ORM框架的优点使用ORM框架有以下优点:1.提高开发


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。