摘要:自定義事件我們知道,父組件使用傳遞數(shù)據(jù)給子組件。另外,父組件可以在使用子組件的地方直接用來監(jiān)聽子組件觸發(fā)的事件。為了讓組件可以組合,我們需要一種方式來混合父組件的內(nèi)容與子組件自己的模板。
自定義事件
使用 綁定自定義事件v-on我們知道,父組件使用 prop 傳遞數(shù)據(jù)給子組件。但子組件怎么跟父組件通信呢?這個時候 Vue 的自定義事件系統(tǒng)就派得上用場了。
每個 Vue 實例都實現(xiàn)了事件接口,即:
使用 $on(eventName) 監(jiān)聽事件
使用 $emit(eventName) 觸發(fā)事件
Vue 的事件系統(tǒng)與瀏覽器的 EventTarget API 有所不同。盡管它們的運行起來類似,但是 $on 和 $emit 并不是addEventListener 和 dispatchEvent 的別名。
另外,父組件可以在使用子組件的地方直接用 v-on 來監(jiān)聽子組件觸發(fā)的事件。
不能用 $on 偵聽子組件釋放的事件,而必須在模板里直接用 v-on 綁定,參見下面的例子。
//定義子組件 var Child = { //獲取data()中的數(shù)據(jù),并添加一個點擊事件 template: ``, data(){ return { counter: 0 } }, methods:{ addCounter(){ this.counter++; //自定義事件$emit傳回根組件,同時調(diào)用根組件方法 this.$emit("add-parent-total") } } } //根組件 var vm = new Vue({ el: "#app", data:{ total: 0 }, components: { Child }, methods: { //根組件中子組件改變根組件的方法 addTotal(){ this.total++ } } }) //html使用插槽分發(fā)內(nèi)容
注意兩點:
為了讓組件可以組合,我們需要一種方式來混合父組件的內(nèi)容與子組件自己的模板。這個過程被稱為內(nèi)容分發(fā) (即 Angular 用戶熟知的“transclusion”)。Vue.js 實現(xiàn)了一個內(nèi)容分發(fā) API,參照了當前 Web Components 規(guī)范草案,使用特殊的
//slot插槽使其可以在html中傳入數(shù)據(jù),也可以在其中傳入默認內(nèi)容 var Child = { template: `1` } var vm = new Vue({ el: "#app", components: { Child } }) html默認內(nèi)容 hello
有名slot
//slot插槽使其可以在html中傳入數(shù)據(jù),也可以在其中傳入默認內(nèi)容 var Child = { template: `非父子組件1` } var vm = new Vue({ el: "#app", components: { Child } }) htmlheader 默認內(nèi)容 footer 頭部內(nèi)容22222底部內(nèi)容
有時候,非父子關(guān)系的兩個組件之間也需要通信。在簡單的場景下,可以使用一個空的 Vue 實例作為事件總線:
var bus = new Vue() var AppHead = { template: "", methods: { add() { // 觸發(fā)組件A中的事件 bus.$emit("change", 1) } } } var AppBody = { template: "模態(tài)框?qū)嵗?/b>{{ counter }}", data() { return { counter: 0 } }, created() { //在組件B創(chuàng)建的鉤子中監(jiān)聽事件 bus.$on("change", count => { this.counter += count }) } } var vm = new Vue ({ el: "#app", components: { AppHead, AppBody } })
vue路由Document 注冊 登錄 注冊
登錄
對于大多數(shù)單頁面應(yīng)用,都推薦使用官方支持的 vue-router 庫。更多細節(jié)可以看 vue-router 文檔。
靜態(tài)路由不需要復雜的路由
首先需要 npm i -S vue-router 安裝router庫 var NewsComponent = { template: `動態(tài)路由新聞`} var ShopComponent = { template: `商場`} var NotFoundComponent = { template: `404`} var routes = [ { path: "/", redirect: "/news"http://默認根目錄跳轉(zhuǎn) }, { path: "/news", component: NewsComponent }, { path: "/shop", component: ShopComponent }, { path: "*", component: NotFoundComponent } ] var router = new VueRouter({ routes }) // var app = new Vue({ // el: "#app", // router // }) var app = new Vue({ el: "#app", router })
var Goods = { template: ``, watch: { $route (to, from) { console.log(to.params.id); axios.get("http://h6.duchengjiu.top/shop/api_goods.php?cat_id="+to.params.id).then(res => { console.log(res.data.data) this.goods = res.data.data }) } }, data() { return { goods: [] } } } var router = new VueRouter({ routes: [ { path: "/cat/:id", component: Goods } ] }); var vm = new Vue({ el: "#app", router, data: { cats: [] }, created() { axios.get("http://h6.duchengjiu.top/shop/api_cat.php").then(res => { console.log(res) this.cats = res.data.data }) } });
- {{ good.goods_name }} {{ good.price }}
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/51497.html
vue 頭條 demo 寫在前面 總結(jié)一下寫 demo 過程中 遇到的一些問題,方便自己的學習總結(jié)!如有錯誤,還請指正! 一直想學習使用 vue ,并準備以后在實際項目使用,之前跟著慕課網(wǎng) 黃軼 老師 敲了一下 餓了么商品購買頁的demoele效果預覽 該 demo 借鑒自 hcy1996-github 這個項目,但內(nèi)部內(nèi)容,布局風格,完全不同,只為共同學習,共同交流 數(shù)據(jù)接口 直接打開 今日...
摘要:本文總結(jié)了組件間通信的幾種方式,如和,以通俗易懂的實例講述這其中的差別及使用場景,希望對小伙伴有些許幫助。狀態(tài)改變提交操作方法。 前言 組件是 vue.js最強大的功能之一,而組件實例的作用域是相互獨立的,這就意味著不同組件之間的數(shù)據(jù)無法相互引用。一般來說,組件可以有以下幾種關(guān)系:showImg(https://segmentfault.com/img/remote/146000001...
摘要:本文總結(jié)了組件間通信的幾種方式,如和,以通俗易懂的實例講述這其中的差別及使用場景,希望對小伙伴有些許幫助。狀態(tài)改變提交操作方法。前言 組件是 vue.js最強大的功能之一,而組件實例的作用域是相互獨立的,這就意味著不同組件之間的數(shù)據(jù)無法相互引用。一般來說,組件可以有以下幾種關(guān)系: showImg(https://user-gold-cdn.xitu.io/2019/5/17/16ac35bf...
閱讀 3267·2021-11-23 10:09
閱讀 2068·2021-10-26 09:51
閱讀 982·2021-10-09 09:44
閱讀 3912·2021-10-08 10:04
閱讀 2750·2021-09-22 15:14
閱讀 3630·2021-09-22 15:02
閱讀 1067·2021-08-24 10:03
閱讀 1732·2019-12-27 12:14