


How to achieve a scrolling loading effect similar to WeChat chat records in Vue?
Apr 04, 2025 pm 04:12 PMVue.js simulates the scrolling loading effect of WeChat chat history
This article demonstrates how to achieve a scrolling loading effect similar to WeChat chat records in Vue.js application. When the user scrolls to the top, more chat history is loaded and the scrollbar is in its current position rather than back to the top.
The following code provides a complete implementation solution:
<template> <div id="app"> <div class="container" ref="chatListRef"> <ul> <li v-for="item in msgs" :key="item">{{ item }}</li> </ul> </div> </div> </template> <script> import { ref, onMounted, nextTick } from 'vue'; export default { setup() { const msgs = ref([...generateNumbers(1, 200)]); // 初始數(shù)據(jù) const chatListRef = ref(null); const generateNumbers = (start, end) => { // 生成數(shù)字序列,此處可替換為實(shí)際數(shù)據(jù)加載邏輯 const numbers = []; for (let i = start; i <= end; i ) { numbers.push(i); } return numbers; }; const scrollToBottom = async () => { await nextTick(); // 確保DOM更新完畢 chatListRef.value.scrollTop = chatListRef.value.scrollHeight; }; const handleScroll = () => { const container = chatListRef.value; if (container.scrollTop === 0) { const prevScrollHeight = container.scrollHeight; const newMsgs = generateNumbers(msgs.value.length 1, msgs.value.length 100); // 加載更多數(shù)據(jù) msgs.value = [...newMsgs, ...msgs.value]; // 將新數(shù)據(jù)添加到數(shù)組頭部 nextTick(() => { container.scrollTop = container.scrollHeight - prevScrollHeight; }); } }; onMounted(() => { scrollToBottom(); }); return { msgs, chatListRef, handleScroll }; }, }; </script> <style scoped> * { margin: 0; padding: 0; } html, body { height: 100vh; background-color: #e9f5f8; } .container { width: 200px; height: 500px; overflow-y: auto; background-color: #fff; } </style>
The key to the code lies in the handleScroll
function: it listens for scroll events, and when the scrollbar reaches the top ( container.scrollTop === 0
), it loads new data, and uses nextTick
to ensure that after the DOM is updated, the scrollbar position is recalculated, thus keeping the scrollbar in its original position. The generateNumbers
function is a placeholder that needs to be replaced with your actual data loading logic (e.g., fetching data from the API). scrollToBottom
function scrolls the scrollbar to the bottom after the component is mounted.
This improved version is more concise and uses the onMounted
lifecycle hook function to initialize the scrollbar position, improving the readability and maintainability of the code. Remember to replace the generateNumbers
function for your actual data acquisition method.
The above is the detailed content of How to achieve a scrolling loading effect similar to WeChat chat records in Vue?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

As July 2025 approaches, the crypto market is hotly discussing which tokens may bring high returns. Are names like Pi, PEPE and FloppyPepe really worth the risky investment? Potential cryptocurrencies worth paying attention to in July 2025: virtual fire or real gold? As mid-2025, the heat of discussions on high-yield crypto assets continues to heat up. Bitcoin trends and "altcoin season" expectations have attracted investors' attention. Do tokens like PiNetwork, PEPE and FloppyPepe have the potential to bring considerable investment returns? Let's analyze its prospects one by one. Altcoin Market: Can July get what it wants? Against the backdrop of Bitcoin’s expected record of historical highs, the “altcoin season” seems to be brewing. Back

In today's era of rapid development of technology, the integration of artificial intelligence and blockchain is gradually becoming a new trend. The Sahara AI (SAHARA) project came into being, and it is committed to creating the first full-stack AI native blockchain platform, making the future of artificial intelligence more accessible, fair and just, and open to everyone.

Robinhood launched OpenAI and SpaceX tokenized stocks caused controversy, with Elon Musk and Sam Altman fighting each other over the nature of the so-called "fake equity". Recently, the intersection of Elon Musk, Sam Altman and Robinhood has become the focus of public attention, all of which stems from tokenized equity. Robinhood's launch of tokenized stocks in private companies such as OpenAI and SpaceX to European users has sparked heated debate and accompanied by clarification and criticism from all parties. Robinhood's tokenized equity: A bold attempt? Robin, led by CEO Vlad Tenev

Contents 1. What is ICN? 2. ICNT latest updates 3. Comparison and economic model between ICN and other DePIN projects and economic models 4. Conclusion of the next stage of the DePIN track At the end of May, ICN (ImpossibleCloudNetwork) @ICN_Protocol announced that it had received strategic investment in NGPCapital with a valuation of US$470 million. Many people's first reaction was: "Has Xiaomi invested in Web3?" Although this was not Lei Jun's direct move, the one who had bet on Xiaomi, Helium, and WorkFusion

Explore Remittix (RTX), Monero (XMR) and Crypto-Fiat Trends: How these projects shape the future of cryptocurrencies through practicality and community orientation. Remittix, Monero and Cryptocurrency Evolution: What is the hottest speculation? The crypto market is always in a dynamic change, and new and old projects are competing for investors' attention. Currently, Remittix (RTX), Monero (XMR) and crypto-fiat currency directions are becoming the focus of discussion. Let’s find out what driving forces are behind this wave of popularity? Remittix: The emerging token with emerging potential is gradually gaining market attention, and its development trajectory has been compared to the early stages of Bitcoin and Ethereum by some people. "CryptoR

Is Bitcoin the best cryptocurrency investment option now? Explore Bitcoin’s soar, rising altcoins and top P2E games. Bitcoin, Cryptocurrency, Buy Now: Interpreting the latest trends and hidden opportunities Bitcoin has been active recently, and the entire cryptocurrency market is hotly discussed. Is this the best time to buy? Let's dive into the latest trends and reveal potential investment opportunities in this ever-changing market. Bitcoin is rising strongly: breaking through $109,000 – What is the future trend? Bitcoin has recently successfully broken through the $109,000 mark, a rally affected by positive news from BlackRock ETF, improved global situation and depreciation of the dollar. This breakthrough once again inspired people to set a new high for it

How do novice users choose a safe and reliable stablecoin platform? This article recommends the Top 10 stablecoin platforms in 2025, including Binance, OKX, Bybit, Gate.io, HTX, KuCoin, MEXC, Bitget, CoinEx and ProBit, and compares and analyzes them from dimensions such as security, stablecoin types, liquidity, user experience, fee structure and additional functions. The data comes from CoinGecko, DefiLlama and community evaluation. It is recommended that novices choose platforms that are highly compliant, easy to operate and support Chinese, such as KuCoin and CoinEx, and gradually build confidence through a small number of tests.

WhiteRock founder Ildar Ilham was arrested in the UAE for ZKasino's $30 million "carpet pumping" incident. This indicates how the future of DeFi will develop? The cryptocurrency circle is hotly discussing the latest developments in the ZKasino incident. With WhiteRock founder Ildar Ilham being arrested in the UAE, it marks a gradual start to enforce the law under the accusation of “pulling carpets” involving the disappearance of $30 million in funds. The Fall of ZKasino: A quick look back at last year, the ZKasino platform was exposed to convert the 10,505 ETH deposited by users (about 27 million US dollars) into its own tokens and make it unable to withdraw, causing users to be shocked and panic. This behavior was quickly
