【小程序项目开发-- 京东商城】uni-app之商品列表页面 (下)

news2024/11/18 18:43:19

在这里插入图片描述

🤵‍♂️ 个人主页: @计算机魔术师
👨‍💻 作者简介:CSDN内容合伙人,全栈领域优质创作者。

🌐 推荐一款找工作神器网站: 点击跳转牛客网 |笔试题库|面试经验|实习招聘内推|

还没有账户的小伙伴 速速点击链接登录注册把!🎉🎉

该文章收录专栏
✨ 2022微信小程序京东商城实战 ✨

文章目录

  • 一、上拉加载更多数据
    • 1. 在 pages.json 中配置上拉刷新&上拉距离
    • 2. 定义上拉触底行为
    • 3. 修改调取数据方法
    • 4. 效果
  • 二、设置节流阀控制数据请求
    • 1. 定义节流阀
    • 2. 添加判断
    • 3. 效果
  • 三、判断是否加载数据完毕
  • 四、 上拉刷新效果
    • 1. 配置可下拉刷新
    • 2. 监听事件函数(重置全部数据)
    • 3. 修改获取数据函数(添加停止下拉刷新)
    • 4. 效果
  • 六、配置列表项链接跳转
    • 1. 更改页面结构
    • 2. 定义参数跳转函数
    • 3. 效果
  • 六、分支的提交
  • 七、小结

一、上拉加载更多数据

1. 在 pages.json 中配置上拉刷新&上拉距离

    ,{
                    "path" : "goods_list/goods_list",
                    "style" :                                                                                    
                {
                 // 下拉刷新距离
                    "onReachBottomDistance": 150
                }

2. 定义上拉触底行为

   onReachBottom( ) {
      // 显示加载效果
       uni.showLoading({
        title:"数据请求中..."
      })
      //  页面数自增加一
      this.queryObj.pagenum ++
      // 再次请求数据
      this.getGoodlist()
      // 隐藏加载效果
      uni.hideLoading()
    },

3. 修改调取数据方法

 methods: {
      async getGoodlist() {
        const {
          data: res
        } = await uni.$http.get('/api/public/v1/goods/search', this.queryObj)
        console.log(res)
        if (res.meta.status != 200) return uni.$showMsg("数据调取失败")
        // 展开拼接
        this.goodlist = [...this.goodlist,...res.message.goods]
        this.total = res.message.total
      }
    },

4. 效果

在这里插入图片描述

二、设置节流阀控制数据请求

我们在下拉刷新过程会由于网速慢或各种原因,数据请求慢,此时我们在还没请求到数据又下拉刷新一次,但此时数据还未加载完成(函数还未运行完) ,此时页数加一,后面等到数据再次请求就不是下一页

1. 定义节流阀

   data() {
      return {
        // 节流阀
         isLoading : false
·······

2. 添加判断

在获取数据前设置为true(允许加载数据,添加页码后设置为false,真正请求到数据在设置为true)

 onReachBottom() {
          // 显示加载效果
      uni.showLoading()
      // 如果正在加载 跳出函数
      if  (this.isLoading) return
      
      //  页面数自增加一
      this.queryObj.pagenum++
      // 再次请求数据
      this.getGoodlist()
      // 隐藏加载效果
      uni.hideLoading()
    },
 methods: {
      async getGoodlist() {
        // 此时开始加载 设置为 true
        this.isLoading = true
        const {
          data: res
        } = await uni.$http.get('/api/public/v1/goods/search', this.queryObj)
        console.log(res)
        if (res.meta.status != 200) return uni.$showMsg("数据调取失败")
        // 展开拼接
        this.goodlist = [...this.goodlist, ...res.message.goods]
        this.total = res.message.total
        // 请求成功 设置为false ( 没有走完函数是不允许再次请求)
        this.isLoading = false
      }
 

3. 效果

在这里插入图片描述

三、判断是否加载数据完毕

  • onReachButtom函数中修改如下 ( 这里我们假设你的数据条数为23条)
 onReachBottom() {
      // 判断是否加载完毕
      // 方法一 ( 总长度相加 )
      if (this.goodlist.length + this.queryObj.pagesize >= this.total) return uni.$showMsg('没有更多的数据啦...')
      // 方法二 ( 页面数 * 页面数据条数)
      // if (this.queryObj.pagenum * this.queryObj.pagesize >= this.total) return uni.$showMsg('没有更多的数据啦...')

在这里插入图片描述

四、 上拉刷新效果

1. 配置可下拉刷新

在这里插入图片描述

2. 监听事件函数(重置全部数据)

  onPullDownRefresh() {
      // 重置所有数据
      this.queryObj.pagenum = 1
      this.goodlist = []
      this.total = 0
      this.isLoading = false
      // 重写获取数据,并传箭头函数进行取消下拉刷新
      this.getGoodlist(() => uni.stopPullDownRefresh())
    },

3. 修改获取数据函数(添加停止下拉刷新)

async getGoodlist(callback) {
        // 此时开始加载 设置为 true
        this.isLoading = true
        const { data: res } = await uni.$http.get('/api/public/v1/goods/search', this.queryObj)
        console.log(res)
        // 取消下拉刷新 (如果有则往后走达到存在则允许函数的效果)
        callback && callback()
        // 请求成功 设置为false (没有走完函数是不允许再次请求)
        this.isLoading = false
        // 隐藏加载效果
        uni.hideLoading()
        if (res.meta.status != 200) return uni.$showMsg("数据调取失败")
        // 展开拼接
        this.goodlist = [...this.goodlist, ...res.message.goods]
        this.total = res.message.total
      }

4. 效果

在这里插入图片描述

六、配置列表项链接跳转

1. 更改页面结构

block更改为view,并添加onclick 事件跳转页面,由于需要更多的操作所以这里不单纯更改为navigator组件

< <!-- 列表页 -->
    <view class="goods-list">
      <view v-for="(item,i) in goodlist" v-bind:key="i" @click="goToUrl(item)">
        <my-goods :good="item"></my-goods>
      </view>
    </view>

2. 定义参数跳转函数

  methods: {
      goToUrl(item){
        uni.navigateTo({
          url:"/subpackages/goods_detail/goods_detail?goods_id=" + item.goods_id,
        })
      },

3. 效果

在这里插入图片描述

六、分支的提交

git add .

git commit -m "商品分类页面开发完成"

git push origin -u goodlist

git checkout master 

git merge goodlist

git push 

git branch -d goodlist

在这里插入图片描述

在这里插入图片描述

七、小结

在项目开发中经常会遇到列表页开发,如之前文章的搜索组件,显示建立列表 ✨ 京东商城uni-app之自定义搜索组件(中) ✨, 而这些列表页都有以下开发共性

  1. 获取列表数据
  2. 渲染列表数据结构到页面
  3. 美化样式
  4. 下拉刷新请求数据( 经典参数:请求数据关键字、页码数、每页数据量、其他属性等, 经典接口返回数据:状态meta(是否查询成功)、所含数据总数、
  5. 下拉刷新节流阀
  6. 上拉刷新重新加载数据
  7. 为列表项添加链接

	  🤞到这里,如果还有什么疑问🤞
🎩欢迎私信博主问题哦,博主会尽自己能力为你解答疑惑的!🎩
 	 🥳如果对你有帮助,你的赞是对博主最大的支持!!🥳

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/409446.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

推荐几个优秀的echarts 图表网站,让你轻松搞定全部报表

1.PPChart - 让图表更简单让图表更简单。PPChart 提供 Echarts 收录、图表制作等服务http://ppchart.com/#/ 2.https://madeapie.com/#/echarts图表制作&#xff0c;Make A Pie&#xff0c;Made A Pie&#xff0c;echarts案例分享&#xff0c;echarts教程分享https://madeapie…

PHP连接数据库MySQL打造xxx管理系统,实现简单的增删改查功能

目录 前言 概述 内容 创建数据库表 实现列表 新增用户 删除用户 编辑用户 前言 最近刚学完PHP和Mysql,历时半个多月时间完成了这样一个简单的算是人员管理系统吧&#xff0c;为了加深印象总结一下&#xff0c;还有很多不足之处&#xff0c;希望大家多多指正&#xff0c;一…

vue点击变色

vue点击一个遍历后元素改变其颜色的方法&#xff0c;有两种情况&#xff0c;第一种是点击单行元素变色&#xff0c;点击另一行元素时&#xff0c;原来变色的元素变回原来的颜色&#xff0c;始终只有一行元素是变色的&#xff0c;第二种情况是点击后永久变色&#xff0c;点击其他…

手把手教你部署前端项目

手把手教你部署前端项目 1.1 用Vue-cli构建简易前端项目 1.1.1 安装 Vue CLI 包 打开命令行工具&#xff0c;执行下列命令来安装 Vue CLI 包&#xff1a; npm install -g vue/cli可以用下面的命令查看是否安装成功&#xff1a; vue --version1.1.2 创建一个项目 新建一个…

背景图片相关应用-铺满,自适应

1.首先了解一下背景相关属性 background-color&#xff1a; 颜色。 background-position&#xff1a; 位置。 数值&#xff0c;或者top,right,bottom,left等&#xff0c;center&#xff1a;距离页面左边的定位&#xff0c;0px&#xff1a;距离页面上面的定位 background-si…

Cesium3Dtilesets 使用customShader的解读以及泛光效果示例

前言&#xff1a;光带原理在旋转弹跳四棱锥这篇文章里早已经阐述过&#xff0c;但还是有不少靓仔靓女可能会感到疑惑&#xff0c;在3Dtilesets里怎么使用&#xff1f;为啥我在网上看到的为数不多的代码示例我看不懂&#xff1f;是由于没理解透彻导致的。借此机会&#xff0c;提…

SocketIO介绍+SpringBoot整合SocketIO完成实时通信

Socket.IO笔记 即时通信是基于TCP长连接&#xff0c;建立连接之后&#xff0c;客户段/服务器可以无限次随时向对端发送数据&#xff0c;实现服务器数据发送的即时性 HTTP HTTP是短链接&#xff0c;设计的目的是减少服务器的压力 HTTP伪即时通讯 轮询 emmet长轮询 long pulling…

vue打包之后出现空白页的原因以及解决方式

路由模式 history 新建项目什么都不动&#xff0c;路由模式&#xff1a;history, 直接npm run build打包 打包之后&#xff0c;直接打开dist文件里面的ndex.html可以看到页面是空白的&#xff0c;控制台是这样的。 再看看网页源码, 对比dist文件夹结构可以看到资源路径的引入…

【前端】React使用react-markdown+antd实现引入渲染markdown文件

项目中遇见一个需求&#xff0c;要求直接在浏览器打开markdown文件进行预览&#xff0c;初次使用遇见一些坎坷&#xff0c;以下记录实现过程&#xff0c;将其封装成了一个组件。 1.下载依赖 yarn add react-markdown//其余样式插件&#xff1a; yarn add remark-gfm yarn …

vue+springboot使用文件流实现文件下载

前言 本次将使用vue和springboot通过文件流的方式教大家怎么去实现文件的下载&#xff0c;那么话不多说&#xff0c;我们直接开始 相关vue导出文件 以下链接为我其他vue进行下载导出文件文章 vue实现把字符串导出为txt 步骤 文件路径 要进行下载的话&#xff0c;我们肯定…

WEB核心【案例:文件下载,案例:点击切换验证码,几种获取properties资源方式】第十二章

目录 1.文件下载 1.1超链接下载&#xff1a; 1.2自定义servlet下载 1.3小结 2.点击切换验证码 2.1前置只是-验证码生成 2.2分析及代码实现 2.3需求2&#xff1a;点击切换验证码-绕过缓存 3.几种获取preperties资源方式 &#x1f49f;作者简介&#xff1a;大家好呀&…

CTF中Web题目的各种基础的思路-----入门篇十分的详细

我期间也考察很多人的&#xff0c;但搞这个的确实有点少&#xff0c;希望这篇可以大家一点帮助&#xff0c;这篇文章也借鉴一些人的文章&#xff0c;还有很多东西&#xff0c;我没搞&#xff0c;确实有点麻烦&#xff0c;但以后还会不断更新的&#xff0c;希望大家在web这里少走…

Web系统常见安全漏洞介绍及解决方案-CSRF攻击

&#x1f433;博客主页&#xff1a;拒绝冗余 – 生命不息&#xff0c;折腾不止 &#x1f310;订阅专栏&#xff1a;『Web安全』 &#x1f4f0;如觉得博主文章写的不错或对你有所帮助的话&#xff0c;还望大家多多支持呀&#xff01; &#x1f449;关注✨、点赞&#x1f44d;、收…

CSS基本布局——grid布局

grid布局简介&#xff1a; Grid布局是将容器划分成“行”和“列”&#xff0c;产生单元格&#xff0c;然后指定“项目所在”的单元格&#xff0c;可以看作是二维布局。 基本概念&#xff1a; 容器&#xff08;container&#xff09;——有容器属性项目&#xff08;items&…

vite项目优化

首先在讲述vite优化之前&#xff0c;我们先来分析一下和传统的项目管理构建工具的区别&#xff0c;以webpack为例&#xff0c;它是利用plugin插件和loader加载器对项目的所有模块和依赖统一通过入口文件进行编译&#xff0c;从而变成我们html所需要的js格式渲染我们的页面。 随…

Vue项目目录结构介绍(三)

前言 本章我们会对一个 Vue 项目的目录结构进行讲解&#xff0c;解释各子目录以及文件的作用&#xff0c;前端的模块化&#xff0c;Vue 单文件组件规范等。 1、基础目录和文件介绍 在上一章&#xff0c;我们通过 vue-cli 创建了一个新的项目&#xff0c;生成的项目目录里已经包…

tauri+vite+vue3开发环境下创建、启动运行和打包发布

目录 1.创建项目 2.安装依赖 3.启动项目 4.打包生成windows安装包 5.安装打包生成的安装包 1.创建项目 运行下面命令创建一个tauri项目 pnpm create tauri-app 我创建该项目时的node版本为16.15.0 兼容性注意 Vite 需要 Node.js 版本 14.18&#xff0c;16。然而&#x…

【玩转CSS】这些高级技巧,你都会吗

&#x1f525;一个人走得远了&#xff0c;就会忘记自己为了什么而出发&#xff0c;希望你可以不忘初心&#xff0c;不要随波逐流&#xff0c;一直走下去&#x1f3b6; &#x1f98b; 欢迎关注&#x1f5b1;点赞&#x1f44d;收藏&#x1f31f;留言&#x1f43e; &#x1f984; …

js去掉两个数组相同的元素、js删除数组中某一个对象、js快速查找数组中重复项下标

一、js去掉两个数组相同的元素 注意&#xff1a;这里并非是数组去重&#xff0c;数组去重是去掉一个数组中相同的元素&#xff0c;这里是比较两个数组&#xff0c;过滤掉二者相同的&#xff0c;留下不同的。 通过 some() 在对方数组里面查找相同元素&#xff0c;再利用filter…

老老实实的程序员该如何描述自己的缺点

答辩的时候&#xff0c;晋升的时候&#xff0c;面试的时候&#xff0c;你有没有经常遇到一个问题&#xff0c;那就是你觉得自己有什么缺点吗&#xff1f; 目录 1. 每个人都有缺点 2. 这道题在考什么&#xff1f; 3. 我之前是怎么回答的 4. 你可以这样回答试一试 5. 总结 …