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

uni-app文章列表制作⑨

文章目录

    • 十三、文章列表制作-文章卡片
        • 一、创建文章相关 listItem 组件
        • 二、文章卡片组件定义
        • 三、定义 uniapp 模版
    • 十四、文章列表制作-数据渲染
        • 一、云函数创建
        • 二、前端进行数据获取
        • 三、数据渲染
        • 四、根据选项卡分类进行数据渲染

十三、文章列表制作-文章卡片

一、创建文章相关 listItem 组件

使用 scroll-view 实现竖向滚动容器制作,注意在样式定义时进行多级高度设定

<view class="list-scroll-container">
		<scroll-view scroll-y="true" class="list-scroll">
			<view>
				<ListCard v-for="item in 50" :key="item"></ListCard>
			</view>
		</scroll-view>
</view>
二、文章卡片组件定义
  1. 创建基本样式及结构
  2. 定义多状态卡片模块
    1. 通过父组件传递 mode 属性进行条件编译
    2. 根据条件进行选项卡卡片展示
三、定义 uniapp 模版
  1. 根目录下创建 index.html 文件
  2. 参考地址:https://uniapp.dcloud.io/collocation/manifest?id=h5-template
  3. manifest 文件的 html5 配置中进行 index.html 文件引入

十四、文章列表制作-数据渲染

一、云函数创建

定义 articleList 云函数

删除不需要返回的文章详情内容

'use strict';
const db = uniCloud.database()
exports.main = async (event, context) => {
	const list = await db.collection('article')
	.aggregate()
	.project({
		content:0
	})
	.end()
	//返回数据给客户端
	return {
		code:0,
		msg:"数据请求成功",
		data:list.data
	}
};
二、前端进行数据获取
  1. articleList 组件 => created 钩子中进行数据获取

    created () {
        this._getArticleList()
      }
     methods: {
        async _getArticleList () {
          const articleList = await this.$http.get_article_list()
          this.articleList = articleList
        }
      }
    
三、数据渲染

listItem 组件中进行循环渲染使用

<view class="list-scroll-container">
		<scroll-view scroll-y="true" class="list-scroll">
			<view>
				<ListCard :item="item" v-for="(item,index) in articleList" :key="index"></ListCard>
			</view>
		</scroll-view>
	</view>
四、根据选项卡分类进行数据渲染
  1. 添加全部分类选项

    async _intiLabelList() {
    				const labelList = await this.$http.get_label_list()
    				this.labelList = [{name:"全部"},...labelList]
    			}
    
  2. 请求 articleList 时进行数据传递

    1. 为了保证导航数据的正确获取,调整 created 函数的_getArticle_list 方法在 watch 中进行调用

       watch: {
          labelList(newVal,OldVal) {
          this._getArticleList()
          },
        },
      
  3. 云函数进行数据过滤调整

    "use strict";
    const db = uniCloud.database();
    exports.main = async (event, context) => {
      const { classify } = event;
    
      let matchObj = {};
    
      if (classify !== "全部") {
        matchObj = { classify };
      }
    
      const list = await db
        .collection("article")
        .aggregate() // 使用聚合的形式进行数据的获取
        .match(matchObj) // 根据匹配条件进行数据返回
        .project({
          content: 0, // 本次查询不需要返回文章详情给前端
        })
        .end();
      //返回数据给客户端
      return {
        code: 0,
        msg: "数据请求成功",
        data: list.data,
      };
    };
    
  4. 前端对数据进行缓存处理

    将原有接受内容数组转换为对象进行存储。每次 change 改变内容时进行判断操作处理

    使用$set 方法进行对象的页面重新渲染

    async _getArticleList (currentIndex) {
          const articleList = await this.$http.get_article_list({classify:this.labelList[currentIndex].name})
          this.$set(this.articleData,currentIndex,articleList)
        }
    

http://www.kler.cn/a/389863.html

相关文章:

  • 开发神器之cursor
  • 【21】Word:德国旅游业务❗
  • vue项目配置多语言
  • 企业级NoSQL数据库Redis
  • mac 安装mongodb
  • mysql 与Redis 数据强一致方案
  • Mysql ERROR 1451 (23000) 外键处理异常
  • GEE 高阶:LandSCaPeN v1.0:一个支持分析景观结构、组成、过程、连通性和网络的Google Earth Engine工具箱
  • 解决部署RKE2或K3S-“docker.io/rancher/mirrored-pause:3.6\“: -无法拉取镜像办法
  • 位运算_判定字符是否唯一
  • 杨中科 .Net Core 笔记 DI 依赖注入2
  • 深入解析Hadoop:大数据处理的基石
  • 大数据新视界 -- 大数据大厂之 Impala 性能优化:为企业决策加速的核心力量(下)(14/30)
  • QToolbar工具栏下拉菜单不弹出有小箭头
  • 阿里云CDN稳定吗?
  • 如何在 Java 中使用 Canal 同步 MySQL 数据到 Redis
  • 【Java学习】电脑基础操作和编程环境配置
  • 华为OD机试真题---电脑病毒感染
  • 基因组编辑与CRISPR技术:基因治疗的革命性突破
  • 刷题---轮转数组
  • unity3d————延时函数
  • 鸿蒙生态的崛起:深度认知、机遇、挑战与案例分析
  • 【MATLAB源码-第214期】基于matlab的遗传算法GA最短路径路由优化算法仿真。
  • 大屏使用自适应后,地图点位偏移问题
  • Verilog基础知识-逻辑值
  • LINUX下的Myql:库的操作