当前位置: 首页 > news >正文

网站空间域名续费世界上有几个空间站

网站空间域名续费,世界上有几个空间站,wordpress 翻页电子书,网站网页设计引言1. 自定义事件 除了可以处理原生的DOM事件, v-on指令也可以处理组件内部触发的自定义的事件,调用this.$emit()函数就可以触发一个自定义事件 $emit() 触发事件函数接受一个自定义事件的事件名以及其他任何给事件函数传递的参数. 然后就可以在组件上使用v-on来绑定这个自定义事…

1. 自定义事件

除了可以处理原生的DOM事件, v-on指令也可以处理组件内部触发的自定义的事件,调用this.$emit()函数就可以触发一个自定义事件

$emit() 触发事件函数接受一个自定义事件的事件名以及其他任何给事件函数传递的参数. 然后就可以在组件上使用v-on来绑定这个自定义事件

{methods: {handleClick(){this.clicks++this.$emit("count",this.clicks )}}
}

所以我们就可以利用自定事件来处理子组件触发父组件数据的更改和向父组件传值


2. 子组件触发父组件数据的改变

通过父组件向子组件传值的学习,我们已经知道了Vue是单向下行数据流, 子组件更改props中的数据不会触发父组件数据的改变, 但是由于响应式原理,父组件数据的改变会导致子组件props中值的改变

那么我们怎样才能在子组件中改变显示的结果呢.

思路:

  1. 子组件中没法更改父组件中的数据,那么我们就让父组件自己的函数改自己的数据
  2. 如何在子组件中触发父组件中的函数呢, 就可以通过自定义事件
  3. 子组件在函数中触发自定义事件, 将父组件中更改数据的函数绑定为自定义事件的函数
  4. 然后父组件中的数据一变,因为响应式,所以子组件中的数据会自动改变

示例代码如下:

<div id="app"><!-- 使用组件 --><!-- 3.在子组件中绑定自定义事件, 将父组件的方法绑定为自定义事件的处理函数--><my-component :clicks="clicks" @count="handleParentClick"></my-component></div><!-- 组件模板 -->
<template id="MyComponent"><div>被点击了{{clicks}}次<!-- 1. 子组件通过原生click事件触发子组件自己的函数 --><button @click="handleClick">点击</button></div>
</template><script>//  组件选项对象let MyComponent = {props:["clicks"],template: `#MyComponent`,methods:{handleClick(){// 2.子组件函数中触发自定义事件this.$emit("count")}}}//  实例中注册组件const vm = new Vue({el:"#app",data: {clicks:0},components: {"MyComponent": MyComponent},methods:{handleParentClick(){// 4. 在父组件函数中修改父组件中的数据this.clicks++}}})
</script>

示例结果

子组件通过自定义事件改变父组件数据.png

最后父组件数据一变,子组件显示结果自然变化

我们也知道$emit方法在触发自定义事件的时候,还可以给自定义事件传参, 这样就可以实现子组件向父组件传参


3. 子组件向父组件传参

上一小节,我们是在子组件中通过自定义事件触发父组件中的函数, 在父组件中修改数据,

同样我们也可以在子组件中修改数据,然后将修改后的数据通过自定义事件传参的方式,传递给父组件函数,在父组件函数中直接用子组件传过来修改后的数据直接替换父组件中的数据

示例代码如下:

<div id="app"><!-- 使用组件 --><!-- 3.在子组件中绑定自定义事件, 将父组件的方法绑定为自定义事件的处理函数--><my-component :clicks="clicks" @count="handleParentClick"></my-component>
</div><!-- 组件模板 -->
<template id="MyComponent"><div>被点击了{{clicks}}次<!-- 1. 子组件通过原生click事件触发子组件自己的函数 --><button @click="handleClick">点击</button></div>
</template><script>//  组件选项对象let MyComponent = {props:["clicks"],template: `#MyComponent`,data(){return {count: this.clicks}},methods:{handleClick(){// 2.子子组件函数中触发自定义事件// 2.1 在触发自定义事件的时候向自定事件传参this.count+=2this.$emit("count",this.count)}}}//  实例中注册组件const vm = new Vue({el:"#app",data: {clicks:0},components: {"MyComponent": MyComponent},methods:{handleParentClick(count){// 4. 在父组件函数中修改父组件中的数据// 4.1 接受自定义事件触发时传递的参数console.log(count)this.clicks = count}}})</script>
http://www.yayakq.cn/news/571039/

相关文章:

  • 邵阳网站建设优化为什么要做响应式网站
  • 网站建站多钱推广网站优化seo教程上排名
  • 北京大学学术学风建设网站企业oa办公软件
  • 做个什么类型网站上海网站建设高端
  • 网站建设覀金手指科杰兰州网站搜索排名
  • 马蜂窝网站建设目的成功网站建设案例
  • 国内做免费的视频网站有哪些全屏网站模板
  • 企业网站建设开发公司wordpress 分类目录置顶
  • 锦州做网站的个人官网建设设计
  • 专用车网站建设哪家专业外贸销售是做什么工作的
  • 乐清网站免费的行情软件网站在线使用
  • 湖南湘源建设工程有限公司网站什么网站做电气自动化兼职
  • 众创空间文化建设网站如何生成自己的网站
  • 互助平台网站制作公司网站建设费计入什么科目
  • 闸北做网站wordpress裁剪失败
  • 帮人做彩票网站广告投放就选亿企联盟
  • 湛江网站制作工具平面设计素材网
  • 郑州市公司网站开发设计企业网站建设博客论坛
  • 做一网站困难吗室内设计软件自学
  • 杭州网页模板建站弄一个小程序要多少钱
  • 网站建设在实际工作中的意义自己怎么来建设网站
  • 建设网站地图素材宁波seo优化公司
  • 任丘建设网站制作福安网站定制
  • 网站html代码英语营销型网站建设
  • 青岛大学网站建设厦门专业做优化的公司
  • wordpress 新建分类昆明seo网站
  • 网站设计人员就业要求网页制作教程免费视频
  • 网站登陆口提交网站网站开发制作
  • 制作介绍的网站模板ps制作个人网站首页
  • seo诊断网站免费诊断平台网站系统分析报告