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; 
		
		
	}
相关推荐
用户6990304848752 天前
try catch使用场景 处理同步代码错误兼容用的
javascript·uni-app
ITKEY_2 天前
uniapp微信开发者工具 更改AppID失败 touristappid
uni-app
Geek_Vison3 天前
APP瘦身实战:从80MB+砍到15MB——基于小程序容器技术剥离APP非核心业务的实践分享
小程序·uni-app·mpaas
CHB3 天前
HDC2026 演讲实录|AI 驱动的跨端进化:利用 uni-agent 快速构建高性能鸿蒙应用
uni-app·harmonyos
2501_915918414 天前
iOS App性能测试工具的实现方法与优化循环指南
android·ios·小程序·https·uni-app·iphone·webview
斯内普吖4 天前
(开源)高校素拓分管理系统小程序实战指南 基于 Java + SpringBoot + uni-app + Vue + MySQL
java·spring boot·mysql·小程序·uni-app·开源
海阔天空66884 天前
uniapp开启调试模式
uni-app·uniapp开启调试模式
anyup5 天前
分享 5 套 uni-app 实用主题,一键适配暗黑模式
前端·uni-app·视觉设计
gg159357284605 天前
Uni-app跨平台开发全解课程:从零基础到企业级多端落地实战
vue.js·uni-app
xshirleyl6 天前
uniapp小兔鲜儿day3
uni-app