uniapp消息会话界面【消息滚动到底部】-02

实现:每次页面进入,以及发送消息都自动定位到最后一条消息

对关键代码解读如下:

scroll-into-view : 值应为某子元素id(id不能以数字开头)。设置哪个方向可滚动,则在哪个方向滚动到该元素 。我设置scroll-y方向(垂直)

scrollToId : 值为 'scrollToBottom' 或 '' 【空字符】 ,值为 'scrollToBottom'的时候就会滚动到底部

id : 表示消息列表中第一个元素的时候,id为 'scrollToBottom'

unshift头部插入 : chatData聊天数据列表中,第一条数据是最新的数据,消息3,消息2,消息1

css样式:

flex-direction: column-reverse; // 将排列方式翻转, 因为chatData列表,第一条为最新数据,需要将它显示到界面的最底部,故翻转

overflow: hidden; // 将超出的数据隐藏

复制代码
<scroll-view class="chat-container" scroll-y :scroll-into-view="scrollToId">
	<view class="msg-contant">
        <view v-for="(item, index) in chatData" :key="index">
            <view :id="index === 0 ? 'scrollToBottom' : ''">消息{{index}}</view>
        </view>
    </view>
</scroll-view>

---------js代码------
<script>
	export default {
		data() {
			return {
				scrollToId: 'scrollToBottom',
				chatData: [],// 所有聊天数据
			};
		},
		
		methods: {
			
			sendMessage() {
				if (!this.inputText.trim()) return;
				this.chatData.unshift('头部插入消息');
				this.inputText = '';
				this.scrollToBottom();
			},
			scrollToBottom() {
				this.$nextTick(() => {
					this.scrollToId = '';
					setTimeout(() => {
						this.scrollToId = 'scrollToBottom';
					}, 50);
				});
			},
			
		}
	};
</script>





-------css样式----
	.chat-container {
		flex: 1;
		padding: 24rpx;
		box-sizing: border-box;
		height: 100%;
		overflow: hidden;

	}

	.msg-contant {
		display: flex;
		flex-direction: column-reverse; 
		
		
	}
相关推荐
2501_916007471 天前
iOS应用性能优化全面指南:从内存管理到工具使用
android·ios·性能优化·小程序·uni-app·iphone·webview
巴博尔2 天前
UNIAPP中NVUE页面 动画
android·前端·javascript·ios·uni-app
边界条件╝2 天前
uniapp 深度使用
uni-app
路光.2 天前
uniapp小程序/App使用webview打通麦克风权限实现录音功能
小程序·uni-app·app
xiaoyan20152 天前
全新首发uniapp+deepseek-v4三端通用智能ai助手
uni-app·ai编程·deepseek
anyup2 天前
【最全鸿蒙】uni-app 转鸿蒙:从打包失败到商店上架成功全过程
前端·uni-app·harmonyos
2501_915106322 天前
深入解析HTTPS抓包原理、中间人攻击及反抓包技术攻防
数据库·网络协议·ios·小程序·https·uni-app·iphone
游戏开发爱好者82 天前
React Grab工具详解:AI助力Vue3、Svelte和Solid前端元素调试
android·ios·小程序·https·uni-app·iphone·webview
sN2vuQ08W3 天前
uni-app 实现视频聊天、屏幕分享,支持Android、HarmonyOS、iOS
android·uni-app·音视频
遗憾随她而去.3 天前
uniapp App平台 真机运行
uni-app