uniapp實現聊天中的接發消息自動滾動、消息定位和回到底部

前言

前言無需多言,想必大家對聊天軟件的功能已經很熟悉, 這里不做過多贅述,筆者通過uniapp實現聊天中的接發消息自動滾動、消息定位和回到底部。

代碼實現

<template><view class="chat-container"><!-- 消息列表 --><scroll-viewclass="message-list"scroll-ystyle="height: 300px;"upper-threshold="200":scroll-into-view="'message-item-' + scrollMsgIdx":scroll-with-animation="true"@scroll="handleScroll"><view class="message-item-box" v-for="(item, idx) in chatMessageList" :key="item.id" :id="'message-item-' + idx"><view :class="['message-item', item.self === true ? 'right' : 'left']"><view class="message-content">{{ item.content }}</view></view></view></scroll-view><view class="back-to-bottom-btn" @click="scrollToBottom" v-if="showBackBottomBtn">回到底部</view><!-- 輸入區域 --><view class="content-area"><view class="input-box"><textarea v-model="inputText" placeholder="輸入內容" maxlength="500" auto-height/></view><button class="send-btn" @click="sendMsg" size="mini">發送</button><button class="jump-btn" @click="jumpMsg" size="mini">定位</button></view></view>
</template><script setup>
import {onLoad} from '@dcloudio/uni-app';
import {nextTick, ref} from "vue";const scrollMsgIdx = ref(0); // 滾動控制
const showBackBottomBtn = ref(false); // 回到底部按鈕顯示
const inputText = ref(''); // 輸入文本
const chatMessageList = ref([{id: 0, content: '請求添加你為好友?', self: false},{id: 1, content: '你好', self: false},{id: 2, content: '你是誰啊?', self: true},{id: 3, content: '我是你爸爸啊', self: false},{id: 4, content: '???', self: true},{id: 5, content: '我是你爺爺', self: true},{id: 6, content: '你真的是個老六', self: false},{id: 7, content: '誰讓你張口就來', self: true},{id: 8, content: '再問一遍你是誰?', self: true},{id: 9, content: '我是張三,你叔叔介紹的相親對象', self: false},{id: 10, content: '哦哦', self: true},{id: 11, content: '那你今年多大了?', self: true},{id: 12, content: '27', self: false},{id: 13, content: '那你哪個學校畢業的啊?', self: true},{id: 14, content: '在哪里工作?', self: true},{id: 15, content: '畢業于家里蹲大學', self: false},{id: 16, content: '現在沒工作', self: false},{id: 17, content: '啊?那你用錢了怎么辦啊', self: true},{id: 18, content: '你管我啊', self: false},{id: 19, content: '那你自己看著辦吧!', self: true},{id: 20, content: '好的', self: false},{id: 21, content: '不用你操心哦', self: false},{id: 22, content: '替你家長操心!', self: true},{id: 23, content: '那也不需要', self: false},{id: 24, content: '你大學學的啥啊?工作都找不到', self: true},{id: 25, content: '大學光掛科去了', self: false},{id: 26, content: '那怪不得', self: true},{id: 27, content: '好自為之吧', self: true},
]); // 消息列表onLoad(() => {// 回到底部scrollToBottom();
});// 發送消息
function sendMsg() {if (!inputText.value.trim()) {console.log('不能發送空白信息');return;}chatMessageList.value.push({id: Date.now(), content: inputText.value, self: true});inputText.value = '';chatMessageList.value.push({id: Date.now(), content: '自動回復', self: false});// 回到底部scrollToBottom();
}// 跳轉指定消息
function jumpMsg() {if (!inputText.value.trim()) {console.log('不能發送空白信息');return;}scrollToMsgIdx(Number(inputText.value));inputText.value = '';
}// 滾動事件處理
function handleScroll(e) {const { scrollTop, scrollHeight } = e.detail;const screenHeight = uni.getSystemInfoSync().screenHeight;showBackBottomBtn.value = scrollHeight - screenHeight - scrollTop > 50;
}// 滾動到底部
function scrollToBottom() {let length = chatMessageList.value.length;if (length > 0) {scrollToMsgIdx(length - 1);}
}// 滾動到指定消息
function scrollToMsgIdx(idx) {nextTick(() => {scrollMsgIdx.value = (idx < 0 || idx > chatMessageList.value.length - 1) ? 0 : idx;showBackBottomBtn.value = chatMessageList.value.length - 1 - scrollMsgIdx.value > 0;});
}
</script><style lang="scss" scoped>
.chat-container {display: flex;flex-direction: column;height: 100vh;background-color: #f5f5f5;.message-list {flex: 1;margin-top: 10px;overflow: auto;background-color: #f5f5f5;.message-item-box {margin: 10px;}.message-item {display: flex;&.left {justify-content: flex-start;.message-content {margin-left: 10px;background-color: #fff;}}&.right {justify-content: flex-end;.message-content {margin-right: 10px;background-color: #95ec69;}}.message-content {max-width: 70%;border-radius: 2px;box-sizing: border-box;word-break: break-word;height: auto;padding: 10px;}}}.content-area {display: flex;align-items: center;padding: 8px 10px;background-color: #fff;border-top: 1px solid #eee;.input-box {flex: 4;textarea {box-sizing: border-box;width: 100%;background-color: #f5f5f5;border-radius: 4px;padding: 8px;font-size: 14px;}}.send-btn {flex: 1;text-align: center;align-items: center;background-color: #07c160;color: #ffffff;font-size: 12px;padding: 2px !important;}.jump-btn {flex: 1;text-align: center;align-items: center;background-color: #97aca1;color: #ffffff;font-size: 12px;padding: 2px !important;}}.back-to-bottom-btn {position: fixed;bottom: 55px;right: 10px;background-color: #575859;color: #ffffff;padding: 5px;border-radius: 4px;font-size: 12px;z-index: 999;}
}
</style>

演示

接發消息自動滾動

發送和接收消息都可以自己滾動到最新消息!
在這里插入圖片描述
在這里插入圖片描述

消息定位

為簡化代碼,消息框直接輸入消息的索引號,即可定位對應消息,你可以自己添加樣式!
在這里插入圖片描述
在這里插入圖片描述

回到底部

點擊回到底部按鈕即可!
在這里插入圖片描述

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/85371.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/85371.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/85371.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MyBatisMyBatis plus

整合 MyBatis 到 Spring 或 Spring Boot 項目中&#xff0c;可以極大地簡化開發流程&#xff0c;尤其是當使用 Spring Boot 時&#xff0c;它提供了自動配置功能&#xff0c;使得集成更加簡便。 在 Spring Boot 中整合 MyBatis 1. 添加依賴 首先&#xff0c;在 pom.xml 文件中…

Stable Diffusion 實戰-手機壁紙制作 第二篇:優化那些“崩臉”和“馬賽克”問題,讓圖像更加完美!

歡迎回來!在《StableDiffusion實戰-手機壁紙制作》系列的第一篇中,我們成功完成了基礎操作,制作出了令人炫目的手機壁紙。 今天,我們將進入一個更高階的領域——優化處理。因為誰不想讓生成的藝術品更完美呢?尤其是避免“崩臉”和“馬賽克”這種讓人抓狂的問題! 創作的路…

408第一季 - 數據結構 - B樹與B+樹

B樹 性質 可以看見一個節點可以有多個數字了 然后也滿足左小右大的特征 然后所有的葉子節點都在同一層&#xff0c;然后2個數字的節點就可以有3個分支 然后呢&#xff0c;每個節點里面到底有幾個數字是有規定的公式的 就這個公式&#xff0c;m是5階的&#xff0c;算出來是2和…

SSRF5 Gopher 協議對內網 Web 服務進行 sql 注入 GET 類型和POST類型

實驗環境&#xff1b; Centos7.6上同時安裝sqli-lib和pikachu 一.Gopher 協議對內網 Web 服務進行 sql 注入 GET 類型 我們先訪問sqli-lib第1關 然后我們構造URL&#xff1a; http://192.168.112.12/pikachu-master/vul/ssrf/ssrf_curl.php?urlhttp://192.168.112.12/sql…

Python打卡DAY31

DAY31&#xff1a;文件的規范拆分和寫法 恩師浙大疏錦行 知識點&#xff1a; 規范的文件命名規范的文件夾管理機器學習項目的拆分編碼格式和類型注解 一、機器學習項目流程&#xff1a; 1、數據加載&#xff1a;從文件、數據庫、API 等獲取原始數據。 - 命名參考&#xff1a;…

字符串大數 -減法

描述 以字符串的形式讀入兩個數字&#xff0c;編寫一個函數計算它們的和&#xff0c;以字符串形式返回。 代碼實現 大小判斷&#xff1a;a - b 與 b - a 的絕對值相等將大的數放前面&#xff0c;抽離出結果的符號 import random s, t str(random.randint(1000, 9999)), s…

android google tts如何不聯網內部預置多國語音包

在內置Google GMS服務的設備中&#xff0c;可以正常使用TTS&#xff0c;并且可以聯網下載多國的語音包。然而&#xff0c;對于未通過GMS認證&#xff0c;只能使用基礎的TTS英語播報&#xff0c;而且聯網后是無法下載語音包的&#xff0c;會提示需要google service。本文基于以上…

Java 全棧開發學習:從后端基石到前端靈動的成長之路

目錄 一、開篇&#xff1a;與 Java 全棧的初遇 二、后端學習&#xff1a;SpringBoot 構建穩健基石 &#xff08;一&#xff09;SpringBoot3 入門&#xff1a;簡約而不簡單的啟程 &#xff08;二&#xff09;Spring Boot Web 應用開發&#xff1a;構建交互橋梁 &#xff08;…

AquaCrop模型源代碼分析、模型優化與敏感性分析、未來氣候變化影響分析

AquaCrop是由世界糧食及農業組織&#xff08;FAO&#xff09;開發的一個先進模型&#xff0c;旨在研究和優化農作物的水分生產效率。這個模型在全球范圍內被廣泛應用于農業水管理&#xff0c;特別是在制定農作物灌溉計劃和應對水資源限制方面顯示出其強大的實用性。AquaCrop 不…

開源模型應用落地-讓AI更懂你的每一次交互-mem0-QDrant-Streamlit(一)

一、前言 在人工智能迅猛發展的今天,大型語言模型(LLM)已經成為各行各業的重要工具。然而,盡管這些模型在生成文本、理解語義等方面表現出色,但它們仍然面臨一個關鍵挑戰——缺乏持久的記憶能力。傳統的對話系統往往只能基于當前對話輪次進行回應,無法有效保留和利用歷史…

RPC - Response模塊

Requestor 類是一個請求-響應管理器&#xff0c;負責發送請求并處理響應&#xff0c;支持三種交互模式&#xff1a;同步、異步和回調。它跟蹤所有發出的請求&#xff0c;當響應到達時將其匹配到對應的請求并進行處理。 newDescribe 函數解析 newDescribe 函數負責創建和注冊一…

超高速10G采集卡

超高速10G采集卡是一款高端14位數據采集平臺&#xff0c;旨在滿足最具挑戰性的測量環境。 特性: 單通道和雙通道操作 單通道10GSPS或雙通道5GSPS 7 GByte/s持續數據傳輸速率開放式FPGA支持實時DSP 脈沖檢測固件選項波形平均固件選項 特征 單通道和雙通道工作模式雙通道5G…

One-Hot、BOW、TF-IDF、N-Gram區別

1. One-Hot Encoding (獨熱編碼) 核心思想&#xff1a; 為語料庫&#xff08;所有文檔的集合&#xff09;中的每個唯一單詞創建一個維度。對于一個特定的單詞&#xff0c;在其對應的維度上標記為1&#xff0c;在所有其他維度上標記為0。 表示&#xff1a; 一個非常長的二進制向…

產品經理如何做用戶調研和訪談

用戶調研和訪談是產品經理挖掘用戶需求、優化產品設計的核心環節。在一個完整的產品流程里面&#xff0c;用戶調研和訪談是非常重要的。 當年史玉柱推出腦白金時&#xff0c;就曾帶領團隊在江蘇很多城市進行了大量的走訪&#xff08;用戶調研&#xff09;&#xff0c;和一幫老…

【python 讀取抖音/小紅書/微博今日頭條/百度熱點等平臺的熱點新聞】

輕松獲取全網熱點&#xff0c;Python助你掌握實時輿情 在信息爆炸的時代&#xff0c;抖音、小紅書、微博、今日頭條和百度熱點等平臺每天都會產生海量熱門內容。無論是品牌營銷、競品分析還是輿情監控&#xff0c;掌握這些熱點新聞至關重要。利用Python的強大爬蟲技術&#xff…

【1.3 MySQL知識庫 - 輕松理解版】

&#x1f680; MySQL知識庫 - 輕松理解版 一、MySQL核心知識順口溜 &#x1f3b5; &#x1f3a4; 經典記憶口訣 MySQL數據庫&#xff0c;InnoDB引擎強 ACID事務特性&#xff0c;隔離級別四檔 索引加速查詢&#xff0c;B樹是主梁 主從復制備份&#xff0c;讀寫分離扛 鎖機制防…

計算機網絡期末速成 網絡層 判斷及單選題

判斷題 路由器和鏈路層交換機都被稱為分組交換機。路由器與鏈路層交換機間的根本區別是:路由器在網絡層存儲轉發IP數據報&#xff0c;鏈路層交換機在鏈路層存儲轉發幀。 A. 對 B. 錯 答案: 對 解析: 路由器和鏈路層交換機確實都是分組交換機&#xff0c;但工作層次不同。路由器…

代理 AI 時代的隱私重構:從邊界控制到信任博弈

過去&#xff0c;我們將隱私等同于邊界與權限控制&#xff0c;依賴墻壁、鎖和規則構筑防線。而如今&#xff0c;隨著代理 AI 深度介入生活&#xff0c;成為能感知、決策的自主實體&#xff0c;它不僅處理數據&#xff0c;更在重塑我們的數字形象與內在認知。在此背景下&#xf…

C++實現手寫strstr函數

strstr 函數用于在主字符串中查找子字符串的首次出現位置,以下是高效的實現方案: KMP算法優化版本 #include <iostream> #include <string> #include <vector> using namespace std; // 計算KMP算法的部分匹配表(PMT) vector<int> getNext(const…

Linux操作系統網絡服務模塊一SSH帶外管理概述

前言&#xff1a; 在復雜的網絡運維環境中&#xff0c;?SSH帶外管理&#xff08;Out-of-Band Management&#xff09;?? 是確保系統高可用性的核心技術手段。區別于依賴業務網絡的“帶內管理”&#xff0c;帶外管理通過獨立物理通道?&#xff08;如專用管理網口或串…