ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

在微信小程序中使用解构赋值实现上拉刷新

2020-12-18 10:03:30  阅读:298  来源: 互联网

标签:console log students 微信 解构 上拉 data 赋值


参考解构赋值文档

解构赋值语法是一种 Javascript 表达式。通过解构赋值, 可以将属性/值从对象/数组中取出,赋值给其他变量。

let a, b, rest;
[a, b] = [10, 20];

console.log(a);
// expected output: 10

console.log(b);
// expected output: 20

[a, b, ...rest] = [10, 20, 30, 40, 50];

console.log(rest);
// expected output: Array [30,40,50]

let a = [10,20];
let b = [20,30];
let c;

c = [...a, ...b];
console.log(c);
//> Array [10, 20, 20, 30]

在微信小程序中实现上拉加载更多数据主要通过生命周期函数onReachButtom()

// 加载下一页数据

    onReachBottom: function(){
        // console.log("滑动触底");
        console.log(this.data.sector)
        let next = this.data.next;
        this.fetchStudents(this.data.majorId, ++next, this.data.sector);
        this.setData({
            next: next
        })
    },

    fetchStudents(majorId, next, sector) {
        request({
            url: "/api/data/contacts_students",
            data: {
                stuMajor: majorId,
                stuSector: sector,
                page: next
            }
        })
        .then(result => {
            this.setData({
                students: [...this.data.students, ...result.data.students]
            })
        })
    },

[...this.data.students, ...result.data.students]就表示将获取的数据result.data.students和this.data.students解析出来,组成一个新的数组赋值给students

解构赋值除了可以对数组进行解构赋值,还可以对对象进行解构赋值

var o = {p: 42, q: true};
var {p, q} = o;

console.log(p); // 42
console.log(q); // true

传统对数组进行追加元素会采用array.push

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.push("Kiwi")

不过采用这种方式对数组进行数据追加的一个缺点是,如果需要追加的数据量比较多,需要进行遍历才能进行添加完成

标签:console,log,students,微信,解构,上拉,data,赋值
来源: https://www.cnblogs.com/kelvinxiong/p/14153488.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有