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">&#xe675;</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