微信小程序-behaviors

简介: 什么是 behaviors• behaviors 是用于组件间代码共享的特性,类似于一些编程语言中的 “mixins”• 每个 behavior 可以包含一组属性,数据,生命周期函数和方法,组件引用它时,它的属性,数据和方法会被合并到组件中,生命周期函数也会在对应时机被调用。每个组件可以引用多个 behavior,behavior 也可以引用其它 behavior。

什么是 behaviors

  • behaviors 是用于组件间代码共享的特性,类似于一些编程语言中的 “mixins”
  • 每个 behavior 可以包含一组属性,数据,生命周期函数和方法,组件引用它时,它的属性,数据和方法会被合并到组件中,生命周期函数也会在对应时机被调用。每个组件可以引用多个 behavior,behavior 也可以引用其它 behavior。


?> 大白话:用来封装多个组件中相同的冗余代码


新建两个组件,一个叫 c-test,一个为 c-demo,两个组件的内容大致就是有一个 counter 变量,每一个组件中有两个按钮,一个按钮点击对 counter 进行增加,一个对 counter 进行减少,然后我们可以将这种冗余的代码进行使用 behavior 进行封装复用,我这里就没有用案例去引出 behavior 的方式进行讲解了,我只是体现这一下 behavior 这个知识点的运用。


?> myBehaviors.js

// myBehavior.js
export const counterBehavior = Behavior({
  data: {
    counter: 0
  },
  methods: {
    increase() {
      this.setData({counter: this.data.counter + 1});
    },
    decrease() {
      this.setData({counter: this.data.counter - 1});
    }
  }
});


?> c-test

// components/c-test/c-test.js
import {counterBehavior} from "../../behaviors/myBehaviors";
Component({
  behaviors: [counterBehavior]
})


<!--components/c-test/c-test.wxml-->
<text>{{counter}}</text>
<button bindtap="increase">我是c-test按钮 increase</button>
<button bindtap="decrease">我是c-test按钮 decrease</button>


?> c-demo

// components/c-demo/c-demo.js
import {counterBehavior} from "../../behaviors/myBehaviors";
Component({
  behaviors: [counterBehavior]
})


<!--components/c-demo/c-demo.wxml-->
<text>{{counter}}</text>
<button bindtap="increase">我是c-demo按钮 increase</button>
<button bindtap="decrease">我是c-demo按钮 decrease</button>


?> index

<!--index.wxml-->
<myTest />
<view/>
<myDemo />


{
  "usingComponents": {
    "myTest": "/components/c-test/c-test",
    "myDemo": "/components/c-demo/c-demo"
  }
}


参考文章


官方文档:https://developers.weixin.qq.com/miniprogram/dev/reference/api/Behavior.html


!> 最终 behavior 是将中的内容分别复制了一份放到了对应使用的组件当中

目录
相关文章
|
21天前
|
小程序 JavaScript
【微信小程序】-- 自定义组件 - behaviors(三十九)
【微信小程序】-- 自定义组件 - behaviors(三十九)
|
小程序 JavaScript
微信小程序开发入门与实战(Behaviors使用)
微信小程序开发入门与实战(Behaviors使用)
微信小程序开发入门与实战(Behaviors使用)
|
小程序
微信小程序:Error: Behaviors should be constructed with Behavior()
微信小程序:Error: Behaviors should be constructed with Behavior()
334 0
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的水果商城附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的水果商城附带文章和源代码部署视频讲解等
20 10
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的汇美食电子商城附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的汇美食电子商城附带文章和源代码部署视频讲解等
20 9
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的在线学习系统附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的在线学习系统附带文章和源代码部署视频讲解等
22 10
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的学报稿件管理系统附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的学报稿件管理系统附带文章和源代码部署视频讲解等
18 9
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的课程辅导网站附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的课程辅导网站附带文章和源代码部署视频讲解等
17 8
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的高校实验室信息化综合管理平台附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的高校实验室信息化综合管理平台附带文章和源代码部署视频讲解等
20 6
|
1天前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的医院管理系统附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的医院管理系统附带文章和源代码部署视频讲解等
15 4