From 1c0627671cd95695df604a54de0bbb76469c21e9 Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期四, 29 五月 2025 10:23:37 +0800 Subject: [PATCH] 真机上视频加载和渲染是异步的,可能导致 onPlay/onPause 事件触发延迟。解决暂停图标和播放不一致问题 --- pages/tabbar/index/home.vue | 83 ++++++++++++++++++++++++++++++++--------- 1 files changed, 64 insertions(+), 19 deletions(-) diff --git a/pages/tabbar/index/home.vue b/pages/tabbar/index/home.vue index 4ed067f..4b7f2e1 100644 --- a/pages/tabbar/index/home.vue +++ b/pages/tabbar/index/home.vue @@ -13,7 +13,7 @@ <view class="play-icon" @click="togglePlay(index)" - v-if="currentVideoIsPlaying != null && !currentVideoIsPlaying" + v-if="!currentVideoIsPlaying" > <image src="/static/video/play.png" style="width: 45px;height: 45px" mode="aspectFit"></image> </view> @@ -97,11 +97,11 @@ <uni-popup ref="commentPopup" type="bottom" :is-mask-click="true" @maskClick="closeCommentPopup"> <view class="comment-popup"> <view class="popup-header"> - <text class="popup-title">璇勮({{comments.length}})</text> + <text class="popup-title">璇勮({{commentsTotal}})</text> <text class="iconfont close-icon" @click="closeCommentPopup"></text> </view> - <scroll-view class="comment-list" scroll-y> + <scroll-view class="comment-list" scroll-y :show-scrollbar="false" @scrolltolower="getCommentPage"> <view v-if="commentLoading" class="loading"> <uni-load-more status="loading"></uni-load-more> </view> @@ -111,10 +111,10 @@ </view> <view v-else class="comment-item" v-for="comment in comments" :key="comment.id"> - <image class="avatar" :src="comment.user.avatar || '/static/default-avatar.png'"></image> + <image class="avatar" :src="comment.userAvatar || '/static/default-avatar.png'"></image> <view class="comment-content"> - <text class="nickname">{{comment.user.nickname}}</text> - <text class="content">{{comment.content}}</text> + <text class="nickname">{{comment.userNickname}}</text> + <text class="content">{{comment.commentContent}}</text> <text class="time">{{formatTime(comment.createTime)}}</text> </view> </view> @@ -143,6 +143,7 @@ export default { data() { return { + commentNoMore: false, // 鏄惁杩樻湁鏇村璇勮 commentQuery: { pageNumber: 1, pageSize: 5, @@ -156,6 +157,7 @@ replyId: null }, comments: [], // 璇勮鍒楄〃 + commentsTotal: 0, // 璇勮鎬绘潯鏁� commentLoading: false, // 璇勮鍔犺浇鐘舵�� startHidenTime: 0, // 璁板綍鍒囨崲鑷冲叾瀹冮〉闈㈢殑鏃堕棿锛岀敤浜庤绠楄棰戣鐪嬫椂闂村噺鍘荤殑閮ㄥ垎 totalHidenTime: 0, // 鎬诲叡闅愯棌椤甸潰鐨勬椂闂� @@ -167,7 +169,7 @@ playAt: 0 ,// 杩欎釜瑙嗛鎾斁鍒板摢浜� startPlayTime: 0 // 杩欎釜瑙嗛浠庝粈涔堟椂鍊欏紑濮嬫挱鏀剧殑 }, - currentVideoIsPlaying: null, // 褰撳墠瑙嗛鏄惁姝e湪鎾斁 + currentVideoIsPlaying: true, // 褰撳墠瑙嗛鏄惁姝e湪鎾斁 isFullScreen: false, windowHeight: 0, currentIndex: 0, // 褰撳墠鎾斁鐨勮棰戠储寮� @@ -181,6 +183,7 @@ } }, onShow() { + this.loadVideos() // 濡傛灉瑙嗛鎸変笅鏆傚仠鍚庡垏鎹㈤〉闈㈠啀鍥炲埌椤甸潰鏃讹紝鍙畻鏆傚仠鏃堕棿锛堝洜涓烘殏鍋滄椂闂村拰绂诲紑椤甸潰鏃堕棿鏄噸澶嶇殑锛屽彧绠椾竴涓級 if(this.startHidenTime !== 0 && this.currentVideoIsPlaying) { const duration = Date.now() - this.startHidenTime @@ -229,10 +232,12 @@ replyId: null } this.comments.unshift(res.data.data); + console.log("鏂板鍚�",this.comments); uni.showToast({ title: '璇勮鎴愬姛' }); // 褰撳墠瑙嗛璇勮鏁板姞涓� + this.commentsTotal += 1; this.videoList[this.currentIndex].commentNum += 1; } else { uni.showToast({ @@ -249,7 +254,6 @@ }, // 鍏抽棴璇勮寮圭獥 closeCommentPopup() { - console.log("瑙﹀彂浜�"); this.$refs.commentPopup.close() this.showCommentPopup = false; this.comments = []; @@ -259,15 +263,45 @@ commentContent: '', replyId: null } + this.commentQuery.pageNumber = 1; + this.commentNoMore = false; }, + // 涓嬫粦璇勮鍖哄姞杞借瘎璁� + async getCommentPage() { + if(this.commentNoMore) { + return; + } + getVideoComments(this.commentQuery).then(res => { + if(this.commentQuery.pageNumber === 1) { + this.comments = res.data.data + } else { + this.comments = [ + ...this.comments, + ...res.data.data.filter( + (newItem) => !this.comments.some((oldItem) => oldItem.id === newItem.id) + ), + ]; + } + if (res.data.data.length < this.commentQuery.pageSize) { + this.commentNoMore = true; + return; + } + this.commentQuery.pageNumber++; + }) + }, // 鏄剧ず璇勮寮圭獥 async showComments(item) { this.commentForm.videoId = item.id; this.$refs.commentPopup.open(); this.commentLoading = true; this.commentQuery.videoId = item.id + // 棣栨鍔犺浇璇勮鍒嗛〉澶у皬澧炲姞涓�鍊嶏紝浠ヤ骇鐢熸粴鍔ㄦ潯锛屽悗缁彲瑙﹀彂 + this.commentQuery.pageSize *= 2; getVideoComments(this.commentQuery).then(res => { - this.comments = res.data.data + this.commentsTotal = res.data.total; + this.comments = res.data.data; + this.commentQuery.pageNumber += 2; + this.commentQuery.pageSize /= 2; }).catch(() => { uni.showToast({ title: '鑾峰彇璇勮澶辫触', @@ -340,14 +374,13 @@ // 淇濆瓨涓婁竴涓棰戠殑鎾斁璁板綍 this.savePlayRecord() const oldIndex = this.currentIndex; - console.log("瑙嗛涓婁笅鏂�",this.videoContexts[oldIndex]); this.currentIndex = e.detail.current; // 鏆傚仠涓婁竴涓棰� if (this.videoContexts[oldIndex]) { this.videoContexts[oldIndex].pause(); } - this.currentVideoIsPlaying = true; + this.startPauseTime = 0; // 鎾斁褰撳墠瑙嗛 if (this.videoContexts[this.currentIndex]) { @@ -387,7 +420,13 @@ }, // 瑙嗛鎾斁浜嬩欢 onPlay(id, index) { - this.currentVideoIsPlaying = true; + console.log(id, index, "瑙﹀彂鎾斁"); + if(index === this.currentIndex) { + this.currentVideoIsPlaying = true; + } else { + this.currentVideoIsPlaying = false; + return + } this.playRecord.videoId = id; // 娌″垵濮嬪寲鎵嶈祴鍊硷紝鍥犱负涓�涓棰戦噸澶嶆挱鏀緊nPlay浼氶噸澶嶈Е鍙� if(this.playRecord.startPlayTime === 0) { @@ -401,7 +440,13 @@ // 瑙嗛鏆傚仠浜嬩欢 onPause(index) { - this.currentVideoIsPlaying = false; + console.log(index, "瑙﹀彂鏆傚仠"); + if(index === this.currentIndex) { + this.currentVideoIsPlaying = false; + } else { + this.currentVideoIsPlaying = true; + return + } this.startPauseTime = Date.now() }, @@ -620,7 +665,7 @@ background-color: #fff; border-radius: 20rpx 20rpx 0 0; padding-bottom: env(safe-area-inset-bottom); - height: 50vh; + height: 60vh; display: flex; flex-direction: column; } @@ -645,14 +690,14 @@ .comment-list { flex: 1; - padding: 20rpx; + padding: 0rpx 20rpx 20rpx 20rpx; box-sizing: border-box; + height: calc(60vh - 260rpx); } .comment-item { display: flex; - padding: 20rpx 0; - border-bottom: 1rpx solid #f5f5f5; + padding: 10rpx 0; } .avatar { @@ -667,14 +712,14 @@ } .nickname { - font-size: 26rpx; + font-size: 24rpx; color: #666; display: block; margin-bottom: 10rpx; } .content { - font-size: 30rpx; + font-size: 24rpx; color: #333; display: block; margin-bottom: 10rpx; -- Gitblit v1.8.0