仿微信点击回复,输入框定位到列表的底部

最近设计提了这么一个需求,就是要仿微信的朋友圈,点击回复的时候,输入框要定位到当前item的底部,为了这么一个小小的功能,把姐姐我折腾了三天,真的是用尽了办法,最后发现,其实真的不是很难,功能实现之后,我的第一反应就是要写一篇博客,希望被同样问题困扰的开发的小白能够有些帮助.

需求的功能:

这里写图片描述
这就是设计想要的效果,就是点击回复的按钮的时候,对话框要定位到这个动态的底部.

一开始真的很懵,根本不知道该从何下手,后来也查找了一些文章,开始自己着手做:
这里有两个方案:
方案一:屏幕总高度-键盘高度-回复的文本输入框-状态栏高度-标题栏高度-当前被点击项的高度=偏移量。(但是问题是还有回复的列表的高度也要计算,并且这些高度并非是固定的,因此这样算出来的可能会有一定的误差,如果是回复列表过长,误差就会更大)
方案二:使用setSelectionFromTop滚动到下一个position,并移动一定距离,offset是整个屏幕可显示内容的高度(就是屏幕高度减去键盘高度、状态栏高度、输入框高度、剩下的即为屏幕高度),当position是最后一个时直接滚动到底部,当是第一个时还要判断头部高度是否够滚动,可以通过下一个item的xy坐标来判断(微信朋友圈因为有一个头部图片,所以第一个item不用担心滚动的距离不够)。

我尝试用第一个方案解决,但是发现难度真的挺大,很多值都获取不到,于是,我决定采用第二个方案:

方案二需要的值有软键盘的高度,状态栏的高度,输入框的高度,以及屏幕的高度

因为使用s

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
2021已然来临,在此之际debug抽空撸了一套 类似“QQ空间”、“新浪微博”、“微信朋友圈”PC版的互联网社交软件系统,并将其录制成了视频,特此分享给诸位进行学习,以掌握、巩固更多的技术栈和项目、产品开发经验! 言归正常,下面以问答的方式重点介绍下本门课程/系统的相关内容!  (1)问题一:这是一门什么样的课程? 本门课程是一门项目实战课程,基于Spring Boot2.X开发的一款类似“新浪微博”、“QQ空间”、“微信朋友圈”PC版的互联网社交软件,包含完整的门户网前端 以及 后台系统管理端,可以说是一套相当完整的系统!,大纲图如下所示:  而整个系统的系统架构设计如下图所示(注意:该图表示的是整个系统架构将经历N个阶段的演进,目前初定是4个阶段的演进,分别是架构1.0、2.0、3.0、4.0 !)   (2)问题二:可以学到哪些技术? 本课程对应着系统架构1.0,即第一阶段,主要的目标在于实现一个完整的系统,可以学到的技术还是比较多的:Spring Boot2.X、Java基础、Java8、JUC、NIO、微服务、分布式、系统架构设计、SpringMVC、MySQL、Lucene、多线程、并发编程、Bootstrap、HTML5、CSS3、JQuery、AdminLTE、VUE、LayUI相关组件等等 从架构2.0,即第二阶段的内容(对应第2门课程)开始将慢慢融入更多地技术栈,用以解决更多的业务、性能和服务拆分等问题!本门课程是后续其他阶段对应的课程的奠基,因此如果想要学习后续架构2.0、3.0、4.0的演进,则必须得先学习本门课程!   (3)问题三:系统运行起来有效果图看吗?   (4)问题四:学习本课程之前有什么要求? 要求的话,主要有两点,一是要有一定的Spring Boot、MySQL 以及 Web开发基础;二是最好学过Debug录制的 “企业权限管理平台(Spring Boot2.X+Shiro+Vue)”项目实战课程,因为本门课程“仿微博系统全程实战”的后台管理正是基于 “企业权限管理平台”项目二次开发的,因此建议最好先撸了那个课程再来学习本门课程! 友情提示:“企业权限管理平台(Spring Boot2.X+Shiro+Vue)”项目实战课程的购买学习地址:https://edu.csdn.net/course/detail/25646  (TIP:可以考虑购买组合套餐课程哦,更加实惠!!!)  岁末将至,人心浮躁 当此之际,应当沉下心,摒弃浮躁 要相信技术是第一生产力 相信技术改变生活、技术成就梦想! 特别是那些即将在过完年准备跳槽面试的小伙伴,本系统将可以为你增添几分亮点!!!  寄语:购买本课程的小伙伴将可获得本课程完整的视频教程、系统源代码数据库、课件PPT以及其他相关的工具跟资料,还可以进专属技术交流群交流技术!!!
以下是使用uniapp实现仿微信支付密码输入框的示例代码: ```html <template> <view class="container"> <view class="input-box"> <view v-for="(item, index) in inputList" :key="index" class="input-item" :class="{ 'input-item-active': index === currentIndex }" > <view class="input-dot" v-show="item !== ''"></view> </view> </view> <view class="keyboard"> <view class="keyboard-row" v-for="row in keyboard" :key="row"> <view class="keyboard-item" v-for="key in row" :key="key" @click="handleKeyClick(key)" > {{ key }} </view> </view> </view> </view> </template> <script> export default { data() { return { inputList: ['', '', '', '', '', ''], // 输入框列表 currentIndex: 0, // 当前输入框索引 keyboard: [ ['1', '2', '3'], ['4', '5', '6'], ['7', '8', '9'], ['', '0', '删除'] ] // 键盘布局 }; }, methods: { handleKeyClick(key) { if (key === '删除') { if (this.currentIndex > 0) { this.currentIndex--; this.inputList[this.currentIndex] = ''; } } else { if (this.currentIndex < this.inputList.length) { this.inputList[this.currentIndex] = key; this.currentIndex++; } } } } }; </script> <style> .container { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100vh; } .input-box { display: flex; justify-content: space-between; width: 300rpx; height: 50rpx; border: 1rpx solid #ccc; border-radius: 4rpx; overflow: hidden; } .input-item { flex: 1; display: flex; align-items: center; justify-content: center; font-size: 24rpx; color: #333; } .input-item-active { background-color: #f5f5f5; } .input-dot { width: 10rpx; height: 10rpx; border-radius: 50%; background-color: #333; } .keyboard { margin-top: 20rpx; } .keyboard-row { display: flex; justify-content: space-between; margin-bottom: 10rpx; } .keyboard-item { display: flex; align-items: center; justify-content: center; width: 100rpx; height: 100rpx; border: 1rpx solid #ccc; border-radius: 4rpx; font-size: 32rpx; color: #333; } </style> ``` 这段代码实现了一个简单的支付密码输入框,包括自定义的输入框样式和键盘布局。用户可以点击键盘上的数字输入密码,点击删除按钮可以删除已输入的密码。输入的密码会在输入框中显示为黑色圆点。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值