From 117b18ca111f2be41aec49961dc98db1769ca39f Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期二, 27 五月 2025 19:17:53 +0800 Subject: [PATCH] uview组件和uniapp组件冲突问题、视频评论 --- pages/tabbar/index/home.vue | 242 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 241 insertions(+), 1 deletions(-) diff --git a/pages/tabbar/index/home.vue b/pages/tabbar/index/home.vue index 6b2f4c5..4ed067f 100644 --- a/pages/tabbar/index/home.vue +++ b/pages/tabbar/index/home.vue @@ -89,18 +89,74 @@ <text style="font-size: 10px;font-weight: lighter;">{{item.commentNum}}</text> </view> </view> + </swiper-item> </swiper> + + <!-- 璇勮寮圭獥 --> + <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="iconfont close-icon" @click="closeCommentPopup"></text> + </view> + + <scroll-view class="comment-list" scroll-y> + <view v-if="commentLoading" class="loading"> + <uni-load-more status="loading"></uni-load-more> + </view> + + <view v-else-if="comments.length === 0" class="empty"> + 鏆傛棤璇勮锛屽揩鏉ュ彂琛ㄧ涓�鏉¤瘎璁哄惂~ + </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> + <view class="comment-content"> + <text class="nickname">{{comment.user.nickname}}</text> + <text class="content">{{comment.content}}</text> + <text class="time">{{formatTime(comment.createTime)}}</text> + </view> + </view> + </scroll-view> + + <view class="comment-input-area"> + <input + class="comment-input" + v-model="commentForm.commentContent" + placeholder="鍐欎笅浣犵殑璇勮..." + placeholder-class="placeholder" + /> + <button class="submit-btn" @click="submitComment">鍙戦��</button> + </view> + </view> + </uni-popup> + + <custom-tabbar bgColor="#333333" selected="index" selectedTextColor="#ffffff"></custom-tabbar> </view> </template> <script> -import { getRecommendVideos, savePlayRecord, subscribe } from "@/api/video.js"; +import { getRecommendVideos, savePlayRecord, subscribe, getVideoComments, addVideoComment } from "@/api/video.js"; import { changeCollect } from "@/api/collect.js"; export default { data() { return { + commentQuery: { + pageNumber: 1, + pageSize: 5, + videoId: '', + masterCommentId: '' + }, + commentForm: { // 璇勮琛ㄥ崟鏁版嵁 + id: null, + videoId: null, + commentContent: '', + replyId: null + }, + comments: [], // 璇勮鍒楄〃 + commentLoading: false, // 璇勮鍔犺浇鐘舵�� startHidenTime: 0, // 璁板綍鍒囨崲鑷冲叾瀹冮〉闈㈢殑鏃堕棿锛岀敤浜庤绠楄棰戣鐪嬫椂闂村噺鍘荤殑閮ㄥ垎 totalHidenTime: 0, // 鎬诲叡闅愯棌椤甸潰鐨勬椂闂� startPauseTime: 0, // 寮�濮嬫殏鍋滅殑鏃堕棿 @@ -142,6 +198,85 @@ this.initVideoContexts(); }, methods: { + // 鏍煎紡鍖栨椂闂� + formatTime(time) { + const date = new Date(time); + const now = new Date(); + const diff = Math.floor((now - date) / 1000); // 绉� + + if (diff < 60) return '鍒氬垰'; + if (diff < 3600) return `${Math.floor(diff / 60)}鍒嗛挓鍓峘; + if (diff < 86400) return `${Math.floor(diff / 3600)}灏忔椂鍓峘; + + return `${date.getMonth() + 1}鏈�${date.getDate()}鏃; + }, + // 鎻愪氦璇勮 + async submitComment() { + if (!this.commentForm.commentContent.trim()) { + uni.showToast({ + title: '璇勮鍐呭涓嶈兘涓虹┖', + icon: 'none' + }); + return; + } + // 鍙戣〃璇勮 + addVideoComment(this.commentForm).then(res => { + if(res.data.code === 200) { + this.commentForm = { + id: null, + videoId: null, + commentContent: '', + replyId: null + } + this.comments.unshift(res.data.data); + uni.showToast({ + title: '璇勮鎴愬姛' + }); + // 褰撳墠瑙嗛璇勮鏁板姞涓� + this.videoList[this.currentIndex].commentNum += 1; + } else { + uni.showToast({ + title: res.data.msg, + icon: 'none' + }); + } + }).catch(() => { + uni.showToast({ + title: '璇勮澶辫触', + icon: 'none' + }); + }) + }, + // 鍏抽棴璇勮寮圭獥 + closeCommentPopup() { + console.log("瑙﹀彂浜�"); + this.$refs.commentPopup.close() + this.showCommentPopup = false; + this.comments = []; + this.commentForm = { + id: null, + videoId: null, + commentContent: '', + replyId: null + } + }, + // 鏄剧ず璇勮寮圭獥 + async showComments(item) { + this.commentForm.videoId = item.id; + this.$refs.commentPopup.open(); + this.commentLoading = true; + this.commentQuery.videoId = item.id + getVideoComments(this.commentQuery).then(res => { + this.comments = res.data.data + }).catch(() => { + uni.showToast({ + title: '鑾峰彇璇勮澶辫触', + icon: 'none' + }); + }).finally(() => { + this.commentLoading = false; + }) + }, // 鍏虫敞浣滆�� subscribeAuth(index, authorId) { this.videoList.forEach(video => { @@ -480,5 +615,110 @@ font-size: 26rpx; font-weight: bold; } + /* 璇勮寮圭獥鏍峰紡 */ + .comment-popup { + background-color: #fff; + border-radius: 20rpx 20rpx 0 0; + padding-bottom: env(safe-area-inset-bottom); + height: 50vh; + display: flex; + flex-direction: column; + } + .popup-header { + padding: 30rpx; + display: flex; + justify-content: space-between; + align-items: center; + border-bottom: 1rpx solid #f5f5f5; + } + + .popup-title { + font-size: 32rpx; + font-weight: bold; + } + + .close-icon { + /* font-size: 36rpx; */ + color: #999; + } + + .comment-list { + flex: 1; + padding: 20rpx; + box-sizing: border-box; + } + + .comment-item { + display: flex; + padding: 20rpx 0; + border-bottom: 1rpx solid #f5f5f5; + } + + .avatar { + width: 80rpx; + height: 80rpx; + border-radius: 50%; + margin-right: 20rpx; + } + + .comment-content { + flex: 1; + } + + .nickname { + font-size: 26rpx; + color: #666; + display: block; + margin-bottom: 10rpx; + } + + .content { + font-size: 30rpx; + color: #333; + display: block; + margin-bottom: 10rpx; + } + + .time { + font-size: 24rpx; + color: #999; + } + + .comment-input-area { + display: flex; + padding: 20rpx 30rpx; + align-items: center; + } + + .comment-input { + flex: 1; + background-color: #fff; + height: 80rpx; + border: 1px solid #dcdcdc; + border-radius: 40rpx; + padding: 0 30rpx; + font-size: 28rpx; + } + + .placeholder { + color: #ccc; + } + + .submit-btn { + margin-left: 20rpx; + background-color: #07c160; + color: #fff; + border-radius: 40rpx; + padding: 0 30rpx; + height: 80rpx; + line-height: 80rpx; + font-size: 28rpx; + } + + .loading, .empty { + padding: 40rpx 0; + text-align: center; + color: #999; + } </style> \ No newline at end of file -- Gitblit v1.8.0