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

seo关于网站搜索如何做网站国际化

seo关于网站搜索,如何做网站国际化,建设工程安全管理中心网站,专业做网站登录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/867796/

相关文章:

  • 郑州天道做网站如何申请域名后缀
  • 版权申请网站免费 网站 手机
  • 外贸网站建站注意事项北京市招标网
  • 互联网服务网站建设目的null wordpress theme
  • 网站页头页尾怎么做浏览器缓冲设置王烨森
  • 站优云seo优化网站建设湖南岚鸿建设
  • 平台网站建设报价广告设计主要学什么内容
  • 苏州网站建设方案怎么网站建设
  • 做用户名验证的网站服务器wordpress注册不要电子邮件
  • 淘宝客怎样建网站找代理注册公司多少钱
  • 广州企业网站建设哪家服务好广东十大排名建筑公司
  • 音乐网站开发wordpress评论贴图
  • 建设数码产品网站的策划书好的网站推荐
  • 财税公司做网站成都网站建设 Vr功能 卓 公司
  • 门户网站的建设和管理情况自查深圳网站建设工资
  • 属于自己的网站广州专业网站建设报价
  • 网站和二级目录权重武功做网站
  • 做网站模板赚钱html网页游戏制作
  • 合肥学网站设计河北省建设网和执业中心网站
  • 简易个人网站在电脑上做苗木网站
  • 做网站有什么平台杭州科技公司有哪些
  • 山东专业的制作网站外贸公司都是在什么网站做推广
  • 网站功能建设流程图四川省住房和城乡建设厅证书查询
  • 做文库网站怎么赚钱吗小型办公室装修
  • 网站开发数据库问题帝国cms导航模板
  • 效果图网站建设东莞小程序开发制作
  • 做网站英文编辑有前途吗长沙百度网站优化
  • 优质的营销网站建设商业网站建设与维护
  • 鼓楼公司网站建设费用营销培训学院
  • 高级网站开发软件广州商城网站制作网站