全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解Vue2.0之去掉组件click事件的native修饰

这个是在组件开发中遇到的问题,当时我在编写button的组件,模板是这样的:

<template>
 <button class="disable-hover button ion-button"
     :class="[modeClass,typeClass,shapeClass,sizeClass,colorClass,roleClass,strongClass]">
  <span class="button-inner">
   <slot></slot>
  </span>
  <div class="button-effect"></div>
 </button>
</template>

使用是这样子的:

<ion-button @click.native="primary()" color="primary">primary</ion-button>

根据Vue2.0官方文档关于父子组件通讯的原则,父组件通过prop传递数据给子组件,子组件触发事件给父组件。但父组件想在子组件上监听自己的click的话,需要加上native修饰符,故写法就像上面这样。

好吧,处女座的毛病又来了。像button这样常用的组件如果加上native的话是感觉很突兀的。虽然组件设计有自身的考虑,因此我想将click的native去掉,思路如下:

  1. 子组件监听父组件给的click事件,
  2. 子组件内部处理click事件然后向外发送click事件:$emit("click".fn)

改造后的代码如下(亲测可用):

<template>
 <button class="disable-hover button ion-button" @click="_click"
     :class="[modeClass,typeClass,shapeClass,sizeClass,colorClass,roleClass,strongClass]">
  <span class="button-inner">
   <slot></slot>
  </span>
  <div class="button-effect"></div>
 </button>
</template>

<script type="text/babel">
export default{
  ....
  ....
  methods: {
   _click: function () {
    this.$emit('click', function () {
     alert('inner')
    })
   }
  }
}
</script>

父组件中这样使用:

<ion-button @click="primary()" color="primary">primary</ion-button>

也许读者能看出来,我正在参照IONIC2.X的组件API写Vue2.0的功能组件,目前只完成了:ActionSheet、Button、Icon、Alert、Toast这几个,一边看IONIC源码,一边将思路总结写成Vue代码,也就是花点时间。积累自己的组件库希望以后能开发快点。

现在项目地址在这里,前期以实现功能为主,不建议用在生产环境,读读代码实现思路就好,中文备注都做好了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue  # click.native  # vue2  # click  # native  # vue组件添加事件@click.native操作  # vue键盘事件点击事件加native操作  # 详解Vue.js中.native修饰符  # vue中引入mousewheel事件及兼容性处理方式  # 自己的  # 是在  # 在这里  # 我在  # 好了  # 就像  # 是这样  # 就好  # 好吧  # 能看  # 向外  # 这几个  # 这样子  # 用在  # 都做  # 处女座  # 边看  # 大家多多  # 想将  # 花点 


相关文章: 电商平台网站制作流程,电商网站如何制作?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何在万网自助建站平台快速创建网站?  免费网站制作appp,免费制作app哪个平台好?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  如何通过.red域名打造高辨识度品牌网站?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  nginx修改上传文件大小限制的方法  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  如何用西部建站助手快速创建专业网站?  如何在阿里云ECS服务器部署织梦CMS网站?  如何高效搭建专业期货交易平台网站?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  如何设置并定期更换建站之星安全管理员密码?  定制建站流程步骤详解:一站式方案设计与开发指南  大连 网站制作,大连天途有线官网?  jQuery 常见小例汇总  实现虚拟支付需哪些建站技术支撑?  青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?  招商网站制作流程,网站招商广告语?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  h5在线制作网站电脑版下载,h5网页制作软件?  建站主机空间推荐 高性价比配置与快速部署方案解析  南平网站制作公司,2025年南平市事业单位报名时间?  如何通过VPS搭建网站快速盈利?  建站之星备案是否影响网站上线时间?  如何在阿里云虚拟服务器快速搭建网站?  如何高效配置香港服务器实现快速建站?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  香港服务器WordPress建站指南:SEO优化与高效部署策略  Python文件管理规范_工程实践说明【指导】  孙琪峥织梦建站教程如何优化数据库安全?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  如何快速选择适合个人网站的云服务器配置?  开源网站制作软件,开源网站什么意思?  存储型VPS适合搭建中小型网站吗?  网站网页制作专业公司,怎样制作自己的网页?  建站之星展会模版如何一键下载生成?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  css网站制作参考文献有哪些,易聊怎么注册?  如何在云主机快速搭建网站站点?  如何正确选择百度移动适配建站域名?  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  建站之星安装后如何自定义网站颜色与字体?  大连网站制作公司哪家好一点,大连买房网站哪个好?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  制作网页的网站有哪些,电脑上怎么做网页?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。