小程序 behaviors

作者:zhuge···预计阅读 5 分钟·1,137 阅读·0 评论
小程序 behaviors

  每个behavior可以包含一组属性、数据、生命周期函数和方法。组件引用它时,它的属性、数据和方法会被合并到组件中。   每个组件可以引用多个behavior,behavior也可以引用其它behavior。 my-behavior.js

module.exports=Behavior({
	data:{
		username:‘zhuge‘
	},
	properties:
		{},
	methods:
		{}
})

使用到的组件wxml

<view>在Behavior中定义的username是{{username}}</view>

使用到的组件js

const myBehavior=require(“../../behaviors/my-behavior“)
Component({
behaviors:[myBehavior],
…

  同名字段的覆盖和组合规则   组件和它引用的 behavior中可以包含同名的字段,此时可以参考如下3种同名时的处理规则: ①同名的数据字段(data) ②同名的属性(properties)或方法(methods) ③同名的生命周期函数   组件和它引用的 behavior 中可以包含同名的字段,对这些字段的处理方法如下:   如果有同名的属性 (properties) 或方法 (methods):   若组件本身有这个属性或方法,则组件的属性或方法会覆盖 behavior 中的同名属性或方法;   若组件本身无这个属性或方法,则在组件的 behaviors 字段中定义靠后的 behavior 的属性或方法会覆盖靠前的同名属性或方法;   在 2 的基础上,若存在嵌套引用 behavior 的情况,则规则为:父 behavior 覆盖 子 behavior 中的同名属性或方法。   如果有同名的数据字段 (data):   若同名的数据字段都是对象类型,会进行对象合并;   其余情况会进行数据覆盖,覆盖规则为:组件 > 父 behavior > 子 behavior 、 靠后的 behavior > 靠前的 behavior。(优先级高的覆盖优先级低的,最大的为优先级最高)   生命周期函数不会相互覆盖,而是在对应触发时机被逐个调用:   对于不同的生命周期函数之间,遵循组件生命周期函数的执行顺序;   对于同种生命周期函数,遵循如下规则:

  1. behavior 优先于组件执行;
  2. 子 behavior 优先于 父 behavior 执行;
  3. 靠前的 behavior 优先于 靠后的 behavior 执行;
  4. 如果同一个 behavior 被一个组件多次引用,它定义的生命周期函数只会被执行一次。

相关文章

评论

加载中...