亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發(fā) > HTML5 > 正文

HTML5實現(xiàn)直播間評論滾動效果的代碼

2024-09-05 07:23:31
字體:
來源:轉載
供稿:網(wǎng)友

直播間評論滾動效果,下劃查看歷史消息并停止?jié)L動,如有新消息會出現(xiàn)新消息提醒,點擊滾動到底部。

2.具體代碼

<template>    <div class="comment">    	<div class="comment-wrap" ref="wrapper">	    <ul class="list" ref="list">    	        <li v-for="item in list" :key="item.id">    		    <span class="name">{{item.name}}:</span>    		    <span class="content">{{item.content}}</span>    	        </li>            </ul>    	</div>    	<div class="rest-nums" v-show="restComment" @click="scrollBottom">{{restComment}}條新消息</div>    </div></template>
<script>import smoothscroll from 'smoothscroll-polyfill';import { debounce, isScrollBottom } from '../utils/utils';smoothscroll.polyfill(); // 移動端scrollTo behavior: "smooth"動畫失效的polyfillexport default {  data() {    return {        list: [],        restComment: 0,        restNums: 0,        wrapperDom: null,        listDom: null,        wrapperHeight: 0    };  },  mounted() {     this.initDom();     // ajax...     const data = new Array(20).fill('');     this.queue(data);     setTimeout(() => {         const list = new Array(10).fill('');	 this.queue(list);      }, 30000);  },  methods: {      initDom() {          this.wrapperDom = this.$refs.wrapper;          this.listDom = this.$refs.list;          this.wrapperHeight = this.wrapperDom.offsetHeight;      },      addTimeOut(opt) {    	   return new Promise((resolve, reject) => {    		setTimeout(() => {    			this.addComment(opt);    			resolve()    		}, 500);    	   });       },	// 隊列添加消息	async queue(data) {    	    for (let i = 0; i < data.length; i++) {    		const opt = {    			name: i + "-用戶名",    			content: i + "-評論內(nèi)容",    			id: Date.now()    		}    		await this.addTimeOut(opt);    	    }	},        addScroll() {            debounce(this.listScroll, 200);            this.isBindScrolled = true;        },        listScroll() {            const ele = this.wrapperDom;            const isBottom = isScrollBottom(ele, ele.clientHeight);            if (isBottom) {		this.restNums = 0;		this.restComment = 0;            }        },	// 添加評論 如果超過150條就將前50條刪除        addComment(data) {            if (this.list.length >= 150) {                this.list.splice(0, 50);            }	    this.list.push(data);	    this.$nextTick(() => {		this.renderComment();	    });	},	// 渲染評論        renderComment() {            const listHight = this.listDom.offsetHeight;            const diff = listHight - this.wrapperHeight; // 列表高度與容器高度差值	    const top = this.wrapperDom.scrollTop; // 列表滾動高度            if (diff - top < 50) {                 if (diff > 0) {                    if (this.isBindScrolled) {                        this.isBindScrolled = false;                        this.wrapperDom.removeEventListener("scroll", this.addScroll);                    }                    this.wrapperDom.scrollTo({                        top: diff + 10,                        left: 0,                        behavior: "smooth"        	    });                    this.restNums = 0;                }            } else {                ++this.restNums;                if (!this.isBindScrolled) {                    this.isBindScrolled = true;                    this.wrapperDom.addEventListener("scroll", this.addScroll);                }            }	    this.restComment = this.restNums >= 99 ? "99+" : this.restNums;    	},	// 滾動到底部        scrollBottom() {	    this.restNums = 0; // 清除剩余消息	    this.restComment = this.restNums;            this.wrapperDom.scrollTo({                top: this.listDom.offsetHeight,                left: 0,                behavior: "smooth"            });        }    }};</script>
<style scoped>    *{    	padding: 0;    	margin: 0;    }    .comment{    	width: 70%;    	height: 350px;    	position: relative;    	margin: 100px 0 0 20px;    }    .comment-wrap{    	height: 350px;    	overflow-y: scroll;    	-webkit-overflow-scrolling:touch;    }    .comment-wrap li{    	text-align: left;    	line-height: 30px;    	padding-left: 10px;    	background: rgba(0, 0, 0, 0.3);    	margin-top: 5px;    	border-radius: 15px;    	color: #fff;    }    .rest-nums{    	position: absolute;    	height: 24px;    	line-height: 24px;    	color: #f00;    	border-radius: 15px;    	padding: 0 15px;    	bottom: 10px;    	background: #fff;    	font-size: 14px;    	left: 10px;    }</style>

用的的兩個工具函數(shù)

/** * @desc 函數(shù)防抖 * @param {需要防抖的函數(shù)} func * @param {延遲時間} wait */export function debounce(func, wait = 500) {    // 緩存一個定時器id    let timer = 0;    // 這里返回的函數(shù)是每次用戶實際調(diào)用的防抖函數(shù)    // 如果已經(jīng)設定過定時器了就清空上一次的定時器    // 開始一個新的定時器,延遲執(zhí)行用戶傳入的方法    return function (...args) {    	if (timer) clearTimeout(timer)    	timer = setTimeout(() => {    		func.apply(this, args)    	}, wait)    }}/** * @desc 是否滾到到容器底部 * @param {滾動容器} ele  * @param {容器高度} wrapHeight  */export function isScrollBottom(ele, wrapHeight, threshold = 30) {    const h1 = ele.scrollHeight - ele.scrollTop;    const h2 = wrapHeight + threshold;    const isBottom = h1 <= h2;    return isBottom;}

總結

到此這篇關于HTML5實現(xiàn)直播間評論滾動效果的代碼的文章就介紹到這了,更多相關H5直播間評論滾動內(nèi)容請搜索武林網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持武林網(wǎng)!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
成人午夜亚洲| 黄色三级高清在线播放| 国内精品伊人久久久| 亚洲男人的天堂成人| 日韩一区二区三区视频| 亚洲国产精品视频在线观看| gogogo影视剧免费观看在线观看| 草草久久久无码国产专区| 国产精品久久久久7777按摩| 国产一区91| 天天躁日日躁狠狠躁免费麻豆| 中文字幕三级电影| 自拍视频在线免费观看| 26uuu国产日韩综合| 国产精品视频首页| 欧美特黄一级大片| 日韩久久久久久| 蜜桃传媒入口| 中文字幕在线国产| 开心婷婷激情五月| 中文精品99久久国产香蕉| 欧美一区二区三区在线观看视频| 国产有码在线| 丁香六月久久综合狠狠色| 久久五月婷婷丁香社区| 在线观看操人| 女囚岛在线观看| 福利视频第一页| 午夜视频在线观看网站| 正在播放国产对白害羞| 国产人妖乱国产精品人妖| 一级片免费观看视频| 亚洲第一福利专区| 亚洲福利在线看| 国产精品白丝jk喷水视频一区| 国内精品卡一卡二卡三新区| 亚洲最大成人综合网| 国产三级在线免费| 国产精品亚洲午夜一区二区三区| 色欲AV无码精品一区二区久久| 蜜臀久久99精品久久久久久| 日本在线视频中文字幕| 女优一区二区三区| 在线黄色免费网站| 亚洲视频一区二区在线观看| 一区二区三区蜜桃| 在线观看国产一级片| 国产欧美一区二区三区四区| 国产精品一区二区久久精品| 欧洲亚洲一区二区三区四区五区| 天天色综合社区| 国产aⅴ精品一区二区三区色成熟| 福利小视频在线观看| 91中文字幕在线播放| 久久99久久人婷婷精品综合| 色综合久久久久综合99| 亚洲国产精品久久久久| 18精品爽国产三级网站| 国产免费视频一区二区三区| 国产乱淫av片免费| 极品一线天粉嫩虎白馒头| 成人av在线播放| 欧美一区二区三区免费大片| 色综合综合色| 国产精选一区二区三区不卡催乳| 日本不卡二三区| japanese日本护士撒尿| 亚洲AV无码国产成人久久| 精品乱码一区内射人妻无码| 91久久国语露脸精品国产高跟| 成人亚洲综合| 看看黄色一级片| 欧美在线视频第一页| 精品国产www| 精品少妇一区二区三区在线视频| 欧美一级淫片a免费视频| 最新中文字幕av专区| 成人免费视频在线观看| 在线一区亚洲| 成年在线播放小视频| 亚洲最大黄色| 国模吧无码一区二区三区| 国产极品嫩模在线视频一区| 深夜在线视频| 亚洲精品久久久久久久蜜桃臀| 尤物视频在线观看视频| av免费网站在线| 亚洲国产精品久久久| 深夜在线视频| 国产毛片毛片毛片毛片毛片| 欧美黄色免费影院| 欧美极品另类| 91免费观看视频在线| 天天躁日日躁狠狠躁超碰2020| 久操成人av| 欧美一区二区三区婷婷月色| 日韩视频 中文字幕| 福利视频久久| 霍思燕三级露全乳照| 亚洲综合婷婷| 夜夜嗨av一区二区三区四季av| 秋霞一区二区三区| 成人毛片一区二区三区| 国产福利电影在线播放| 色先锋久久av资源部| 久久综合成人网| 91网址在线观看精品| 日韩免费电影| av不卡免费看| 国产精品久久久久久亚洲色| 欧美videossex另类| 怡红院精品视频| 天天操天天操天天色天天要| 五月婷婷综合色| 国产精品第一页第二页第三页| 宅男宅女性影片资源在线1| 欧美日中文字幕| 久久久久久国产精品三级玉女聊斋| 久久午夜影视| 国产精品久久久久久久久免费桃花| 91老师片黄在线观看| 亚洲精品永久免费视频| 国产精品影院在线观看| 日韩专区一卡二卡| 在线观看17c| 天天操天天干天天综合网| 曰本女人与公拘交酡| 欧美人与禽性xxxxx杂性| 国产精品一区二区三区视频网站| 亚洲国产日韩在线一区模特| 欧美一卡2卡三卡4卡5免费| 日韩久久99| 亚洲免费视频在线观看| 激情综合网五月婷婷| 亚洲欧美日韩系列| 国产人妻人伦精品| 97超级碰碰人国产在线观看| 国产一区二区三区四区五区美女| 久久精品一区二区三区不卡| 亚洲乱码国产乱码精品精软件| 色88久久久久高潮综合影院| 99在线小视频| 日韩中文字幕一区二区| 91久久电影| 日韩一级片免费看| 欧美成人免费网站| 极品美女扒开粉嫩小泬| 亚洲国产综合在线| 免费av在线播放| 免费羞羞视频| 日本va欧美va精品发布| www.国产二区| 狠狠干 狠狠操| 欧美色婷婷天堂网站| 国产999视频| 免费电影网站在线视频观看福利| 成人av播放| wwwxxx色| 欧美做受高潮1| 伊人久久大香线蕉综合影院首页| 国产真实乱偷精品视频| 国产精品黄色大片| 69堂精品视频| 久草在线资源视频在线观看| 97久草视频| freehdxxxx| 精品人伦一区二区三区| 国产精品第10页| 欧洲亚洲成人| 99综合在线| 国产精品进线69影院| 精品久久久三级丝袜| 狠狠88综合久久久久综合网| 国产精品一二三四五| 欧美v在线观看| 午夜伦全在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 国产精品伦一区二区三级视频| 超碰97av在线| 亚洲视屏一区| 久久国产精品一区二区三区四区| 亚洲国产精华液网站w| 182tv在线播放| 五月综合激情| ·天天天天操| 一区二区91美女张开腿让人桶| 欧美人成免费网站| 亚洲尤物影院| 欧美日韩国产成人在线| 久久精品高清| 亚洲精品欧美| 欧洲精品99毛片免费高清观看| 国产精品成人观看视频免费| 国产成人精品优优av| 久久亚洲AV无码专区成人国产| 亚洲蜜桃精久久久久久久久久久久| eeuss影院www在线观看手机| 国产精品久久免费看| 国产字幕视频一区二区| 国产ts在线观看| 久久精品一区八戒影视| 中文字幕欧美视频| 2019av中文字幕| 激情欧美日韩一区| 97在线视频免费播放| 久久精品亚洲7777影院| www.五月色.com| 国产无码精品久久久| 18黄暴禁片在线观看| 欧美综合视频在线| 韩国成人免费视频| 中国特级黄色片| 91午夜理伦私人影院| 99热在线免费| 综合亚洲深深色噜噜狠狠网站| 色综合网色综合| www天堂在线观看| 日韩激情在线播放| 99精品全国免费观看| 久久国产生活片100| 精品国产伦一区二区三区| 男人天堂中文字幕| 在线免费观看污| 欧美三级华人主播| 欧美少妇xxx| 亚洲国产www| 二区三区四区视频| 麻豆成人91精品二区三区| 精品欧美激情在线观看| 黄页网站在线观看| 欧美日韩一区二区三区在线观看免| 女人十八毛片嫩草av| 超碰在线首页| jk漫画禁漫成人入口| 2020日本不卡一区二区视频| 91入口在线观看| 亚洲亚洲一区二区三区| 欧美影院午夜播放| 日韩国产一区三区| 天堂网avav| 九九大香尹人视频免费| 熟女少妇a性色生活片毛片| 青青草原国产在线| 夜夜爽www精品| 一区二区三区在线视频看| 国产精品视频| 欧美高清视频看片在线观看| 四虎4hu永久免费入口| 欧美人妻精品一区二区免费看| 亚洲精品国产精品国自产| 久久99精品网久久| 一区二区三区性视频| 男人和女人做事情在线视频网站免费观看| 国产a亚洲精品| 亚洲男人的天堂在线播放| 日本一区午夜艳熟免费| eeuss影院www免费视频| 欧美视频第二页| 日韩电影中文字幕在线| www.狠狠操.com| 俄罗斯一级**毛片在线播放| 国产97色在线 | 日韩| 成人h版在线观看| 欧美三级黄色大片| 蜜臀av一级做a爰片久久| 夜夜嗨av一区二区三区中文字幕| 成人综合视频在线| 久久日韩粉嫩一区二区三区| 91传媒在线免费观看| 婷婷精品国产一区二区三区日韩| 欧美成a人免费观看久久| 日韩美女视频在线观看| 日韩精品免费一区| 99re这里只有精品首页| 精品网站在线看| 欧美精选一区| 免费观看在线午夜影视| 欧美特级www| 国产毛片精品久久| 黄色a级片免费看| 亚洲色偷精品一区二区三区| 免费黄网大全| 国产精品久久久久久久久久小说| 精品一区二区免费视频| 日韩免费观看一区二区| 91精品在线一区| 日韩高清人体午夜| 国产一区二区三区免费在线| 变态另类ts人妖一区二区| 久草免费在线播放| 天天干,天天干| 国产精品欧美大片| 青青色在线视频| 久久人人爽人人爽人人片av免费| 欧美视频一二三区| 美女把尿口扒开给男人桶视频| 蜜臀av性久久久久蜜臀aⅴ流畅| aaa毛片在线观看| 国产精品88888| 2222www色视频在线观看| 亚洲一二三四在线观看| 中文成人av在线| 日韩欧美视频在线免费观看| 一区二区视频| 国产第一页浮力| 亚洲一区二区免费在线| y111111国产精品久久久| 国产亚洲婷婷免费| 日韩精品一区二区三区免费视频| 四虎影视18库在线影院| 日本三级视频在线| 男人的天堂久久| 国产原创视频在线| 亚洲天堂久久av| 亚洲色图狂野欧美| 国产sm调教视频| 97caopron在线视频| 成人永久免费网站| 超碰97在线免费观看| 欧美r级在线| 麻豆精品一区二区av白丝在线| 视频一区二区视频| 天堂在线免费av| 国产在线视频在线观看| 免费观看黄色一级视频| 成年女人a毛片免费视频| 欧美性xxxx禁忌| 欧美xxxxx在线视频|