(二十)、完成个人中心页面的数据统计+设置详情页点赞用户的头像组【uniapp+uinicloud多用户社区博客实战项目(完整开发文档-从零到完整项目)】

有目标就不怕路远。年轻人.无论你现在身在何方.重要的是你将要向何处去。只有明确的目标才能助你成功。没有目标的航船.任何方向的风对他来说都是逆风。因此,再遥远的旅程,只要有目标.就不怕路远。没有目标,哪来的劲头?一车尔尼雷夫斯基

导读:本篇文章讲解 (二十)、完成个人中心页面的数据统计+设置详情页点赞用户的头像组【uniapp+uinicloud多用户社区博客实战项目(完整开发文档-从零到完整项目)】,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

1,个人中心页面的数据统计

数据统计包括两项内容:1.当前登录用户的点赞总数量。2.当前登录用户发布文章的总数量

1.1,在self页面data中定义对象
		data() {
			return {
				totalObj:{
					artNum:0,
					likeNum:0
				}
			};
		},
1.2,获取总数量的方法:

文章数:查询当前登录用户的文章数据表数量:

let artCount = await db.collection("quanzi_articles").where(`user_id == $cloudEnv_uid`).count();

点赞数:查询当前登录用户的文章数据表,使用jql语法—分组统计groupby
求和、求均值示例

				let likeCount=await db.collection("quanzi_articles").where(`user_id == $cloudEnv_uid`)
				.groupBy('user_id')
				.groupField('sum(like_count) as totalScore').get()

getTotal方法:

      //获取点赞数和文章数的方法
      async getTotal() {
        if (!this.hasLogin) return;
        //查询当前登录用户的文章数据表数量
        let artCount = await db.collection("quanzi_articles").where(`user_id == $cloudEnv_uid`).count();
        this.totalObj.artNum = artCount.result.total;

        let likeCount = await db.collection("quanzi_articles").where(`user_id == $cloudEnv_uid`)
          .groupBy('user_id')
          .groupField('sum(like_count) as totalScore').get()
        this.totalObj.likeNum = likeCount.result.data[0].totalScore

        console.log(this.totalObj);

      },

打印输出:

在这里插入图片描述

1.3,页面渲染数据
			<view class="info">
				<view class="item"><text>{{totalObj.likeNum}}</text>获赞</view>
				<!-- <view class="item"><text>11</text>评论</view> -->
				<view class="item"><text>{{totalObj.artNum}}</text>发文</view>
			</view>

2,设置详情页点赞用户的头像组

2.1,在detail页面data中定义对象

定义点赞用户的数组

likeUserArr: [],
2.1,写获取数据方法
      //获取部分点赞的用户
      getLikeUser() {
        let likeTemp = db.collection("quanzi_like").where(`article_id == "${this.artid}"`).getTemp()
        let userTemp = db.collection("uni-id-users").field("_id,avatar_file").getTemp()
        db.collection(likeTemp, userTemp).orderBy("publish_date desc").limit(5).get().then(res => {
          console.log(res);
          res.result.data = res.result.data.reverse()
          this.likeUserArr = res.result.data
        })
      },
2.1,页面渲染
          <!-- 游览 -->
          <view class="users">
            <template v-for="item in likeUserArr">
              <image :src="giveAvatar(item)" mode="aspectFill"></image>
            </template>
          </view>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/135723.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!