微信小程序开发之自定义事件
凌雪 2018-08-24 来源 :网络 阅读 2302 评论 0

摘要:本文将带你了解微信小程序开发之自定义事件,希望本文对大家学微信有所帮助

本文将带你了解微信小程序开发之自定义事件,希望本文对大家学微信有所帮助


在上一章节中我是给大家介绍了一下微信小程序的自定义组件,这一章我要说说小程序的另一个强大功能--自定义事
      什么是自定义事件呢,你可以简单的理解为:在触发子组件的一些事件的时候,同时也能触发父组件对应的事件并对父组件中的某些数据进行修改的事件就是自定义事件.
    有翻阅学习过小程序官方给出的自定义组件教程的小伙们一定会有和我一样想爆粗口的冲动...
    因为上面说的真的有点乱...
    不过没事,今天在这里博主会详细的讲解讲解微信小程序的自定义事件.
      案例结构首先,我还是会以案例的形式向大家讲解(这样也能方便大家更好的理解)简单介绍一下案例项目的内容(以上一章自定义组件的案例为基础)项目名称:component自定义子组件cpt父组件:logs
    component1.png
    在子组件cpt中有一个按钮,按钮上显示的是当前这按钮组件存储的数值counter.
    父组件logs引用三个cpt子组件,在父组件有它自己的第一个变量total.
    每点击一次不同的按钮都让按钮上的数值不同大小的增加,
    同时total变量记录的是三个按钮的数值总和,如图:
    logs.wxml.png
    编写子组件cpt.wxml
   
    "inner">
        "_incrementCounter">{{counter}}
    子组件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
   
    "container log-list">
     
       三个按钮总和: {{total}}
      "incrementTotal"   num="2">
      "incrementTotal"   num="3">
      "incrementTotal"   num="5">
      这里有一个坑要重点提一下,在官方给出的在父组件中调用子组件时,给其添加绑定事件使用的是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    其实个人认为官方文档写的还是不错的,想学习小程序的同学也可以按着官方文档上的说明进行学习.    

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之微信频道!

本文由 @凌雪 发布于职坐标。未经许可,禁止转载。
喜欢 | 2 不喜欢 | 2
看完这篇文章有何感觉?已经有4人表态,50%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程