摘要:直接創建組件使用標簽名組件模板,根據組件構造器來創建組件。相應的,實例也被稱為父組件。而且不允許子組件直接修改父組件中的數據,強制修改會報錯。
一、組件 (一)什么是組件
組件(Component)是 Vue.js最強大的功能之一。組件可以擴展 HTML元素,封裝可重用的代碼組件是自定義元素(對象)。
(二)創建組件的兩種方式官方推薦組件標簽名是使用-連接的組合詞,例如:
使用這種方式創建組件首先需要使用Vue.extend()創建一個組件構造器,然后使用Vue.component(標簽名,組件構造器),根據組件構造器來創建組件。
//1.創建構造器 var MyComponent=Vue.extend({ template:"Hello World
" }); //2.創建組件 Vue.component("my-hello",MyComponent); //3.使用組件
這種創建組件的方式比較麻煩,使用的較少。
2、直接創建組件使用Vue.component(標簽名,組件模板),根據組件構造器來創建組件。
//1.創建組件 Vue.component("my-world", { template: "(三)組件的分類hello vue.js
" }); //2.使用組件
組件分為全局組件和局部組件。
1、全局組件使用Vue.component()創建的組件都是全局組件。這樣的組件在任何組件內都能使用。上面我們創建就是全局組件。
2、局部組件局部組件一般都是定義在實例的選項中,稱為實例的子組件。相應的,實例也被稱為父組件。
//1.定義組件 new Vue({ el: "#app", components: { dawei: { template: "(四)引用模板my name is dawei
" } } }); //2.使用組件
很多時候我們的template模板中需要存放很多標簽內容,這樣的話寫起來會很麻煩。這時候我們可以使用template標簽。
用法如下:
//使用template標簽new Vue({ el: "#app", components: { "my-dawei": { template: "#wbs", //選擇template標簽 data() { return { msg: "vue.js", arr: ["a", "b", "c", "d"] } } } } });hello {{msg}}
- {{value}}
這里涉及到的幾個知識點得著重提一下:
在template模板中,所有的元素必須放置在一個根元素中,要不然會報錯。例子中我們將元素放置在了 組件中的data選項必須是一個函數類型,使用return返回所有的數據。 很多時候項目中需要在某一個地方動態的使用不同的組件,這時候就需要使用動態組件。 簡單示例: 我是a組件 我是b組件 使用keep-alive組件緩存非活動組件,可以保留狀態,避免重新渲染,默認每次都會銷毀非活動組件并重新創建。 使用范例: {{x}} {{y}} 這樣的話,第一次產生的隨機數就會被緩存,再次切換的時候也不會發生改變。 在一個組件內部定義另一個組件,那么這對組件稱為父子組件。子組件只能在父組件內部使用。默認情況下,每個組件實例的作用域是獨立的,子組件無法訪問父組件中的數據,同樣,父組件也無法訪問子組件中的數據。 {{msg}} {{mydata}} 步驟: a、調用子組件時,綁定想要獲取的父組件中的數據 b、在子組件內部,使用props選項聲明獲取的數據,即接收來自父組件的數據 改進上面的例子: {{msg}} 這是要傳遞給子組件的值:{{myname}} {{mydata}} 這是父組件傳遞過來的數據:{{name}} 步驟: a 在子組件中使用vm.$emit(事件名,數據)觸發一個自定義事件,將數據發送給父組件,事件名自定義 b 父組件在使用子組件的地方監聽子組件觸發的事件,并在父組件中定義方法,用來獲取數據 props是單向數據綁定的,當父組件數據發生變化時,將傳遞給子組件,但是不會反過來。而且不允許子組件直接修改父組件中的數據,強制修改會報錯。 解決方案: 如果子組件想把它作為局部數據來使用,可以將數據存入另一個變量中再操作,不影響父組件中的數據 如果子組件想修改數據并且同步更新到父組件,兩個方法: 使用.sync顯式地觸發一個更新事件(1.0版本中支持,2.0版本中不支持,2.3版本又開始支持) 可以將父組件中的數據包裝成對象,然后在子組件中修改對象的屬性(因為對象是引用類型,指向同一個內存空間),推薦使用這種方式。 非父子組件間的通信,可以通過一個空的Vue實例作為中央事件總線(事件中心),用它來觸發事件和監聽事件,從而實現非父子組件間的通信。 用來獲取組件中的原內容 如果組件標簽中沒有內容就會顯示slot中的內容,這也就是所謂的單個插槽。 還可以對顯示的內容進行分組,這就是具名插槽,可以操作標簽組中的內容: hello vue.js 這樣,就可以對組件中的內容實時操作。 文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。 轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/51417.html
動態組件的使用需要綁定is屬性://點擊按鈕顯示不同的組件
(六)keep-alive組件
(二)組件間數據傳遞(通信)
1、子組件訪問父組件的數據
2、父組件訪問子組件的數據
//子組件‘my-b’內部
methods:{
send(){//使用$emit()觸發一個事件,發送數據,this指當前子組件實例
this.$emit("e-world", this.senddata);
}
}
//在調用子組件的地方監聽子組件觸發的事件,調用自己的方法獲取數據
3、單向數據流
//使用.sync
data() {
return { //將要傳遞的數據放入message對象中
message: {
hello: "子組件b你好,我是父組件a"
}
}
}
4. 非父子組件間的通信
var Event = new Vue(); //空vue實例
methods: {
send() { //觸發emit事件
Event.$emit("hello", this.asmsg);
}
}
mounted() { //在子組件的鉤子函數中監聽該事件
Event.$on("hello", data => { //獲取值
this.bsmsg = data;
})
}
三、slot內容分發
var vm = new Vue({
el: "#app",
components: {
"my-hello": {
template: "#hello"
}
}
});
摘要:升級的區別與的斷層式升級不同,延續了自己的風格。在命名方式和上有一些區別,掌握它們是你升級整個項目的關鍵。以下內容都是來源于個人項目的一些經驗之談,并非系統性的闡述。總目錄前端經驗收集器轉載自個人建了前端學習群,旨在一起學習前端。 升級的區別 與angular的斷層式升級不同,vue延續了自己的風格。在命名方式和API上有一些區別,掌握它們是你升級整個項目的關鍵。以下內容都是來源于個人...
摘要:直接創建組件使用標簽名組件模板,根據組件構造器來創建組件。相應的,實例也被稱為父組件。而且不允許子組件直接修改父組件中的數據,強制修改會報錯。 一、組件 (一)什么是組件 組件(Component)是 Vue.js最強大的功能之一。組件可以擴展 HTML元素,封裝可重用的代碼組件是自定義元素(對象)。 (二)創建組件的兩種方式 官方推薦組件標簽名是使用-連接的組合詞,例如:。 1、使用...
摘要:有興趣的同學可以查看之前發布的文章學習系列一學習實踐筆記附學習系列二學習實踐筆記附學習系列三和網絡傳輸相關知識的學習實踐學習系列四打包工具的使用學習系列五從來聊聊學習系列項目地址項目暫時有點亂,之后會進行整理優化。 上次學習了vue-router的使用,讓我能夠在各個頁面間切換,將頁面搭建了起來。這次則要學習vue的狀態管理模式——vuex。它類似于redux來應用的全局狀態。 注:本...
摘要:提供了兩種向組件傳遞參數的方式。子路由項路徑不要使用開頭,以開頭的嵌套路徑會被當作根路徑。路由實例的方法這里學習兩個路由實例的方法和。實際上,是通過不同的將這些資源加載后打包,然后輸出打包后文件。 一、vue-router 1、簡介 我們經常使用vue開發單頁面應用程序(SPA)。在開發SPA過程中,路由是必不可少的部分,vue的官方推薦是vue-router。單頁面應用程序看起來好像...
摘要:提供了兩種向組件傳遞參數的方式。子路由項路徑不要使用開頭,以開頭的嵌套路徑會被當作根路徑。路由實例的方法這里學習兩個路由實例的方法和。實際上,是通過不同的將這些資源加載后打包,然后輸出打包后文件。 一、vue-router 1、簡介 我們經常使用vue開發單頁面應用程序(SPA)。在開發SPA過程中,路由是必不可少的部分,vue的官方推薦是vue-router。單頁面應用程序看起來好像...
閱讀 3832·2021-11-25 09:43
閱讀 2178·2021-11-23 10:11
閱讀 1406·2021-09-29 09:35
閱讀 1315·2021-09-24 10:31
閱讀 2040·2019-08-30 15:48
閱讀 2357·2019-08-29 15:28
閱讀 431·2019-08-29 12:36
閱讀 3494·2019-08-28 18:12