鸿蒙HarmonyOS评论功能小demo

评论页面小demo

效果展示

img

1.拆解组件,分层搭建

我们将整个评论页面拆解为三个组件,分别是头部导航,评论项,回复三个部分,然后统一在index界面导入

image-20250304150652225

2.头部导航界面搭建

image-20250304151026576

@Preview
@Component
struct HmNavBar {
  // 属性:是可以被传递值进行替换的
  build() {
    Stack({ alignContent: Alignment.Start }) {
      Row() {
        Image($r('sys.media.ohos_ic_compnent_titlebar_back'))
          .width('100%')
          .aspectRatio(1)
      }.width(24)
      .padding(4)
      .borderRadius(12)
      .backgroundColor('#f5f7f8')


      Text('评论回复')//先设置占页面的100%  然后在居中对齐
        .width('100%')
        .textAlign(TextAlign.Center)
    }
    .width('100%')
    .padding(20)
  }
}

export { HmNavBar }
  • 上述UI界面搭建很简单,但要注意一点就是在有了返回按钮的情况下如何让评论回复在整行居中,我们可以采用Stack布局,或者是在右边也放置一个宽度为24的容器

3.评论项搭建

image-20250304151409576

@Preview
@Component
struct HmReplay {
  build() {
    Row({ space: 8 }) {
      Image($r('app.media.Cover1'))
        .width(60)
        .borderRadius(30)
      Column({ space: 5 }) {
        Text('遇到困难睡大觉')
          .fontSize(18)
          .fontWeight(700)
        Text('你已经是一个成熟的评论了要学会自己打破零回复!')
          .fontSize(18)

        Row() {
          Row() {
            Text('10-21.IP 属地安徽')
              .fontColor('#ffcfcfcf')
          }

          Row({ space: 5 }) {
            Image($r('app.media.love'))
              .width(24)
              .aspectRatio(1)
            Text('100')
              .fontColor('#ffcfcfcf')
          }
        }.width('100%')
        .justifyContent(FlexAlign.SpaceBetween)
      }.layoutWeight(1)
      .alignItems(HorizontalAlign.Start)

    }.width('100%')
    .padding(20)
    .height(120)
    .alignItems(VerticalAlign.Top)

  }
}

export { HmReplay }

4.评论列表搭建

4.1.1分割线+回复 部分

    Row() {
        Text('回复 (7)')
      }.padding(12)
      .border({
        width: {
          top: 6
        },
        color: 'rgb(246,246,246)'
      })
      .width('100%')

4.1.2 评论列表

1.导入对应的数据结构
@State commentList: ReplyItemModel[] = [
    new ReplyItemModel({
      id: 1,
      avatar: 'https://picx.zhimg.com/027729d02bdf060e24973c3726fea9da_l.jpg?source=06d4cd63',
      author: '偏执狂-妄想家',
      content: '更何况还分到一个摩洛哥[惊喜]',
      time: '11-30',
      area: '海南',
      likeNum: 34,
      likeFlag: false
    }),
    new ReplyItemModel({
      id: 2,
      avatar: 'https://pic1.zhimg.com/v2-5a3f5190369ae59c12bee33abfe0c5cc_xl.jpg?source=32738c0c',
      author: 'William',
      content: '当年希腊可是把1:0发挥到极致了',
      time: '11-29',
      area: '北京',
      likeNum: 58,
      likeFlag: false
    }),
    new ReplyItemModel({
      id: 3,
      avatar: 'https://picx.zhimg.com/v2-e6f4605c16e4378572a96dad7eaaf2b0_l.jpg?source=06d4cd63',
      author: 'Andy Garcia',
      content: '欧洲杯其实16队球队打正赛已经差不多,24队打正赛意味着正赛阶段在小组赛一样有弱队。',
      time: '11-28',
      area: '上海',
      likeNum: 10,
      likeFlag: false
    }),
    new ReplyItemModel({
      id: 4,
      avatar: 'https://picx.zhimg.com/v2-53e7cf84228e26f419d924c2bf8d5d70_l.jpg?source=06d4cd63',
      author: '正宗好鱼头',
      content: '确实眼红啊,亚洲就没这种球队,让中国队刷',
      time: '11-27',
      area: '香港',
      likeNum: 139,
      likeFlag: false
    }),
    new ReplyItemModel({
      id: 5,
      avatar: 'https://pic1.zhimg.com/v2-eeddfaae049df2a407ff37540894c8ce_l.jpg?source=06d4cd63',
      author: '柱子哥',
      content: '我是支持扩大的,亚洲杯欧洲杯扩到32队,世界杯扩到64队才是好的,世界上有超过200支队伍,欧洲区55支队伍,亚洲区47支队伍,即使如此也就六成出现率',
      time: '11-27',
      area: '旧金山',
      likeNum: 29,
      likeFlag: false
    }),
    new ReplyItemModel({
      id: 6,
      avatar: 'https://picx.zhimg.com/v2-fab3da929232ae911e92bf8137d11f3a_l.jpg?source=06d4cd63',
      author: '飞轩逸',
      content: '禁止欧洲杯扩军之前,应该先禁止世界杯扩军,或者至少把亚洲名额一半给欧洲。',
      time: '11-26',
      area: '里约',
      likeNum: 100,
      likeFlag: false
    })
  ]
//先定义一个接口 然后可以使用接口转换工具转换成对应的类
export interface ReplyItem {
  avatar: ResourceStr // 头像
  author: string // 作者
  id: number // 评论的id
  content: string // 评论内容
  time: string // 发表时间
  area: string // 地区
  likeNum: number // 点赞数量
  likeFlag: boolean | null // 当前用户是否点过赞
}

export class ReplyItemModel implements ReplyItem {
  avatar: ResourceStr = ''
  author: string = ''
  id: number = 0
  content: string = ''
  time: string = ''
  area: string = ''
  likeNum: number = 0
  likeFlag: boolean | null = null

  constructor(model: ReplyItem) {
    this.avatar = model.avatar
    this.author = model.author
    this.id = model.id
    this.content = model.content
    this.time = model.time
    this.area = model.area
    this.likeNum = model.likeNum
    this.likeFlag = model.likeFlag
  }
}

4.搭建评论列表界面
      List() {
        ForEach(this.commentList, (item: ReplyItemModel) => {
          ListItem() {
            HmCommentItem({
              commentInfo: item,
              //但凡传函数吧必须用箭头函数包裹!
              changeLike:(id:number)=>{
                this.changeLike(id)
              }
            })
          }

        })
      }.layoutWeight(1)
  • 这里需要注意几点
  1. List里面必须放置ListItem()
  2. 评论列表的高度可以给一个自适应,这样可以让列列表超出屏幕的高度时实现自适应

5.点赞逻辑的实现

实现任务:当我们点击爱心或者点赞的时候,点赞数量+1,爱心变位红色,当我们再次点击,点赞由原来的点赞变为取消点赞,爱心的颜色变为灰色,点赞的数量-1

代码层面分析:由于我们显示的数据是由主界面传到子界面的,所以我们需要在父界面定义一个方法,传递到子面去,在子界面去调用这个方法,所以在子界面需要有一个接受的方法

5.1.1 子界面接收的方法

  changeLike:(id:number)=>void = ()=> {

  }

5.1.2 点赞业务逻辑的实现

  //点赞逻辑处理
  changeLike(id:number){
    //遍历数组  对commentlist数组中的每一个元素item进行迭代
    const index = this.commentList.findIndex(item =>item.id === id)
    //分支处理主评论和回复评论点赞状态
    if(index < 0){//处理主评论
      if(this.comment.likeFlag){//已经点赞
        this.comment.likeNum -- //点赞数量--
      }else {//未点赞
        //点赞数量++
        this.comment.likeNum++
      }

      this.comment.likeFlag = !this.comment.likeFlag
    }else{//处理回复评论   找到回复列表中的某一个子评论
      //返回第一次匹配元素的数组索引(0~N)
      if(this.commentList[index].likeFlag){
        this.commentList[index].likeNum--
      }else {
        this.commentList[index].likeNum++
      }
      this.commentList[index].likeFlag = !this.commentList[index].likeFlag
   //@State修饰的数据只能监听到第一层或者本身  需要new一下在使用
      this.commentList[index] = new ReplyItemModel(this.commentList[index])
      // this.commentList.splice(index,1,this.commentList[index])
    }

5.1.3父界面进行传值

image-20250304214822497

6.发布界面的搭建

6.1.1 发布的逻辑

  publishComment(content:string){
    this.commentList.unshift(new ReplyItemModel({
      // id: Math.random()的作用是生成一个基于随机数的临时唯一标识,但需注意:
      // 数值范围: 0 ≤ N < 1 (浮点数)
      // 格式示例: 0.1234567890123456
      // 非整型: 生成16位小数的浮点数
      //id不能重复
      id: Math.random(),
      avatar: 'https://picx.zhimg.com/027729d02bdf060e24973c3726fea9da_l.jpg?source=06d4cd63',
      author: '遇到困难睡大觉',
      content: '山外青山楼外楼,不回消息我记仇',
      time: '11-30',
      area: '安徽',
      likeNum: 0,
      likeFlag: false
    }))
  }

6.1.2 发布界面

@Preview
@Component
struct replay {
  content: string = ''
  @Link
  conmentsnum: number
  publish: (content: string) => void = () => {

  }

  build() {
    Row() {
      TextInput({ placeholder: '请留下你的评论~', text: $$this.content })
        .layoutWeight(1)
        .onSubmit(() => {
          this.publish(this.content)
          this.content = ''
        })
      Button('发布')
        .onClick(() => {

          this.publish(this.content)
          this.content = ''
          this.conmentsnum++

        })
    }
    .width('100%')
    .padding(12)
  }
}

export { replay }

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

智能机器人学习机WT3000A AI芯片方案-自然语音交互 打造沉浸式学习体验

一、概述 当AI浪潮席卷全球&#xff0c;教育领域也未能幸免。AI学习机&#xff0c;这个打着“个性化学习”、“精准提分”旗号的新兴产品&#xff0c;正以惊人的速度占领市场。从一线城市到偏远乡镇&#xff0c;从学龄前儿童到高考备考生&#xff0c;AI学习机的广告铺天盖地&am…

鸿蒙与DeepSeek深度整合:构建下一代智能操作系统生态

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 https://www.captainbed.cn/north 目录 技术融合背景与价值鸿蒙分布式架构解析DeepSeek技术体系剖析核心整合架构设计智能调度系统实现…

【UCB CS 61B SP24】Lecture 22 23: Tree and Graph Traversals, DFS, BFS 学习笔记

本文讲解了二叉树的四种遍历方式&#xff0c;以及如何通过前/后序遍历与中序遍历重建出二叉树&#xff0c;接着介绍了新的非线性数据结构&#xff1a;图&#xff0c;详细讲解了图的存储方式与遍历方式&#xff0c;最后使用 Java 基于邻接表的存储方式实现了图与 DFS、BFS 两种遍…

GCC RISCV 后端 -- C语言语法分析过程

在 GCC 编译一个 C 源代码时&#xff0c;先会通过宏处理&#xff0c;形成 一个叫转译单元&#xff08;translation_unit&#xff09;&#xff0c;接着进行语法分析&#xff0c;C 的语法分析入口是 static void c_parser_translation_unit(c_parser *parser); 接着就通过类似递…

Swagger-01.介绍和使用方式

一.Swagger介绍 有了接口文档&#xff0c;我们就可以根据接口文档来开发后端的代码了。如果我们开发完了某个功能&#xff0c;后端如何验证我们开发的是否正确呢&#xff1f;我们就需要测试&#xff0c;使用Swagger就可以帮助后端生成接口文档&#xff0c;并且可以进行后端的接…

MAVEN的环境配置

在下载好maven后或解压maven安装包后进行环境配置 1.在用户环境变量中 新建一个MAVEN_HOME 地址为MAVEN目录 注&#xff1a;地址为解压后maven文件的根目录&#xff01;&#xff01;&#xff01; 2.在系统环境变量的path中添加该变量 %MAVEN_HOME%\bin 3. 测试maven安装是否成…

分布式存储学习——HBase概述

1.1 HBase概述 1.1.1 理解大数据背景 1.1.2 HBase是什么 1.1.3 HBase与Hadoop的关系 1.1.4 HBase的核心功能模块 1.1.5 HBase的应用场景和经典案例 1.1.6 小结 本文参考于学校《HBase应用于开发》教材 1.1 HBase概述 本节将介绍大数据背景和HBase的基本概念&#xff0c…

TypeError: Assignment to constant variable.

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 &#x1f35a; 蓝桥云课签约作者、…

Chain of Draft: 借鉴人类草稿思维让大型语言模型更快地思考

这个研究探讨了大型语言模型&#xff08;LLMs&#xff09;在执行复杂推理任务时面临的计算资源消耗与响应延迟问题。研究特别聚焦于思维链&#xff08;Chain-of-Thought, CoT&#xff09;提示范式的效率局限性。CoT虽然有效&#xff0c;但在推理过程中需要生成冗长、详尽的逐步…

从零开始实现大语言模型(十三):预训练大语言模型GPTModel

1. 前言 使用梯度下降算法通过下一个token预测任务预训练大语言模型GPTModel&#xff0c;前向传播流程每次会输入一个batch的长度均为context_len的训练样本&#xff0c;执行 batch_size context_len \text{batch\_size}\times\text{context\_len} batch_sizecontext_len次下…

vue3:初学 vue-router 路由配置

承上一篇&#xff1a;nodejs&#xff1a;express js-mdict 作为后端&#xff0c;vue 3 vite 作为前端&#xff0c;在线查询英汉词典 安装 cnpm install vue-router -S 现在讲一讲 vue3&#xff1a;vue-router 路由配置 cd \js\mydict-web\src mkdir router cd router 我还…

档案AI审核1

需求&#xff1a; 处理扫描件和图像档案&#xff0c;解决AI决策能力&#xff0c;引入NLP和CV技术&#xff0c;形成多层次审核体系&#xff0c;解析jpg内容并校验结构&#xff0c;自定义训练审核模型&#xff0c;智能档案合规性检查&#xff0c;档案自动化审核&#xff0c;标注…

MC9S12单片机上电初始化过程及BOOTLOADER分析

上电过程 上电后&#xff0c;CPU从固定的位置读取复位向量。 这个固定的位置就是0xFFFE。是芯片厂商出厂时预设好的。 这个地址是NON_BANKED的。这个位置保存的是复位向量&#xff0c;实际上就是一个函数指针。该函数指针指向_Startup()函数。 map文件: 注意&#xff1a;程序…

Oxidized收集H3C交换机网络配置报错,not matching configured prompt (?-mix:^(<CD>)$)

背景&#xff1a;问题如上标题&#xff0c;H3C所有交换机配置的model都是comware 解决方案&#xff1a; 1、找到compare.rb [rootoxidized model]# pwd /usr/local/lib/ruby/gems/3.1.0/gems/oxidized-0.29.1/lib/oxidized/model [rootoxidized model]# ll comware.rb -rw-r--…

【算法方法总结·四】字符串操作的一些技巧和注意事项

【算法方法总结四】字符串操作的一些技巧和注意事项 【算法方法总结一】二分法的一些技巧和注意事项【算法方法总结二】双指针的一些技巧和注意事项【算法方法总结三】滑动窗口的一些技巧和注意事项【算法方法总结四】字符串操作的一些技巧和注意事项 【字符串操作】 此章节涉…

Halcon 算子 一维码检测识别、项目案例

首先我们要明白码的识别思路 把窗口全部关闭读取新的图片图像预处理创建条码模型设置模型参数搜索模型获取条码结果显示条码结果 图像预处理和条码增强 对比度太低&#xff1a; scale_image&#xff08;或使用外部程序scale_image_range&#xff09;,增强图像的对比度图像模糊…

STM32使用有源蜂鸣器

1.1 介绍&#xff1a; 有源蜂鸣器&#xff1a;内部自带振荡源&#xff0c;将正负极接上直流电压即可持续发声&#xff0c;频率固定 无源蜂鸣器&#xff1a;内部不带振荡源&#xff0c;需要控制器提供振荡脉冲才可发声&#xff0c;调整提供振荡脉冲的频率&#xff0c;可发出不同…

人工智能之数学基础:对线性代数中逆矩阵的思考?

本文重点 逆矩阵是线性代数中的一个重要概念,它在线性方程组、矩阵方程、动态系统、密码学、经济学和金融学以及计算机图形学等领域都有广泛的应用。通过了解逆矩阵的定义、性质、计算方法和应用,我们可以更好地理解和应用线性代数知识,解决各种实际问题。 关于逆矩阵的思…

数据仓库架构全解析:如何构建高效、有序的数据分层?

1.数仓架构规范 &#xff08;一&#xff09;分层架构规范 1.明确分层原则&#xff1a;通常遵循自下而上的 ODS&#xff08;操作数据存储层&#xff09;、DWD&#xff08;明细数据层&#xff09;、DWS&#xff08;汇总数据层&#xff09;、ADS&#xff08;应用数据层&#xff…

windows:curl: (60) schannel: SEC_E_UNTRUSTED_ROOT (0x80090325)

目录 1. git update-git-for-windows 报错2. 解决方案2.1. 更新 CA 证书库2.2. 使用 SSH 连接&#xff08;推荐&#xff09;2.3 禁用 SSL 验证&#xff08;不推荐&#xff09; 1. git update-git-for-windows 报错 LenovoLAPTOP-EQKBL89E MINGW64 /d/YHProjects/omni-channel-…