vue父子組件的通信

来源:https://www.cnblogs.com/DreamchaserHe/archive/2019/11/08/11766170.html
-Advertisement-
Play Games

一、父組件向子組件傳遞數據 1、首先形成父子組件關係 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="../js/vue.js"></script> ...


 

一、父組件向子組件傳遞數據

1、首先形成父子組件關係

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <div id="app">

    </div>

    <template id="cpn">
        <div>
            <h2>{{cmovies}}</h2>
            <p>{{cmessage}}</p>
        </div>
    </template>
    <script>
        const cpn = {
            template: `#cpn`,
            data() {
                return {}
            },
            methods: {}
        }
        let vm = new Vue({
            el: '#app',
            data: () => ({
                message: '父組件的數據',
                movies: ['戰狼1', '流浪地球', '攀登者']
            }),
            components: {
                cpn
            }
        })
    </script>
</body>

</html>

2、在子組件中定義一個props,定義兩個變數 (messages) (moviess)

props: ['messages', 'moviess']

3、使用子組件時,用V-bind綁定兩個變數(messages) (moviess),並且把父組件中的數據(message)(movies)傳給這兩個變數。

<cpn :messages="message" :moviess="movies"></cpn>
<!-- 不支持駝峰命名法 大寫字母之間用 - 隔開 -->

****完整代碼*****

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <div id="app">
        <cpn :messages="message" :moviess="movies"></cpn>
        <!-- 不支持駝峰命名法 大寫字母之間用 - 隔開 -->
    </div>
    <!-- 父傳子 -->
    <!-- 
        1、建立父子關係
        2、在子組件中定義一個props,定義兩個變數 (messages) (moviess)
        3、使用子組件時,用V-bind綁定兩個變數,並且把父組件中的數據(message)(movies)傳給這兩個變數。
        
     -->
    <template id="cpn">
        <div>
            <h2>{{messages}}</h2>
            <ul>
                <li v-for="item in moviess">
                    {{item}}
                </li>
            </ul>
        </div>
    </template>
    <script>
        const cpn = {
            template: `#cpn`,
            // props: ['messages', 'moviess'],


            props: {
                // 1、類型限制
                // messages:Array,
                // moviess:String,

                // 提供一些預設值
                messages: {
                    type: String,
                    default: 'aaaa',
                    required: true
                },
                // 當使用組件的時候,沒有綁定props中定義的變數,就會顯示定義的預設值
                moviess: {
                    // 類型是對象或數組,預設值必需是一個函數。  
                    type: Array,
                    // default: []
                    default() {
                        return []
                    }
                }
            },
            data() {
                return {}
            },
            methods: {}

        }
        let vm = new Vue({
            el: '#app',
            data: () => ({
                message: '父組件的數據',
                movies: ['戰狼1', '流浪地球', '攀登者'],

            }),
            components: {
                cpn
            }
        })
    </script>
</body>

</html>

** props中補充寫法

props: {
                // 1、類型限制
                // messages:Array,
                // moviess:String,

                // 提供一些預設值
                messages: {
                    type: String,
                    default: 'aaaa',
                    required: true
                },
                // 當使用組件的時候,沒有綁定props中定義的變數,就會顯示定義的預設值
                moviess: {
                    // 類型是對象或數組,預設值必需是一個函數。  
                    type: Array,
                    // default: []
                    default() {
                        return []
                    }
                }
            }

 二、子組件向父組件傳數據

1、構成父子組件關係

 2、在子組件中自定義一個事件      作用:發射一個事件給父組件

<button v-for="item in categories" @click="btnclick(item)">{{item.name}}</button>

 

            methods: {
                btnclick: function (item) {
                    // 發射事件:自定義事件
                    this.$emit('itemclick', item)
                }
            }

3、在父組件的模板中使用子組件中定義的事件 @itemclick="cpnclick"   並且在父組件創建一個新的事件 cpnclick 

<cpn @itemclick="cpnclick"></cpn>
            methods: {
                cpnclick: function (item) {
                    console.log('cpnclick', item)
                }
            }

***完整代碼***

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>
<!-- 父組件模板 -->
<div id="app">
    <cpn @itemclick="cpnclick"></cpn>
</div>
<!-- 
    1、構成父子組件關係
    2、在子組件定義一個事件,作用是  發射一個事件給父組件。this.$emit('itemclick')
    3、在父組件的模板中使用子組件中定義的事件 @itemclick="cpnclick" ,並且在父組件創建一個新的事件 cpnclick ,
    這裡面可以寫傳給父組件數據的邏輯以及限制
 -->

<body>
    <!-- 子組件模板 -->
    <template id="cpn">
        <div>
            <button v-for="item in categories" @click="btnclick(item)">{{item.name}}</button>
        </div>
    </template>
    <script>
        // 子組件
        const cpn = {
            template: `#cpn`,
            data() {
                return {
                    categories: [
                        { id: 'aa', name: '熱門推薦' },
                        { id: 'bb', name: '手機數位' },
                        { id: 'cc', name: '智能家居' },
                        { id: 'dd', name: '美容美髮' }
                    ]
                }
            },
            methods: {
                btnclick: function (item) {
                    // 發射事件:自定義事件
                    this.$emit('itemclick', item)
                }
            }
        }
        // 父組件
        let vm = new Vue({
            el: '#app',
            data: () => ({}),
            components: {
                cpn
            },
            methods: {
                cpnclick: function (item) {
                    console.log('cpnclick', item)
                }
            }
        })
    </script>
</body>

</html>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 算是 ...
  • 統計信息概念 MySQL統計信息是指資料庫通過採樣、統計出來的表、索引的相關信息,例如,表的記錄數、聚集索引page個數、欄位的Cardinality....。MySQL在生成執行計劃時,需要根據索引的統計信息進行估算,計算出最低代價(或者說是最小開銷)的執行計劃.MySQL支持有限的索引統計信息,... ...
  • 1.序列 設置主鍵自增 (1)創建t_user表 create table t_user( id number, name varchar2(10) ); (2)自增設置create sequence my_seq increment by 1 start with 1 (3)序列第一次使用必須使用 ...
  • 在上篇筆記中,為車輛信息表、車輛耗損表以及車輛營收表插入了一些數據。之後便是查詢了,重點也在查詢……按照之前定好的數據結構,如果是查詢mongodb document的最外層比較簡單,但是我們的重點應該是FormItems表單項集合中的表單項,對他們進行查詢、統計等。根據插入的數據,我寫了一個查詢: ...
  • --查詢資料庫鎖表記錄 select sess.sid, sess.serial#, lo.oracle_username, lo.os_user_name, ao.object_name, lo.locked_mode from v$locked_object lo, dba_objects ao ...
  • begin try 語句 end trybegin catch --ERROR_NUMBER() 返回錯誤號。 --ERROR_SEVERITY() 返回嚴重性。 --ERROR_STATE() 返回錯誤狀態號。 --ERROR_PROCEDURE() 返回出現錯誤的存儲過程或觸發器的名稱。 --E ...
  • 跨平臺開發是當下最受歡迎、應用最廣泛的框架之一。能實現跨平臺開發的框架也五花八門,讓人眼花繚亂。最流行的跨平臺框架有 Xamarin、PhoneGap、Ionic、Titanium、Monaca、Sencha、jQuery Mobile、React native、Flutter 等等。但這些工具的表 ...
  • 效果圖 修改思路 1、增加全局控制變數 sys.launcher3.is_full_app ,用來動態切換 2、增加兩套佈局,對應有抽屜和無抽屜 3、去除 allAppsButton 4、將 AllAppsContainerView 中的圖標載入到 Workspace 5、新安裝的 app 自動添加 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...