IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue中解读关于this.$emit()的用法 -> 正文阅读

[JavaScript知识库]Vue中解读关于this.$emit()的用法

解读this.$emit()的用法,小案例

this.$emit()主要用于子组件像父组件传值,接下来已模拟删除数据为例来进行深度刨析,话不多说上代码。

首先定义组件和插槽

//slot:定义插槽
   Vue.component("today",{
            template: '<div>' +
                '<div>' +
                '<slot name="today-title"></slot>' +
                '<ul>' +
                '<slot name="today-items"></slot>' +
                '</ul>' +
                '</div>'
   });
   Vue.component("today-title",{
       props:['title'],
       template: '<div>{{title}}</div>'
   })
    Vue.component("today-items",{
        props: ['item'],
        //只能绑定当前的组件方法
        template: '<li>{{item}}</li>',

    })

将定义好的组件放在视图层

<div id="app">
<today>

    <today-title slot="today-title" > </today-title>
    <today-items slot="today-items"  ></today-items>
</today>

</div>

在定义一个对象并给组件赋值

  var vm = new Vue({
        el:"#app",
        data:{
            title:"如下所示",
            todayitems:['zx','d2','21']
        },
      
    })

通过双向绑定将组件与值绑定起来(v-for中需要给每个元素一个索引,因为此案例需要根据索引来删除元素,下面会具体描述)

<div id="app">
<today>
    
    <today-title slot="today-title" :title="title"> </today-title>
    <today-items slot="today-items" v-for="(item,index) in todayitems"  :item="item" ></today-items>
</today>

</div>

在组件里定义一个删除事件。

   Vue.component("today-items",{
        props: ['item'],
        //只能绑定当前的组件方法
        template: '<li>{{item}}   <button @click="remove">删除</button></li>',
        methods:{
            remove:function () {
                //this.$emit 自定义事件分发
                 this.$emit('remove')
            }
        }
    })

然后在已经定义的vue对象里定义一个删除方法(通过元素的index来进行删除且一次只删除一个)

 var vm = new Vue({
        el:"#app",
        data:{
            title:"666",
            todayitems:['zx','d2','21']
        },
        methods:{
            removeitems:function (index) {
                console.log("删除了"+this.todayitems[index]+"OK");
                this.todayitems.splice(index,1);//一次删除一个
            }
        }
    })

在视图层里通过v-on来进行绑定,

   <today-title slot="today-title" :title="title"> </today-title>
    <today-items slot="today-items" v-for="(item,index) in todayitems" v-on:remove="removeitems(index)"
                :item="item" ></today-items>

效果如下
在这里插入图片描述
点击删除
在这里插入图片描述
根据控制台看出我们已经成功删除了’zx’这个元素也就是第一个元素。

下面我们来对代码进行刨析:
在这里插入图片描述
我们在这里定义了一个按钮和remove事件,通过@click绑定,我们通过this.$emit(‘remove’)来实现子组件与父组件之间的交互,此时我们需要一个具体的删除方法,所以在定义的vue对象里再定义一个具体的实现方法来删除元素,这里用到了,splice方法(具体使用这里先不做详细分析)。
在这里插入图片描述
v-on中左边绑定的是子组件里所定义的事件,右边绑定的是我们具体实现的方法且方法中传输index参数。

稍微梳理一下逻辑关系

  1. 首先我们需要在已经显示的数据里实现删除方法;
  2. 我们在定义的插槽里定义个删除按钮,这就相当于给每个元素后面都加了删除按钮;
  3. 在组件里定义一个事件通过删除来触发此事件,然后我们需要删除元素,
  4. 可是元素在哪呢?在我们之前定义好的对象里,所以我们在对象里定义个删除方法;
  5. 这样大体就是:我们通过子组件里的删除事件来触发vue对象里的删除方法,但是无法直接操作,所以我们通过在父组件里的v-on来搭建起一座桥梁,父组件通过v-on来监听子组件触发的事件,再传给vue实例化对象里的方法一个index进而实现模拟删除。

以上为个人学习的小总结,喜欢且对您有帮助的请您支持一下。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-26 12:02:06  更:2021-08-26 12:03:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 13:13:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码