博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微信小程序自定义事件
阅读量:6721 次
发布时间:2019-06-25

本文共 2052 字,大约阅读时间需要 6 分钟。

前文

在上一章节中我是给大家介绍了一下微信小程序的自定义组件,这一章我要说说小程序的另一个强大功能--自定义事件

什么是自定义事件呢,你可以简单的理解为:在触发子组件的一些事件的时候,同时也能触发父组件对应的事件并对父组件中的某些数据进行修改的事件就是自定义事件.

有翻阅学习过小程序官方给出的自定义组件教程的小伙们一定会有和我一样想爆粗口的冲动...

因为上面说的真的有点乱...

不过没事,今天在这里博主会详细的讲解讲解微信小程序的自定义事件.

案例结构

首先,我还是会以案例的形式向大家讲解(这样也能方便大家更好的理解)

简单介绍一下案例项目的内容(以上一章自定义组件的案例为基础)
项目名称:component
自定义子组件cpt
父组件:logs

component1.png

在子组件cpt中有一个按钮,按钮上显示的是当前这按钮组件存储的数值counter.

父组件logs引用三个cpt子组件,在父组件有它自己的第一个变量total.

每点击一次不同的按钮都让按钮上的数值不同大小的增加,

同时total变量记录的是三个按钮的数值总和,如图:

logs.wxml.png

编写子组件

cpt.wxml

复制代码

子组件cpt中有一个按钮,按钮添加点击事件_incrementCounter,同时按钮内容显示的是其数值counter

cpt.js

Component({  properties: {    // 这里定义了num属性,属性值可以在组件使用时指定    num: {          // num定义的就是点击每个按钮分别增加的数值,可以在调用组件的时候进行更改      type: Number,      value: 1    }  },  data: {    // 这里是一些组件内部数据    counter: 0      // counter定义的是每个按钮上的数值  },  methods: {    // 这里是一个自定义方法,每次点击按钮增加对应的数值    _incrementCounter (e) {      let num = this.data.num      this.setData({        counter: this.data.counter + num      })     // 微信小程序中是通过triggerEvent来给父组件传递信息的      this.triggerEvent('increment', {num: num})  // 将num通过参数的形式传递给父组件    }  }})复制代码

编写父组件

子组件编写完之后,就可以在父组件logs中引用了,并且给它设定自定义事件

(别忘了在父组件的.json文件中进行引用哟)
logs.json

{  "navigationBarTitleText": "查看启动日志",  "usingComponents": {    "component-tag-name": "../components/cpt/cpt"  }}复制代码

logs.wxml

三个按钮总和: {
{total}}
复制代码

这里有一个坑要重点提一下,在官方给出的在父组件中调用子组件时,给其添加绑定事件使用的是bind:increment的形式,但是亲试之后,还是得用bindincrement的这种写法才有用.这里的increment就是你在定义子组件时通过triggerEvent传递过来的事件名.

logs.js

Page({  data: {    logs: [],    total: 0,  // 父组件中的数据total用以记录三个按钮总和  },  incrementTotal (e) {    // 定义父组件的    console.log(e.detail)    // 通过e.detail获取点击的那个对象    var num = e.detail.num    this.setData({      total: this.data.total + e.detail.num    })  },})复制代码

分别点击三个按钮时可以看到数值上都有变化的,并且控制台输出的e.detail中也有对应的num属性.

result.png

后语

通过一个简单的小案例,小程序中的自定义事件在这里就介绍完了,学过vue.js的小伙会发现怎么感觉又学了一遍vue.js o(╥﹏╥)o 其实个人认为官方文档写的还是不错的,想学习小程序的同学也可以按着官方文档上的说明进行学习.

转载于:https://juejin.im/post/5a0a6f4e51882554bd5092a6

你可能感兴趣的文章
jquey动画效果
查看>>
计算 $s=1+(1+2)+(1+2+3)+\cdots+(1+2+3+\cdots+n)$
查看>>
《解析几何》吕林根,徐子道第四版 习题 1.4.7,1.4.8,1.4.9
查看>>
ruby Logger日志
查看>>
【应用】浮点数四则运算器 Part3:运算模块的编写
查看>>
puppet使用 apache passsenger 作为前端 (debian)
查看>>
IDA*
查看>>
双机调试和windbg的命令
查看>>
20155229《网络对抗技术》Exp8:Web基础
查看>>
MVC中用js写入的button按钮单击事件失效问题
查看>>
POJO与javabean的区别
查看>>
数据结构与算法设计--树的镜像
查看>>
Oracle常用的性能诊断语句
查看>>
Shell命令-文件及内容处理之more、less
查看>>
实验5 数独游戏界面设计
查看>>
linux 中的vim的配置文件
查看>>
深入浅出node(3) 异步I/O
查看>>
iOS,plist文件、pch文件,工程设置,小知识点
查看>>
CentOS7配置IP和网络问题排查
查看>>
java Multiple Contexts have a path of ""
查看>>