vue中的this.$emit方法:用于子組件中觸發父組件方法并傳值

vue中的this.$emit方法

  • 使用一:$emit
  • 使用二:$emit update 和 .sync 修飾符


作用:用于子組件中觸發父組件方法并傳值
注意:?$emit傳入的事件名稱只能使用小寫,不能使用大寫的駝峰規則命名。
?

使用一:$emit

//子組件中
<template><button @click="handleChildEvent">子組件中觸發的事件</button>
</template><script>
export default {name:'ChildComponent',methods: {handleChildEvent() {// 觸發自定義事件,并傳遞數據給父組件this.$emit('parent-event', 'Hello, World!');}}
}
</script>  
//父組件中
<child-component @parent-event="handleParentEvent"/><script>
export default {name: 'ParentComponent',// 注冊子組件components: {ChildComponent},   methods: {handleParentEvent(data) {// 處理自定義事件的邏輯console.log(data); // 輸出:'Hello, World!'}}
}
</script>  

使用二:$emit update 和 .sync 修飾符

作用:.sync可以幫我們實現父組件向子組件傳遞的數據的雙向綁定,所以子組件接收到數據后可以直接修改,并且會同時修改父組件的數據

// 父組件
<template>//給子組件傳值時使用.sync修飾符<child :page.sync="page"></child>
</template>
<script>
export default {data(){return {page:1}}
}
</script>
//子組件中
<script>
export default {props:["page"],computed(){// 當我們在子組件里修改 currentPage 時,父組件的 page 也會隨之改變 currentPage {get(){return this.page},set(newVal){//$emit update 修改父組件中的數據this.$emit("update:page", newVal)}}}
}
</script>

相當于省略了父組件給子組件多傳遞一個修改數據的方法

// 帶 .sync 修飾符
<children :selectNode.sync="node" />// 無 .sync 修飾符,等同于
<children :selectNode="node" @update:selectNode="node=$event" />

實現子組件與父組件雙向綁定的【sync】修飾符:其實sync這個修飾符是vue1.0就有的,它可以實現父子組件的雙向綁定,但是Vue2.0被移除了,直到2.3.0版本發布后,又重新開始啟用,由于數據安全問題,后來vue3.x后又被重新取消了。

【.sync】可以很輕松的實現子組件同步修改父組件的值,如果子組件想修改父組件的值,推薦在子組件中以 update:my-prop-name 的模式觸發事件取而代之,也就是這樣:

父組件: 
<text-documentv-bind:title="doc.title"v-on:update:title="doc.title = $event"
></text-document>
 子組件:
this.$emit("update:title",newTitle)
而上邊的 v-on:update:title="doc.title = $event",本質上就可以用sync這個語法糖來表示,.sync后面緊接的就是父組件中需要被改變的值,看下邊的例子: 
父組件:
<template><div><child-com :value.sync="text" ></child-com></div>
</template>
<script>export default{data(){return {text:"父組件的值",}},}
</script>
子組件中修改父組件的值:
<template><div @click="post"></div>
</template> 
<script>export default{methods:{post(){this.$emit('update:value',"子組件的值")}}}
</script>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/697654.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/697654.shtml
英文地址,請注明出處:http://en.pswp.cn/news/697654.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【正點原子STM32連載】 第五十五章 FreeRTOS移植實驗 摘自【正點原子】APM32E103最小系統板使用指南

1&#xff09;實驗平臺&#xff1a;正點原子APM32E103最小系統板 2&#xff09;平臺購買地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套實驗源碼手冊視頻下載地址&#xff1a; http://www.openedv.com/docs/boards/xiaoxitongban 第五…

用Python制定旅行計劃

編寫一個Python腳本,用于制定旅行計劃。這個腳本將詢問關于旅行的基本問題,并根據回答生成一旅行計劃。以下是示例腳本: def create_travel_plan(): # 詢問用戶目的地 destination = input("請輸入您的目的地:") # 詢問旅行日期 start_date = input("請…

【Kuiperinfer】筆記02 GoogleTest入門

文章目錄 Google Test基本概念 編寫測試頭文件AssertionTESTTest FixtureInvoking the Tests編寫main()函數 參考 Google Test Google Test是用于編寫C測試的框架&#xff0c;支持多種類型的測試&#xff0c;而不是只有單元測試&#xff08;unit test&#xff09;。 編寫測試…

weblogic8版本修改控制臺密碼

weblogic的8.1老版本在控制臺界面上沒有修改密碼的按鈕選項&#xff0c;因此需要通過修改服務器配置文件來更新密碼。 步驟1&#xff1a; 備份域目錄下的DefaultAuthenticatorInit.ldift文件 通過find /域目錄 -name weblogic.jar 查到jar包&#xff0c;通過命令生成文件 …

css3的var()函數

css3的var()函數 變量要以兩個連字符--(橫桿)(減號)為開頭 變量可以在:root{}中定義, :root可以在css中創建全局樣式變量。通過 :root本身寫的樣式&#xff0c;相當于 html&#xff0c;但優先級比后者高。 在CSS3中&#xff0c;var()函數是一個用于插入CSS自定義屬性&#xff…

Vulhub 靶場訓練 DC-6解析

一、搭建環境 kali充當攻擊機 ip地址是&#xff1a;192.168.200.14 DC-6充當靶機 &#xff1a; IP地址暫時未知 注意&#xff1a;讓兩臺機器的使用同一種網絡適配器 二、信息收集 1、探索同網段存活的主機 ①第一種方法 arp-scan -l②第二種方法 netdiscover -i eth0 -…

Python內置函數67個語法、參數和用法詳解

要獲取Python解釋器中所有當前可用的內置函數和變量的完整列表,您可以在Python解釋器中使用dir(__builtins__)命令。這將返回一個包含所有內置函數、異常和其他內置對象的列表。 分為10類 數學運算(7): abs 絕對值divmod 商和余數max 最大min最小pow 指數冪round 取整sum 求…

npm/nodejs安裝、切換源

前言 發現自己電腦上沒有npm也沒有node很震驚&#xff0c;難道我沒寫過代碼么&#xff1f;不扯了&#xff0c;進入正題哈哈…… 安裝 一般沒有npm的話會報錯&#xff1a; 無法將“npm”項識別為 cmdlet、函數、腳本文件或可運行程序的名稱而且報這個錯&#xff0c;我們執行…

【騎行新紀元】社交風暴來襲,你準備加入騎友圈了嗎?

當你的自行車輪輕輕滑過清晨的露水&#xff0c;你是否曾想與志同道合的騎友分享這一刻的喜悅&#xff1f;騎行&#xff0c;這個曾經只是簡單運動的代名詞&#xff0c;如今正在悄然轉變。隨著科技的進步和社交平臺的發展&#xff0c;騎行不再只是一種健身方式&#xff0c;它還帶…

【機器學習】是什么?——講解

機器學習 機器學習是人工智能&#xff08;AI&#xff09;的一個子領域&#xff0c;它提供了系統通過數據學習并改進其性能的能力&#xff0c;而不需要人為進行顯式編程&#xff0c;機器學習模型利用大量的數據樣本&#xff08;訓練數據&#xff09;來學習如何識別模式和關系&a…

C-指針-010

1指針 1.1語法&#xff1a; 【基類型*指針變量名】 【int *p&a】1.2語義&#xff1a; 【基類型】&#xff1a;指針變量指向的目標的數據類型 【*】&#xff1a;表示此時定義的變量是一個指針類型的變量 【&a】&#xff1a;一塊存放著int類型數據的空間的地址 【*p】…

slot全局屬性 <slot>標簽</slot> ::slotted()偽元素 筆記240223

slot全局屬性 標簽 ::slotted()偽元素 MDN HTML全局屬性 MDN HTML全局屬性 slot MDN HTML <slot>標簽元素 MDN CSS ::slotted()為元素 MDN 使用 templates and slots <slot>標簽 <slot>標簽是的 display 是 contents 在Web開發中&#xff0c;<s…

【高德地圖】Android搭建3D高德地圖詳細教

&#x1f4d6;Android搭建3D高德地圖詳細教程 &#x1f4d6;第1章 高德地圖介紹?了解高德地圖?2D地圖與3D地圖 &#x1f4d6;第2章 搭建3D地圖并顯示?第 1 步&#xff1a;創建 Android 項目?第 2 步&#xff1a;獲取高德Key?第 3 步&#xff1a;下載地圖SDK?第 4 步&…

照片上多余的人怎么處理?這幾種方法讓你的照片更完美!

照片怎么去掉多余人像&#xff1f;這是許多攝影愛好者經常遇到的問題。有時候&#xff0c;我們拍攝了一張非常美好的照片&#xff0c;但由于某些原因&#xff0c;照片中出現了不希望出現的人物。這時候&#xff0c;我們該如何處理呢&#xff1f;下面&#xff0c;我將分享幾種常…

2.5網安學習第二階段第五周回顧(個人學習記錄使用)

本周重點 ①多進程和多線程 1、進程和線程 2、多線程爆破 ②Redis數據庫 1、Redis的使用 2、Redis持久化 3、Redis未授權免密登錄 ③嗅探和Python攻擊腳本 1、嗅探&#xff08;端口掃描和IP掃描&#xff09; 2、SCAPY的應用 3、Python攻擊腳本&#xff08;SYN半連接…

【More Effective C++】條款22:采用op+=取代op+優勢

采用operator實現operator優點&#xff1a; 降低維護成本&#xff0c;只需要維護operator即可&#xff1b;如果operator為publicoperator不需要稱為class的友元&#xff1b;通過模板的方式自動實現operator版本&#xff1b;提供兩種操作方式&#xff0c;operator效率高&#x…

計算機網絡-局域網

文章目錄 局域網局域網拓撲結構以太網以太網傳輸介質以太網時隙提高傳統以太網帶寬的途徑以太網幀格式 局域網協議IEEE 802參考模型IEEE802.2協議LLC幀格式及其控制字段LLC提供的三種服務 IEEE 802.3協議IEEE 802.4協議IEEE 802.5協議 高速局域網100M以太網千兆以太網萬兆以太網…

沖突管理最佳實踐

任何團隊都無法避免沖突&#xff0c;如何有效管理沖突&#xff0c;將沖突轉化為團隊成長和凝聚的動力&#xff0c;是任何一個團隊管理者的必修課。原文: Best Practices for Managing Conflict in Engineering Management Obie Fernandez Unsplash 沖突在任何組織中都不可避免&…

計算機網絡中的與或非運算

三種基本邏輯運算關系 搭建中小公司網絡&#xff0c;根據網址計算&#xff0c;用戶的人數 需要ip和掩碼&#xff0c;確定可分配的ip數 與運算電路為串聯電路&#xff0c;的&#xff0c;A,B的組合情況 具體參考三種基本邏輯運算關系

圖片參考網站

攝圖網-正版高清圖片免費下載_商用設計素材圖庫 (699pic.com) AIGC數字藝術素材圖片-數字藝術-數字藝術圖片-攝圖網 (699pic.com) 花瓣網 - 陪你做生活的設計師&#xff08;創意靈感天堂&#xff0c;搜索、發現設計靈感、設計素材&#xff09; (huaban.com) 千圖網-免費在線…