vue父子組件的通信

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

一、父組件向子組件傳遞數據 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>

 


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

更多相關文章
  • 算是 ...
  • 統計信息概念 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 自動添加 ...
一周排行
  • C 語法糖——持續更新 1. return的switch寫法 ...
  • 0. 前言 繼上一篇,以及上上篇,我們對SqlSugar有了一個大概的認識,但是這並不完美,因為那些都是理論知識,無法描述我們工程開發中實際情況。而這一篇,將帶領小伙伴們一起試著寫一個能在工程中使用的模板類。 1. 創建一個Client SqlSugar在操作的時候需要一個Client,用來管理數據 ...
  • 1 class Program 2 { 3 static void Main(string[] args) 4 { 5 //數組:長度不可變,類型單一 6 //ArrayList集合:長度可以任意改變,類型可以不單一 7 8 //創建一個ArrayList對象 9 ArrayList mylist ...
  • .NET 程式下銳浪報表 (Grid++ Report) 的綠色發佈指南 在銳浪報表官方為 CSharp 編寫的開發文檔:“在C#與VB.NET中開始使用說明.txt” 中,關於發佈項目是這麼描述的: ★發佈你的項目,用VS.NET製作安裝程式:1、先創建安裝項目:在解決方案資源管理器的根節點上點右 ...
  • 執行代碼清理時,可以點擊那個掃把小圖片,會按照預設的第一種配置文件來自動修複。也可以點擊下拉三角符合,選擇不同的配置文件,然後進行修複。或者快捷鍵Ctrl+K,Ctrl+E。 針對每一項配置的說明: 刪除不必要的using 儘可能將私有欄位設置為只讀 刪除不必要的類型轉換(針對強類型轉換),像Con ...
  • 1.概念簡述 (1)AR模型 AR 模型(auto regressive model)自回歸模型,模型參量法高解析度譜分析方法之一,也是現代譜估計中常用的模型。 用AR模型法求信具體作法是: ①選擇AR模型,在輸入是衝激函數或白雜訊的情況下,使其輸出等於所研究的信號,至少,應是對該信號的一個好的近似 ...
  • 4.元組 元組的主要特性為: 1.元組在創建之後,具有不可以更改的特性,因此不能直接給元組的元素賦值 2.元組的元素類型可以為任意類型,如字典、字元串、列表等 3.元組常用於在程式的整個生命周期中都不變的場景中 4.1 常用方法 元組大小和內容在定義賦值之後,就不可更改,常用的方法如下所示: cou ...
  • 老孟導讀:今天分享一個類似“孔雀開屏”的動畫效果,打開新的頁面時,新的頁面從屏幕右上角以圓形逐漸打開到全屏。 先來看下具體的效果 不知道這種效果大家叫什麼名字?如果有更合適的名字可以在評論處告訴我,下麵來說下如何實現此效果。 在使用Navigator進入一個新的頁面時,通常用法如下: 就包含了切換頁 ...
  • hashCode() 和equals() 方法的重要性體現在什麼地方? Java中的HashMap使用hashCode()和equals()方法設置值,根據鍵獲取值的時候也會用到這兩個方法。 怎樣 設置 的值? hashCode()獲得 hash值。而hash值用來確定hashmap中內部 Node ...
  • IDEA一些不錯的插件分享 目錄 IDEA一些不錯的插件分享 插件集合 CamelCase Translation LiveEdit MarkDown Navigator Jrebel CheckStyle IDEA Alibaba Java Coding Guidelines Ideavim Ma ...