当前位置: 首页 > news >正文

网站下做二级域名深圳网站开发

网站下做二级域名,深圳网站开发,网站怎么做的qq邮件订阅,昌图网站推广一、前情提要 微信小程序中实现上拉加载更多,其实就是pc端项目的分页。使用的是scroll-view,scroll-view详情在微信开发文档/开发/组件/视图容器中。每次上拉,就是在原有数据基础上,拼接/合并上本次上拉请求得到的数据。这里采用…

一、前情提要

  1. 微信小程序中实现上拉加载更多,其实就是pc端项目的分页。
  2. 使用的是scroll-view,scroll-view详情在微信开发文档/开发/组件/视图容器中。
  3. 每次上拉,就是在原有数据基础上,拼接/合并上本次上拉请求得到的数据。
  4. 这里采用的是concat,concat 是数组对象的一个方法,用于合并两个或多个数组,生成一个新的数组。这个方法不会修改原始数组,而是返回一个新的数组
  5. concat使用示例如下:
// 示例数组
const array1 = [1, 2, 3];
const array2 = [4, 5, 6];
const array3 = [7, 8, 9];// 使用concat合并数组
const mergedArray = array1.concat(array2, array3);// 打印结果
console.log("原始数组1: ", array1);
console.log("原始数组2: ", array2);
console.log("原始数组3: ", array3);
console.log("合并后的数组: ", mergedArray);//输出结果应为:
原始数组1:  [1, 2, 3]
原始数组2:  [4, 5, 6]
原始数组3:  [7, 8, 9]
合并后的数组:  [1, 2, 3, 4, 5, 6, 7, 8, 9]

二、代码示例(1)不使用onReachBottom

  1. index.wxml
//1、scroll-y 允许纵向滚动
//2、lower-threshold="100px" 距底部/右边多远(100px)时,触发 scrolltolower 事件
//3、scroll-top="{{topHeight}}px" 设置竖向滚动条位置
<view class="box"><!-- 列表 --><scroll-view scroll-y lower-threshold="100px" bindscrolltolower="scrollToLower" style="height: 80vh;" scroll-top="{{topHeight}}px" class="scrView"><view class="listBox" wx:for="{{groupData}}" wx:key="id"><view class="name">{{item.name}}</view><view class="phone">{{item.mobile}}</view><image src="../../image/icon/bj.png" bindtap="editRecipient" data-item="{{item}}" class="mini-btn" /><image src="../../image/icon/sc.png" bindtap="deleteRecipient" data-id="{{item.id}}" class="mini-btn2" /></view><view style="text-align: center;"><view wx:if="{{loading}}">加载中...</view><view wx:if="{{noMore && !noData}}">没有更多了</view><view wx:if="{{noData}}">暂无数据</view></view></scroll-view>
</view>
  1. index.js
Page({data: {loading: false, //加载更多的loadingnoMore: false,   //没有更多了noData:false, //暂无数据isPage:false, // 是否需要分页 ispage的作用 进页面首次在onLoad中调用时,不需要合并数据page:1,limit:5,topHeight:0, },/*** 生命周期函数--监听页面加载*/onLoad(options) {this.getContactList()},// restore函数的作用,当业务有搜索、删除、新增、编辑等操作时,需要还原对应参数状态。// 初始化数据restore(){this.setData({loading: false, //加载更多的loadingnoMore: false,   //没有更多了noData:false,isPage:false,page:1,limit:5,topHeight:0, })},getContactList(isPage){let params = {page:this.data.page,limit:this.data.limit,tid: this.data.inquirFform.tagID}req.group.contactList(params).then((res) =>{if (isPage) {// 下一页数据拼接在原始数据后面this.setData({groupData: this.data.groupData.concat(res.data.list),loading: false})} else {this.setData({groupData: res.data.list,loading: false})}//如果返回的数据为空,那么就没有下一页了if (res.data.list.length == 0 && this.data.isPage) {this.setData({noMore: true})}if (res.data.list.length == 0 && !this.data.isPage) {this.setData({noMore: true,noData:true})}})},// 下滑到底部触发scrollToLower(){if (!this.data.loading && !this.data.noMore) {this.setData({loading: true,page: this.data.page + 1,isPage:true})this.getContactList(this.data.isPage)}},
})

示例图片如下:
请添加图片描述

三、代码示例(2)使用onReachBottom(1)

onReachBottom:监听用户上拉触底事件。
可以在app.json的window选项中或页面配置中设置触发距离onReachBottomDistance。
在触发距离内滑动期间,本事件只会被触发一次。

  • 每次请求数据时候,在底部提示加载中

  • 当请求完全部数据时,在底部提示 没有更多数据了,
    后端返回数据总条数 如下.js文件中的 total 判断 每次请求时判断前端拿到的总数据的length == total,若是等于 则显示 没有更多数据了,并且 再次上拉时,不进行数据的请求。

  • 前端传 page 当前页 每次请求 page + 1
    limit:没有数量 前端自己写个固定值就行
    业务参数:若列表支持查询搜索等,传自己的业务数据

  • 后端返回 total:总数据条数
    data:[] 对应的数据列表

  • 有导航切换的需要注意,切换导航后先重置 加载中提示,没有更多数据提示,page等参数后,在请求数据

、、、
1、wxml

<view class="content"><view class="body"><view class="box" wx:for="{{proArr}}" wx:key="_id"><xzs-product-item item="{{item}}"></xzs-product-item></view></view><view class="loadOut"><van-loading size="24px" wx:if="{{loading}}">加载中...</van-loading><view class="noData" wx:if="{{isData}}">没有更多数据了~</view></view>
</view>
```';

3、.js


Page({/*** 页面的初始数据*/data: {navActive:0,navArr:[],proArr:[],page:1,limit:10,loading:false,isData:false},/*** 生命周期函数--监听页面加载*/async onLoad(options) {let {idx} = options;    await this.getNavList(); if(idx){this.navChange(idx);}else{navid = this.data.navArr[0]._id;this.getProductList();}},//获取产品列表getProductList(){this.setData({loading:true})queryProduct({navid:navid,page:this.data.page,limit:this.data.limit}).then(res=>{   let oldArr= this.data.proArr;let newArr=oldArr.concat(res.data)   console.log(res);this.setData({proArr:newArr,loading:false})if(res.total == this.data.proArr.length){this.setData({isData:true})}})},//导航条切换事件navChange(e){    let index= e?.detail?.index ?? e;navid = this.data.navArr[index]._idthis.setData({proArr:[],loading:false,isData:false,page:1,navActive:Number(index)})    this.getProductList();},/*** 页面上拉触底事件的处理函数*/onReachBottom() {if(this.data.isData) return;this.setData({page:this.data.page + 1})this.getProductList()},
})

四、代码示例(2)使用onReachBottom(2)

  • 这个同 三、代码示例(2)类似,只不过是请求时传递给后端的参数不同
  • 前端传 size: 就是列表数据的长度,初始是0。例如:第一次,请求得到数据长度为5 ,那么上拉数据请求时候,size就传5,再次上拉,合并数据后长度为10,下次上拉请求就传10

1、.wxml

<view class="content"><view class="body"><view class="box" wx:for="{{proArr}}" wx:key="_id"><xzs-product-item item="{{item}}"></xzs-product-item></view></view><view class="loadOut"><van-loading size="24px" wx:if="{{loading}}">加载中...</van-loading><view class="noData" wx:if="{{isData}}">没有更多数据了~</view></view>
</view>

2、.js

Page({/*** 页面的初始数据*/data: {navActive:0,navArr:[],proArr:[],loading:false,isData:false},/*** 生命周期函数--监听页面加载*/async onLoad(options) {this.getProductList();},//获取产品列表getProductList(s=0){this.setData({loading:true})queryProduct({navid:navid,size:s}).then(res=>{   let oldArr= this.data.proArr;let newArr=oldArr.concat(res.data)   console.log(res);this.setData({proArr:newArr,loading:false})if(res.total == this.data.proArr.length){this.setData({isData:true})}})},//导航条切换事件navChange(e){    let index= e?.detail?.index ?? e;navid = this.data.navArr[index]._idthis.setData({proArr:[],loading:false,isData:false,navActive:Number(index)})    this.getProductList();},/*** 页面上拉触底事件的处理函数*/onReachBottom() {if(this.data.isData) return;this.getProductList(this.data.proArr.length)}
})

三和四几乎一样,就看前后端怎么约定的穿什么数据,返回什么数据

http://www.mmbaike.com/news/92098.html

相关文章:

  • 东子WordPress一个网站的seo优化有哪些
  • 宁波 手机网站建设点击排名优化
  • 百拓公司做网站怎么样站长工具seo综合查询是什么
  • wordpress 手机网站支付宝5000人朋友圈推广多少钱
  • 自己做网站怎么发布百度信息流是什么
  • 网站的后台系统怎么进入百度热搜词排行榜
  • 织梦 导航网站 模板国外网站排名前十
  • 网站开发数据接口如何利用东莞今天发生的重大新闻
  • 番禺网站建设怎么样图片外链在线生成网址
  • 跨境电商独立站是什么意思百度云网盘网页版登录
  • 可以做软件的网站有哪些内容吗外贸平台排行榜前十名
  • 简约淘宝网站模板免费下载搜索引擎营销的特点有
  • 如何推广网站业务成都关键词排名系统
  • 网站怎么做用户体验百度推广客户端手机版
  • 宣讲家网站李慎明两学一做曼联vs曼联直播
  • 已有网站可以做服务器吗网站收录提交入口
  • 重庆石桥铺网站建设公司semen
  • 大学生毕业设计课题做网站电商网站设计方案
  • 如何做网站优化推广福州seo网络推广
  • html网站怎么搭建搜索引擎名词解释
  • 上海平台网站制作公司sem竞价托管公司
  • wordpress 404跳转首页沈阳seo优化新势力
  • 怎么做多语言的网站seo软文推广
  • 有没有做婚车的网站seo免费外链工具
  • 知名大型网站搭建公司seo是什么及作用
  • 西安专业做网站的公司有哪些无锡网站建设
  • 烟台网站建设服务灰色关键词怎么做排名
  • app外包公司大全成都最好的seo外包
  • 游戏网站模百度今日小说排行榜
  • 陕西省建设执业资格注册中心网站口碑营销的优势