Vue自定义事件内容分发的原理及代码是什么
Admin 2022-07-07 群英技术资讯 517 次浏览
1、小伙伴们这个理解起来有点复杂,希望仔细看里面的原理,自己去敲一遍:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <todo> <xian slot="xian" :title="title"></xian> // 建议从后面往前看,理解为遍历得到的值赋值给v-bind,v-bind的值赋值给props同名的值 // [提醒]v-on:绑定的自定义事件名会自动变成小写,如果有人事件名用了大写,下面this.$emit里仍然是大写,会绑定不上 <yu slot="yu" v-for="(item,index) in items" v-bind:item="item" v-bind:index="index" v-on:remove="deleteItems(index)"></yu> // Vue实例将数据和方法与View层绑定,View层在分发这些数据和方法到下面的组件绑定,View相当于中转了Vue实例的数据和方法交由组件控制 </todo> </div> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script> <script> Vue.component("todo",{ template: '<div>\ <slot name="xian"></slot>\ <ul>\ <slot name="yu"></slot>\ </ul>\ </div>' }); Vue.component("xian",{ props: ['title'], template: '<div>{{title}}</div>' }); Vue.component("yu",{// props是参数名,类似于变量名,可以随便定义,v-bind绑定的是变量,是数据,是定义的变量 props: ['item','index'], // 只能绑定当前组件的方法 template: '<li>{{index}}---->{{item}}<button @click="remove">delete</button></li>', methods: { remove: function (index) { // this.$emit 自定义事件分发 // 【注意】this.$emit('事件名')这个事件名要使用kebab-case(短横线命名)方式,不要写成camelCased (驼峰式); this.$emit('remove',index); } } }); var vm = new Vue({ el: "#app", data: { title: "作者", items: ['咸鱼翻身1','咸鱼翻身2','咸鱼翻身3'] }, methods: { deleteItems: function (index) { console.log("您删除了"+this.items[index]); this.items.splice(index,1); } } }); </script> </body> </html>
运行结果:
当我们点击删除就能删除任意的作者名字,这里我点击删除第二个,显示结果如下:
2、这里有一个图供大家理解:
理解大概是这样 组件和实例之间方法不能互调 而要删除的节点属于实例的属性 所以通过事件分发让组件中定义的方法转向实例中定义的方法 然后删除节点
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在jquery中,可以使用hasClass()方法来判断是否有某个class,该方法的作用就是检查被选元素是否包含指定的class,语法“$(selector).hasClass(classname)”。
JS怎样实现移动端的拖动效果?移动端的拖动元素的效果想必大家应该都很熟悉,那么这个效果是怎样做的呢?下面我们就来看看用JS实现移动端拖动元素的具体代码。
JavaScript实现乘和加的方法:1、通过function创建add和take函数,并设置两个参数;2、设置相加和相乘的数学公式;3、输入参数并在浏览器中输出计算结果即可。
怎样用JS实现复选框的全选功能?复选框的全选功能便于多选操作,也是比较实用的一个功能,对此这篇文章就给大家分享JS实现复选框的全选的代码,感兴趣的朋友就接着往下看吧。
方法:1、给按钮元素绑定click点击事件,指定事件处理函数;2、在处理函数中利用“$(元素)”语句匹配元素对象;3、利用“:eq()”和remove()方法删除当前行,语法为“元素对象.eq(位置值).remove()”。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008