首先简单回顾下组件事件及组件的复用

demo1:按钮事件

    <div class="button_area">
<button-area></button-area>
<button-area></button-area>
<button-area></button-area>
</div>
<script type="text/javascript">
// 1、注册组件
Vue.component('button-area',{
data:function(){
return {
count:
}
},
template:`<button v-on:click="count++">您点击了{{count}}次</button>`
})
// 2、实例化,构建组件模板
new Vue({
el:".button_area"
})
</script>

demo2:监听子组件事件

在开发 <event-area> 组件时,它的一些功能可能要求我们和父级组件进行沟通。例如我们可能会引入一个可访问性的功能来放大博文的字号,同时让页面的其它部分保持默认的字号。在其父组件中,可以通过添加一个 blogFontSize数据属性来支持这个功能:

        new Vue({
el:".event_area",
data:{
blogs:[
{id:,title:"文章标题1",content:"文章内容1..."},
{id:,title:"文章标题2",content:"文章内容2..."},
{id:,title:"文章标题3",content:"文章内容3..."},
],
blogFontSize:
}
})

它可以在模板中用来控制所有博文的字号:

v-bind:style="{fontSize:blogFontSize+'em'}"

接下来添加按钮,点击放大字体。当点击这个按钮时,需要告诉父级组件放大所有博文的文本。Vue 实例提供了一个自定义事件的系统来解决这个问题。父级组件可以像处理 native DOM (本地DOM)事件一样通过 v-on 监听子组件实例的任意事件:

v-on:add-size="blogFontSize+=0.1"

子组件可以通过调用内建的 $emit 方法 并传入事件名称来触发这个事件

        Vue.component('event-area',{
props:['blog'],
template:`<div class="blog_show_area">
<p>标题:{{blog.title}}</p>
<p>内容:{{blog.content}}</p>
<button v-on:click="$emit('add-size')">放大字体</button>
</div>`
});

有了这个 v-on:add-size="blogFontSize += 0.1" 监听器,父级组件就会接收该事件并更新 blogFontSize 的值。完整代码

    <div class="event_area">
<event-area
v-for="blog in blogs"
v-bind:key="blog.id"
v-bind:blog="blog"
v-bind:style="{fontSize:blogFontSize+'em'}"
v-on:add-size="blogFontSize+=0.1"
></event-area>
</div>
<style type="text/css">
.blog_show_area{
padding: 20px;
background-color: rgba(,,,.);
border: 1px solid red;
margin: 10px;
}
</style>
Vue.component('event-area',{
props:['blog'],
template:`<div class="blog_show_area">
<p>标题:{{blog.title}}</p>
<p>内容:{{blog.content}}</p>
<button v-on:click="$emit('add-size')">放大字体</button>
</div>`
});
new Vue({
el:".event_area",
data:{
blogs:[
{id:,title:"文章标题1",content:"文章内容1..."},
{id:,title:"文章标题2",content:"文章内容2..."},
{id:,title:"文章标题3",content:"文章内容3..."},
],
blogFontSize:
}
})

(1)事件名

不同于组件和 prop,事件名不存在任何自动化的大小写转换。而是触发的事件名需要完全匹配监听这个事件所用的名称。举个例子,如果触发一个 addSize名字的事件:

组件template里:
<button v-on:click="$emit('addSize')">放大字体</button>

则监听这个名字的 kebab-case (短横线隔开式)版本是不会有任何效果。

        <event-area
v-for="blog in blogs"
v-bind:key="blog.id"
v-bind:blog="blog"
v-bind:style="{fontSize:blogFontSize+'em'}"
v-on:add-size="blogFontSize+=0.1"
></event-area>
<!--没有效果-->

不同于组件和 prop,事件名不会被用作一个 JavaScript 变量名或属性名,所以就没有理由使用 camelCase 或 PascalCase 了。并且 v-on 事件监听器在 DOM 模板中会被自动转换为全小写 (因为 HTML 是大小写不敏感的),所以 v-on:myEvent 将会变成 v-on:myevent——导致 myEvent 不可能被监听到。因此,推荐始终使用 kebab-case 的事件名。

测试:这里使用PascalCase (小驼峰式)版本命名调用

父级组件:
v-on:addSize="blogFontSize+=0.1"
子级模板中:
<button v-on:click="$emit('addSize')">放大字体</button>

此时,控制台输出警告

翻译:

 请注意,HTML属性不区分大小写,并且在使用in-DOM模板时不能使用v-on来侦听camelCase事件。 您应该使用“add-size”而不是“addSize”。

(2)自定义组件的v-model(待验证

(3)将原生事件绑定到组件(待验证

(4).sync修饰符(待验证

.

.sync 修饰符

vue组件---自定义事件的更多相关文章

  1. Vue基础-自定义事件的表单输入组件、自定义组件的 v-model

    Vue 测试版本:Vue.js v2.5.13 学习 Vue 的自定义事件的表单输入组件,觉得文档讲的不太细致,所以这里再细化一下: 如果不用 v-model,代码应该是这样: <myinput ...

  2. vue组件添加事件@click.native

    1,给vue组件绑定事件时候,必须加上native ,否则会认为监听的是来自Item组件自定义的事件 2,等同于在子组件中:  子组件内部处理click事件然后向外发送click事件:$emit(&q ...

  3. Vue3手册译稿 - 深入组件 - 自定义事件

    本章节需要掌握组件基础 emit我译成发射,觉得发射这个词比较形象的形容将子组件事件发射出来的一个动作. 事件名 像组件和props,事件名也会进行自动转换,如果你在子组件里发射一个驼峰命名的事件,你 ...

  4. vue-gemini-scrollbar(vue组件-自定义滚动条)

    vue-gemini-scrollbar(vue组件-自定义滚动条) https://segmentfault.com/a/1190000013338560

  5. Vue.js 源码分析(十四) 基础篇 组件 自定义事件详解

    我们在开发组件时有时需要和父组件沟通,此时可以用自定义事件来实现 组件的事件分为自定义事件和原生事件,前者用于子组件给父组件发送消息的,后者用于在组件的根元素上直接监听一个原生事件,区别就是绑定原生事 ...

  6. Vue学习之--------组件自定义事件(绑定、解绑)(2022/8/21)

    文章目录 1.基础知识 2.代码实例 2.1 App.vue 2.2 school.vue 2.3 student.vue 3.测试效果(略) 4.实际应用(在组件化编码实战三的基础上改进) 4.1 ...

  7. vue.js 自定义事件

    <div id="app"> <h2>{{num}}</h2> <h1>全局组件</h1> <my-compone ...

  8. vue组件原生事件以及路由

    1.组件 组件就是可以扩展HTML元素,封装可重用的HTML代码,可以将组件看作自定义的HTML元素 1.1组件注册 全局注册: 组件注册时,需要给他一个名字,如下: Vue.component('m ...

  9. vue组件之事件

    自定义事件 通过prop属性,父组件可以向子组件传递数据,而子组件的自定义事件就是用来将内部的数据报告给父组件的. <div id="app3"> <my-com ...

随机推荐

  1. MySQL系列:innodb源代码分析之内存管理

    在innodb中实现了自己的内存池系统和内存堆分配系统,在innodb的内存管理系统中,大致分为三个部分:基础的内存块分配管理.内存伙伴分配器和内存堆分配器.innodb定义和实现内存池的主要目的是提 ...

  2. HDU 5773The All-purpose Zero

    The All-purpose Zero Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Oth ...

  3. Error处理: android.media.MediaRecorder.start(Native Method) 报错:start failed: -19【转】

    本文转载自:http://blog.csdn.net/netwalk/article/details/17686993 Error处理: android.media.MediaRecorder.sta ...

  4. flash builder 4.6 下载完成后安装不成功

    从网上下载了一下flash builder 4.6 下载完成后安装不成功,说是有一个安装被挂起,不成安装成功结果从注册表中删除了pendingobject,还是不行,没有办法,从网上搜了一下,发现了大 ...

  5. 用C语言实现websocket服务器

    Websocket Echo Server Demo 背景 嵌入式设备的应用开发大都依靠C语言来完成,我去研究如何用c语言实现websocket服务器也是为了在嵌入式设备中实现一个ip camera的 ...

  6. 微信公众平台appid和appsecret在哪

    1.appid和appsecret是微信公众平台服务号才有的,如果自己家的公众平台不是服务号,需要升级为服务号. 2.登录服务号,登录“服务”条目,“服务中心”如图. 3.点击“自定义菜单”-“开发模 ...

  7. 解决Error for wireless request "Set Mode" (8B06) 问题 (转载)

    转自:http://blog.csdn.net/muge0913/article/details/17062871 在运行以下命令的时候,意外的出错,最后google了下,最终才确定了原因,因为在运行 ...

  8. 安装Git(转载)

    转自:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/00137396287703 ...

  9. hdu 1043 Eight

    欸我一直以为双向bfs是搜完一半再搜另一半呢,妹想到是两个一起搜 然后队列里放的结构体里不能直接存答案,所以做一个邻接表一样的东西,直接指向需要的字符即可 记录状态用康托展开来hash 以及居然是多组 ...

  10. Akka源码分析-Akka-Streams-Materializer(1)

    本博客逐步分析Akka Streams的源码,当然必须循序渐进,且估计会分很多篇,毕竟Akka Streams还是比较复杂的. implicit val system = ActorSystem(&q ...