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; 
		
		
	}
相关推荐
Geek_Vison3 小时前
三款小程序容器技术选型对比分析——融媒新闻APP如何进行技术选型~
小程序·uni-app·app开发·finclip·小程序开发平台·跨端开发·小程序容器
DK1858383225214 小时前
知识付费会员小程序/付费圈子系统——课程兑换码+会员体系完整实战,开源运营级方案
小程序·uni-app·开源·php
陈龙龙的陈龙龙1 天前
uni-app中获取参数的几个方法
uni-app
果壳~1 天前
【Uniapp】【rich-text】富文本展示以及图片预览功能解决方案
前端·javascript·uni-app
雯0609~1 天前
微信小程序的原生开发项目如何转至uni-app
微信小程序·小程序·uni-app
四方云1 天前
Uni-app 跨端集成 SIP 电话功能(H5 + App)实战
uni-app
习明然2 天前
UniApp开发体验感受总结
前端·uni-app
anyup2 天前
全面重构的 uni-app 多平台上传组件,功能强到离谱!
前端·vue.js·uni-app
LIO2 天前
一套代码,多端并行——uni-app + Vue3 多端开发完全指南
前端·vue.js·uni-app