微信小程序 behaviors进阶实现 list 列表优化

behaviors 介绍

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

详细的参数含义和使用请参考 链接: Behavior 参考文档

list Behaviors js文件设置

整体list 请求默认参数以及返回值处理集中在behaviors中 ,抛出相关其他处理函数

函数名用途
afterGetList除去默认拼接list 其他data值的处理
getListError加载错误的其他的处理
beforeGetMore除了是否存在下一页和是否加载中判断外的其他判断
import request from "../utils/http";

module.exports = Behavior({
  behaviors: [],
  properties: {
  },
  data: {
    list: [],
    listLoading: false,
    hasMore: true,
    pageSize: 20,
    pageIndex: 1,
  },
  methods: {
    /**
      * @description: 获取列表数据
      * @param {*} isFirst 是否首次加载
      * @param {*} data 除了分页外其他data
    */
    async getListData({ isFirst = false, url = '', data = {} }) {
      let { listLoading, pageIndex, pageSize, list, hasMore } = this.data;
      //加载中不重新请求
      if (listLoading) return
      if (isFirst) {
        list = [];
        pageIndex = 1;
        this.setData({ list: [], pageIndex: 1 });
      }
      this.setData({ listLoading: true })
      try {
        let result = await request({ url, data: { pageSize, pageIndex, ...data } });
        hasMore = pageSize * pageIndex > result.count ? false : true;
        this.afterGetList && (result = this.afterGetList(result));
        list = list.concat(result.list)
        this.setData({ list, hasMore, listLoading: false });

      } catch (error) {
        this.setData({ listLoading: false })
        this.getListError && this.getListError();
      }
    },
//加载下一页  默认判断是否在加载中,和是否存在下一页,另外判断可放在beforeGetMore 函数中
    getMore() {
      let { listLoading, hasMore, pageIndex } = this.data;
      let checkBeforeData = true
      this.beforeGetMore && (checkBeforeData = this.beforeGetMore());
      if (listLoading || !hasMore || !checkBeforeData) { return }
      this.setData({ pageIndex: pageIndex + 1 })
      this.getList()
    }
  }
})

page 页面对于behaviors 的使用

提示:这里设置的data 能覆盖behaviors文件中设置的初始data

import { DeleteMemberAddress, GetMemberAddressList, UpdateMemberAddress } from "../../../api/user";
var listBehavior = require('../../../behaviors/list')

Page({
  behaviors: [listBehavior],
  data: {},
  onLoad(options) {
    this.getList();
  },
  getList() {
    this.getListData({ isFirst:true, url: GetMemberAddressList });
  },
  //上拉触底,加载下一页
 onReachBottom(){
    this.getMore();
 }
})

behaviors 使用注意组合规则

  • 如果有同名的属性 (properties) 或方法 (methods)
    1. 若组件本身有这个属性或方法,则组件的属性或方法会覆盖 behavior 中的同名属性或方法; 若组件本身无这个属性或方法,则在组件的
    2. behaviors 字段中定义靠后的 behavior 的属性或方法会覆盖靠前的同名属性或方法;
    3. 在 2 的基础上,若存在嵌套引用 behavior 的情况,则规则为:引用者 behavior 覆盖 被引用的 behavior 中的同名属性或方法。
  • 如果有同名的数据字段 (data):
    1. 若同名的数据字段都是对象类型,会进行对象合并
    2. 其余情况会进行数据覆盖,覆盖规则为: 引用者 behavior > 被引用的 behavior 、 靠后的 behavior > 靠前的 behavior。(优先级高的覆盖优先级低的,最大的为优先级最高)
  • 生命周期函数和 observers 不会相互覆盖,而是在对应触发时机被逐个调用:
    1. 对于不同的生命周期函数之间,遵循组件生命周期函数的执行顺序;
    2. 对于同种生命周期函数和同字段 observers ,遵循如下规则:
    - 优先于组件执行;
    - 被引用的 behavior 优先于 引用者 behavior 执行;
    - 靠前的 behavior 优先于 靠后的 behavior 执行;
    4. 如果同一个 behavior 被一个组件多次引用,它定义的生命周期函数和 observers 不会重复执行。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抖音小程序中的behaviors是一种行为的定义方式,可以将一些常用的行为抽象出来,然后在多个组件中复用。通过behaviors,可以在组件中定义一些公共的属性、方法和生命周期函数,然后在需要使用这些行为的组件中引用该behaviors。引用\[1\]中的文档提供了详细的步骤来配置behaviors。在父组件的js文件中,可以定义一个函数,并通过自定义事件的形式传递给子组件\[2\]。在子组件的js文件中,可以通过调用this.triggerEvent()方法将数据发送到父组件\[2\]。在父组件的js文件中,可以通过e.detail获取子组件传递过来的数据\[2\]。此外,可以使用this.selectComponent()方法获取子组件的实例对象,从而直接访问子组件的任意数据和方法\[2\]。在小程序组件中,可以使用data节点定义组件的私有数据,methods节点定义事件处理函数和自定义方法,properties节点定义组件的对外属性\[3\]。data更倾向于存储组件的私有数据,而properties更倾向于存储外界传递到组件中的数据\[3\]。可以使用setData方法修改properties的值\[3\]。此外,小程序组件还支持数据监听器,用于监听和响应属性和数据字段的变化\[3\]。通过定义数据监听器,可以在属性或数据字段发生变化时执行特定的操作\[3\]。 #### 引用[.reference_title] - *1* [小程序 | 案例---自定义tabBar](https://blog.csdn.net/muziqwyk/article/details/127325168)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [小程序的自定义组件](https://blog.csdn.net/m0_58190023/article/details/129699536)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值