188 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			188 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
|   | <template> | ||
|  | 	<view class="content"> | ||
|  | 		<view class="list" v-if="articleList.length > 0"> | ||
|  | 			<view class="wrapper" v-for="item,index in articleList" @click="toDetail(item.articleId)" :key="index"> | ||
|  | 				<view class="img"> | ||
|  | 					<image :src="item.asdArticleList[0].litpic"></image> | ||
|  | 				</view> | ||
|  | 				<view class="right"> | ||
|  | 					<view class="title">{{item.asdArticleList[0].title}}</view> | ||
|  | 					<view class="info">{{item.asdArticleList[0].description ? item.asdArticleList[0].description : ''}} | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 				<view class="fav" @click.stop="userDelFavorite(item.asdArticleList[0].id)"> | ||
|  | 					<u-icon slot="icon" size="20" name="star-fill" color="#FFA521"></u-icon> | ||
|  | 					<text>已收藏</text> | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 
 | ||
|  | 		</view><u-empty mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png" v-else></u-empty> | ||
|  | 		<u-toast ref="uToast"></u-toast> | ||
|  | 
 | ||
|  | 
 | ||
|  | 	</view> | ||
|  | 
 | ||
|  | </template> | ||
|  | 
 | ||
|  | <script> | ||
|  | 	import oneArticle from '@/components/one-article/one-article.vue' | ||
|  | 	export default { | ||
|  | 		components: { | ||
|  | 			oneArticle | ||
|  | 		}, | ||
|  | 		data() { | ||
|  | 			return { | ||
|  | 				classifyArr: [{ | ||
|  | 					name: '全部', | ||
|  | 					id: '', | ||
|  | 				}], | ||
|  | 				pageNum: 1, | ||
|  | 				pageSize: 10, | ||
|  | 				parentId: '', | ||
|  | 				articleList: [], | ||
|  | 				loading: '', | ||
|  | 			} | ||
|  | 		}, | ||
|  | 		onLoad() { | ||
|  | 			this.userFavoriteList() | ||
|  | 		}, | ||
|  | 		onReachBottom() { | ||
|  | 			console.log('触底'); | ||
|  | 			if (this.loading == 'more') { | ||
|  | 				this.pageNum++; | ||
|  | 				this.userFavoriteList(); | ||
|  | 			} | ||
|  | 		}, | ||
|  | 		methods: { | ||
|  | 			// 获取收藏列表
 | ||
|  | 			async userFavoriteList() { | ||
|  | 				const res = await this.$myRequest({ | ||
|  | 					url: '/system/favorite/userFavoriteList', | ||
|  | 					data: { | ||
|  | 						pageNum: this.pageNum, | ||
|  | 						pageSize: this.pageSize | ||
|  | 					} | ||
|  | 				}) | ||
|  | 
 | ||
|  | 				if (res.data.code == 200) { | ||
|  | 					for (let i = 0; i < res.data.rows.length; i++) { | ||
|  | 						res.data.rows[i].asdArticleList[0].litpic = this.baseUrl + res.data.rows[i].asdArticleList[0] | ||
|  | 							.litpic | ||
|  | 					} | ||
|  | 					if (res.data.rows.length >= this.pageSize) { | ||
|  | 						this.loading = 'more'; | ||
|  | 					} else { | ||
|  | 						this.loading = 'noMore'; | ||
|  | 					} | ||
|  | 					this.articleList = this.articleList.concat(res.data.rows); | ||
|  | 				} | ||
|  | 				console.log(res.data.rows); | ||
|  | 
 | ||
|  | 			}, | ||
|  | 			toDetail(id) { | ||
|  | 				uni.navigateTo({ | ||
|  | 					url: '/homePackage/pages/newsDetail?id=' + id | ||
|  | 				}) | ||
|  | 			}, | ||
|  | 			// 取消收藏
 | ||
|  | 			async userDelFavorite(id) { | ||
|  | 				uni.showModal({ | ||
|  | 					title: '提示', | ||
|  | 					content: '确实要取消收藏吗?', | ||
|  | 					success: (res) => { | ||
|  | 						if (res.confirm) { | ||
|  | 							const res = this.$myRequest({ | ||
|  | 								method: 'DELETE', | ||
|  | 								url: '/system/favorite/userDelFavorite/' + id | ||
|  | 							}) | ||
|  | 							console.log(res); | ||
|  | 							this.$refs.uToast.show({ | ||
|  | 								type: 'success', | ||
|  | 								message: '删除成功', | ||
|  | 								complete: () => { | ||
|  | 									this.articleList = []; | ||
|  | 									this.userFavoriteList() | ||
|  | 								} | ||
|  | 							}) | ||
|  | 
 | ||
|  | 						} | ||
|  | 					} | ||
|  | 				}) | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 	} | ||
|  | </script> | ||
|  | 
 | ||
|  | <style lang="less" scoped> | ||
|  | 	.content { | ||
|  | 		.list { | ||
|  | 			margin: 50rpx 22rpx; | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.wrapper { | ||
|  | 		line-height: 20px; | ||
|  | 		border-radius: 15px; | ||
|  | 		background-color: rgba(255, 255, 255, 1); | ||
|  | 		text-align: center; | ||
|  | 		padding: 20rpx; | ||
|  | 		display: flex; | ||
|  | 		// justify-content: space-between;
 | ||
|  | 		border-radius: 15px; | ||
|  | 		background-color: rgba(255, 255, 255, 1); | ||
|  | 		box-shadow: 0px 4rpx 16rpx 2rpx #E4E4E4; | ||
|  | 		margin-bottom: 16rpx; | ||
|  | 		position: relative; | ||
|  | 
 | ||
|  | 		.img { | ||
|  | 			width: 112px; | ||
|  | 			height: 90px; | ||
|  | 			border-radius: 6px; | ||
|  | 
 | ||
|  | 			image { | ||
|  | 				width: 100%; | ||
|  | 				height: 100%; | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 		.right { | ||
|  | 			width: 60%; | ||
|  | 			margin-left: 20rpx; | ||
|  | 
 | ||
|  | 			.title { | ||
|  | 				color: rgba(16, 16, 16, 1); | ||
|  | 				font-size: 28rpx; | ||
|  | 				overflow: hidden; | ||
|  | 				text-overflow: ellipsis; | ||
|  | 				white-space: nowrap; | ||
|  | 				text-align: left; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			.info { | ||
|  | 				margin-top: 30rpx; | ||
|  | 				color: rgba(140, 139, 139, 1); | ||
|  | 				font-size: 24rpx; | ||
|  | 				overflow: hidden; | ||
|  | 				text-overflow: ellipsis; | ||
|  | 				display: -webkit-box; | ||
|  | 				-webkit-box-orient: vertical; | ||
|  | 				-webkit-line-clamp: 2; | ||
|  | 				text-align: left; | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 		.fav { | ||
|  | 			position: absolute; | ||
|  | 			right: 20rpx; | ||
|  | 			bottom: 20rpx; | ||
|  | 			display: flex; | ||
|  | 			align-items: center; | ||
|  | 
 | ||
|  | 			text { | ||
|  | 				font-size: 28rpx; | ||
|  | 				color: #101010; | ||
|  | 			} | ||
|  | 		} | ||
|  | 	} | ||
|  | </style> |