国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

vue組件之間的數據傳遞方法詳解

來源:懂視網 責編:小采 時間:2020-11-27 21:58:31
文檔

vue組件之間的數據傳遞方法詳解

vue組件之間的數據傳遞方法詳解:(1)props屬性: 在父組件中,可以通過子組件標簽屬性的形式將數據或者函數傳給子組件,子組件通過props去讀取父組件傳過來的數據 用法 父組件傳數據給子組件: 一般的屬性值都是用來給子組件展示的 子組件傳數據給父組件 屬性值為函數類型的,一般是用來
推薦度:
導讀vue組件之間的數據傳遞方法詳解:(1)props屬性: 在父組件中,可以通過子組件標簽屬性的形式將數據或者函數傳給子組件,子組件通過props去讀取父組件傳過來的數據 用法 父組件傳數據給子組件: 一般的屬性值都是用來給子組件展示的 子組件傳數據給父組件 屬性值為函數類型的,一般是用來

(1)props屬性:

在父組件中,可以通過子組件標簽屬性的形式將數據或者函數傳給子組件,子組件通過props去讀取父組件傳過來的數據

用法

父組件傳數據給子組件:

  1. 一般的屬性值都是用來給子組件展示的

子組件傳數據給父組件

  1. 屬性值為函數類型的,一般是用來子組件向父組件傳遞數據,子組件通過調用父組件傳過來的函數,可以修改父組件的狀態數據

缺點:

  1. 隔層組件間傳遞: 必須逐層傳遞(麻煩)
  2. 兄弟組件間: 必須借助父組件(麻煩)

注意:

//子組件獲取父組件傳過來的值
props: {
 obj: {//obj為{id:'2'}
 type: Object 
 }
}

引用類型的props,我們可以在子組件中直接修改引用類型屬性的值(如:this.obj.id='3',會生效),但是不能直接改變引用類型存儲的地址值(如:this.obj = {id: '3'}),會發出警告。


雖然子組件可以直接修改父組件的狀態值,但我們不建議這樣做,我們希望所有的 prop 都使得其父子 prop 之間形成了一個單向下行綁定:父級 prop 的更新會向下流動到子組件中,但是反過來則不行。這樣會防止從子組件意外改變父級組件的狀態,從而導致你的應用的數據流向難以理解。

(2)vue自定義事件:

方式1: 給子組件標簽綁定事件監聽

子組件向父組件的通信方式

功能類似于function props

通過在父組件中給子組件標簽綁定自定義事件的監聽,再由子組件觸發事件,實現子組件向父組件傳遞數據的方法,事件名必須一致,且不能有大寫字母,v-on 事件監聽器在 DOM 模板中會被自動轉換為全小寫 (因為 HTML 是大小寫不敏感的)

// 方式一: 通過v-on綁定
<component @delete_todo="deleteTodo"/>
// 方式二: 通過$on()綁定
this.$refs.xxx.$on('delete_todo', function (todo) {
this.deleteTodo(todo)
})

通過this.$emit('delete_todo', todo)觸發事件

不適合隔層組件和兄弟組件間的通信

方式2: 通過單獨的vm對象綁定監聽/分發事件

任意組件間通信(類似于pubsub)

創建一個公用的vm對象

import Vue from 'vue'

export default new Vue()

在接收消息的組件,綁定監聽

import vm from './vm.js'

mounted(){
 vm.$on('delete_todo', function (todo) {
	this.deleteTodo(todo)
	})
}

在發送消息的組件,觸發事件

vm.$emit('delete_todo', todo)

(3) 消息的訂閱和發布(pubsub)

適用于任何關系的組件間的通信
缺點:相對于vuex,管理不夠集中
用法:

引入pubsub-js庫
在接收消息的組件訂閱消息(subscribe)
在發送消息的組件發布消息 ( publish)

(4)vuex

多組件共享狀態(數據的管理)
組件間的關系也沒有限制
功能比pubsub強大, 更適用于vue項目

(5) slot

父向子通信
通信是帶數據的標簽
注意: 標簽是在父組件中解析

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

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

vue組件之間的數據傳遞方法詳解

vue組件之間的數據傳遞方法詳解:(1)props屬性: 在父組件中,可以通過子組件標簽屬性的形式將數據或者函數傳給子組件,子組件通過props去讀取父組件傳過來的數據 用法 父組件傳數據給子組件: 一般的屬性值都是用來給子組件展示的 子組件傳數據給父組件 屬性值為函數類型的,一般是用來
推薦度:
標簽: VUE 方式 的方式
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: a国产精品| 亚洲欧美中文日韩在线 | 日韩午夜视频在线观看 | 一级毛片免费毛片一级毛片免费 | 欧美高清第一页 | 明星国产欧美日韩在线观看 | 99视频在线 | 国产一区二区三区日韩欧美 | 国产成人久久久精品毛片 | 日本成本人观看免费fc2 | xxx色xxx性| 欧美色亚洲图 | 欧美国产日韩一区二区三区 | 福利片一区二区 | 成人精品一区二区三区 | 国产99久久亚洲综合精品 | 亚洲综合视频一区 | 亚洲欧美日本另类激情 | 欧美亚洲国产一区二区 | 国产91久久久久久久免费 | 国精产品一区 | 日韩伦理网 | 日韩高清专区 | 麻豆porn | 九九久久亚洲综合久久久 | 91大神在线精品视频一区 | 亚洲成a人一区二区三区 | 中文字幕日本一本二本三区 | 精品一区二区三区三区 | 国产精品成久久久久三级 | 亚洲精品毛片久久久久久久 | 国产午夜在线观看 | 精品欧美一区手机在线观看 | 中日韩欧美在线观看 | 国产精品成人一区二区 | 91香蕉国产亚洲一区二区三区 | 欧美日韩一区二区三区免费 | 影音先锋中文字幕资源 | 日韩欧美大陆 | 成人精品一区二区www | 91精品成人免费国产 |