亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中emit事件無(wú)法觸發(fā)的問題及解決

 更新時(shí)間:2022年09月23日 09:28:52   作者:y_hh_  
這篇文章主要介紹了Vue中emit事件無(wú)法觸發(fā)的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Vue emit事件無(wú)法觸發(fā)問題

在父組件中定義事件監(jiān)聽,會(huì)出現(xiàn)無(wú)法觸發(fā)對(duì)應(yīng)的事件函數(shù),在下面的代碼中,我想通過(guò)v-on:event_1=“handle”, 想監(jiān)聽子組件中的event_1事件,但盡管事件發(fā)生了, 但還是觸發(fā)不了,這個(gè)問題在于v-on:event_1="handle"的位置,需要放在 <my-template :users=“users” v-on:event_1=“handle” ></my-template> 中。 

<body>
    <div id='app' v-on:event_1="handle1">
        <my-template :users="users"></my-template>
    </div>
    
</body>
<script>
    Vue.component('my-template', {
        data: function () {
            return {
                test:"hello"
            }
        },
        props: ["users"],
        template: `
        <div>
            <ul>
                <li v-for="item in users" :key="item.id">
                    <div>
                    <label>name:</label>
                    {{item.name}}
                    <label>content:</label>
                    {{item.content}}
                    <label>time:</label>
                    {{item.time}}
                    <input type="button" value="remove" @click="remove(item.id)"></input>
                    <input type="button" value="通知" @click="$emit('event_1',this)"></input>
                    </div>
                </li>
            </ul>
        </div>
    `,
    methods:{
        remove(id){
            console.log(id);
            for(let i = 0; i<this.users.length;++i){
                if(this.users[i].id == id){
                    this.users.splice(i,1);
                    break;
                }
            }
        },
        notice(id){
            console.log("notice", id);
            
        },
        handle(e){
            console.log("son handle",e)
        }
    }
    })
    var vm = new Vue({
        el: '#app',
        data: {
            posts: [
                { id: 1, title: 'My journey with Vue' },
                { id: 2, title: 'Blogging with Vue' },
                { id: 3, title: 'Why Vue is so fun' }
            ],
            postFontSize: 1,
            searchText: 'hello',
            users:[
                {
                    name:"zhangsan",
                    id:'1',
                    time:new Date().getUTCDate(),
                    content:"白日依山盡,黃河入海流"
                },
                {
                    name:"lisi",
                    id:'2',
                    time:new Date().getUTCDate(),
                    content:"會(huì)當(dāng)凌絕頂,一覽眾山小"
                },
                {
                    name:"wangwu",
                    id:'3',
                    time:new Date().getUTCDate(),
                    content:"大漠孤煙直,長(zhǎng)河落日?qǐng)A"
                }
            ]
        },
        methods:{
            handle1(e){
                console.log("event 事件觸發(fā),參數(shù)為:",e);
            }
        }
    })
</script>

Vue中emit的使用

vue子傳父參數(shù)的方法共有兩種 

1、子組件通過(guò)emit傳輸 

2、通過(guò)自定義組件傳輸

下列優(yōu)先講解下其emit的傳輸方法 

在父組件中

(1)首先需要定義其改變的函數(shù),一般emit多用于點(diǎn)擊事件,例如我目前所在地的名稱是北京,我想通過(guò)子組件的點(diǎn)擊,導(dǎo)致我的名稱發(fā)生其改變

(2)定義其data屬性存儲(chǔ)器數(shù)據(jù)

<template>
? <div class="hello">
? ? <h2>我是父組件,我需要建立一些參數(shù)</h2>
? ? <h3>我所在地的名稱是:{{ msg }}</h3>
? ? <span><mHome @showCityName="updateCityName" /></span>
? </div>
</template>
<script>
import mHome from "@/views/Home.vue";
export default {
? components: {
? ? mHome,
? },
? data() {
? ? return {
? ? ? msg: "北京",
? ? };
? },
? methods: {
? ? updateCityName(data) {
? ? ? this.msg = data.msg;
? ? },
? },
};
</script>

在子組件中

(1)定義其點(diǎn)擊方法,并且傳入其需要改變的值,例如我所改變的是城市為武漢

(2)定義emit函數(shù),并且傳輸?shù)膕howCityName需與父組件的點(diǎn)擊事件名稱保持一致才行

(3)通過(guò)data進(jìn)行傳參處理即可

<template>
  <div class="home">
    <h1>我是子組件</h1>
    <h2 @click="change('武漢')">測(cè)試其emit組件</h2>
  </div>
</template>
<script>
// @ is an alias to /src
export default {
  methods: {
    change(val) {
      let data = {
        msg: val,
      };
      this.$emit("showCityName", data);
    },
  },
};
</script>

效果圖

總結(jié):

(1)需要在其子組件中定義emit事件

(2)emit的傳遞子組件和父組件的函數(shù)名需要保持一致

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue + Element UI圖片上傳控件使用詳解

    Vue + Element UI圖片上傳控件使用詳解

    這篇文章主要為大家詳細(xì)介紹了Vue + Element UI圖片上傳控件的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • vue中PC端地址跳轉(zhuǎn)移動(dòng)端的操作方法

    vue中PC端地址跳轉(zhuǎn)移動(dòng)端的操作方法

    最近小編接到一個(gè)項(xiàng)目pc端和移動(dòng)端是兩個(gè)獨(dú)立的項(xiàng)目,兩個(gè)項(xiàng)目項(xiàng)目中的內(nèi)容基本相同,鏈接組合的方式都有規(guī)律可循,接到的需求便是在移動(dòng)端訪問pc端的URL連接時(shí),重定向至移動(dòng)端對(duì)應(yīng)頁(yè)面,下面小編給大家分享實(shí)現(xiàn)過(guò)程,一起看看吧
    2021-11-11
  • Element-ui樹形控件el-tree自定義增刪改和局部刷新及懶加載操作

    Element-ui樹形控件el-tree自定義增刪改和局部刷新及懶加載操作

    這篇文章主要介紹了Element-ui樹形控件el-tree自定義增刪改和局部刷新及懶加載操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • 基于Vue實(shí)現(xiàn)拖拽功能

    基于Vue實(shí)現(xiàn)拖拽功能

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)拖拽功能,拖動(dòng)方塊進(jìn)行移動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • 使用electron-builder將項(xiàng)目打包成桌面程序的詳細(xì)教程

    使用electron-builder將項(xiàng)目打包成桌面程序的詳細(xì)教程

    這篇文章主要介紹了使用electron-builder把web端的項(xiàng)目打包生成桌面程序,并可安裝程序,文中通過(guò)代碼示例和圖文結(jié)合的方式給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2024-08-08
  • vue 使用 canvas 實(shí)現(xiàn)手寫電子簽名

    vue 使用 canvas 實(shí)現(xiàn)手寫電子簽名

    這篇文章主要介紹了vue 使用 canvas 實(shí)現(xiàn)手寫電子簽名功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • VUE前端打包到測(cè)試環(huán)境的解決方法

    VUE前端打包到測(cè)試環(huán)境的解決方法

    這篇文章主要介紹了若依VUE前端打包到測(cè)試環(huán)境,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • 使用 Vue.js 仿百度搜索框的實(shí)例代碼

    使用 Vue.js 仿百度搜索框的實(shí)例代碼

    本篇文章主要介紹了使用 Vue.js 仿百度搜索框的實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • Element el-menu中NavMenu的用法

    Element el-menu中NavMenu的用法

    今天封裝一個(gè)導(dǎo)航欄的組件,使用的Element的NavMenu組件。遇到一個(gè)問題,本文主要介紹了Element el-menu中NavMenu的用法,感興趣的可以了解一下
    2023-04-04
  • vue3中使用scss加上scoped導(dǎo)致樣式失效問題

    vue3中使用scss加上scoped導(dǎo)致樣式失效問題

    這篇文章主要介紹了vue3中使用scss加上scoped導(dǎo)致樣式失效問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評(píng)論