214 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			214 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | ||
| 	<view>
 | ||
| 		<uni-nav-bar fixed="true">
 | ||
| 			<block slot="left">
 | ||
| 				<view class="city">
 | ||
| 					<view>
 | ||
| 						<text class="uni-nav-bar-text">{{ city }}</text>
 | ||
| 					</view>
 | ||
| 					<uni-icons type="arrowdown" color="#666" size="18" />
 | ||
| 				</view>
 | ||
| 			</block>
 | ||
| 			<view class="input-view">
 | ||
| 				<uni-icons class="input-uni-icon" type="search" size="18" color="#999" />
 | ||
| 				<input confirm-type="search" class="nav-bar-input" type="text" placeholder="输入搜索关键词"
 | ||
| 					@confirm="confirm" />
 | ||
| 			</view>
 | ||
| 			<block slot="right">
 | ||
| 				<view class="city">
 | ||
| 					搜索
 | ||
| 				</view>
 | ||
| 			</block>
 | ||
| 		</uni-nav-bar>
 | ||
| 		<uni-list>
 | ||
| 			<uni-list-chat clickable @click="onClick(item)" v-for="item in listData" :key="item.id"
 | ||
| 				:title="item.author_name" :avatar="item.cover" :note="item.title" badge-positon="left"
 | ||
| 				:badge-text="item.text">
 | ||
| 				<view class="chat-custom-right">
 | ||
| 					<text class="chat-custom-text">刚刚</text>
 | ||
| 					<uni-icons type="star-filled" color="#999" size="18"></uni-icons>
 | ||
| 				</view>
 | ||
| 			</uni-list-chat>
 | ||
| 		</uni-list>
 | ||
| 	</view>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| 	export default {
 | ||
| 		components: {},
 | ||
| 		data() {
 | ||
| 			return {
 | ||
| 				UNITS: {
 | ||
| 					'年': 31557600000,
 | ||
| 					'月': 2629800000,
 | ||
| 					'天': 86400000,
 | ||
| 					'小时': 3600000,
 | ||
| 					'分钟': 60000,
 | ||
| 					'秒': 1000
 | ||
| 				},
 | ||
| 				listData: [],
 | ||
| 				city: '北京'
 | ||
| 			}
 | ||
| 		},
 | ||
| 		onLoad() {
 | ||
| 			this.getList()
 | ||
| 		},
 | ||
| 		methods: {
 | ||
| 			confirm() {
 | ||
| 				uni.showToast({
 | ||
| 					title: '搜索'
 | ||
| 				})
 | ||
| 			},
 | ||
| 			onClick(e) {
 | ||
| 				console.log(e)
 | ||
| 				uni.showToast({
 | ||
| 					title: '列表被点击'
 | ||
| 				})
 | ||
| 			},
 | ||
| 			avatar(count) {
 | ||
| 				let arr = []
 | ||
| 				this.avatarList.forEach((item, index) => {
 | ||
| 					if (index < count) {
 | ||
| 						arr.push(item)
 | ||
| 					}
 | ||
| 				})
 | ||
| 				return arr
 | ||
| 			},
 | ||
| 			getList() {
 | ||
| 				var data = {
 | ||
| 					column: 'id,post_id,title,author_name,cover,published_at' //需要的字段名
 | ||
| 				};
 | ||
| 
 | ||
| 				uni.request({
 | ||
| 					url: 'https://unidemo.dcloud.net.cn/api/news',
 | ||
| 					data: data,
 | ||
| 					success: data => {
 | ||
| 						if (data.statusCode == 200) {
 | ||
| 							let list = this.setTime(data.data);
 | ||
| 							list = this.reload ? list : this.listData.concat(list);
 | ||
| 							list.map(item => {
 | ||
| 								item.text = Math.floor(Math.random() * (1 - 20) + 20)
 | ||
| 								return item
 | ||
| 							})
 | ||
| 							this.listData = this.getRandomArrayElements(list, 20)
 | ||
| 						}
 | ||
| 					},
 | ||
| 					fail: (data, code) => {
 | ||
| 						console.log('fail' + JSON.stringify(data));
 | ||
| 					}
 | ||
| 				});
 | ||
| 			},
 | ||
| 			getRandomArrayElements(arr, count) {
 | ||
| 				var shuffled = arr.slice(0),
 | ||
| 					i = arr.length,
 | ||
| 					min = i - count,
 | ||
| 					temp, index;
 | ||
| 				while (i-- > min) {
 | ||
| 					index = Math.floor((i + 1) * Math.random());
 | ||
| 					temp = shuffled[index];
 | ||
| 					shuffled[index] = shuffled[i];
 | ||
| 					shuffled[i] = temp;
 | ||
| 				}
 | ||
| 				return shuffled.slice(min);
 | ||
| 			},
 | ||
| 			setTime(items) {
 | ||
| 				var newItems = [];
 | ||
| 				items.forEach(e => {
 | ||
| 					newItems.push({
 | ||
| 						author_name: e.author_name,
 | ||
| 						cover: e.cover,
 | ||
| 						id: e.id,
 | ||
| 						post_id: e.post_id,
 | ||
| 						published_at: this.format(e.published_at),
 | ||
| 						title: e.title
 | ||
| 					});
 | ||
| 				});
 | ||
| 				return newItems;
 | ||
| 			},
 | ||
| 			format(dateStr) {
 | ||
| 				var date = this.parse(dateStr)
 | ||
| 				var diff = Date.now() - date.getTime();
 | ||
| 				if (diff < this.UNITS['天']) {
 | ||
| 					return this.humanize(diff);
 | ||
| 				}
 | ||
| 				var _format = function(number) {
 | ||
| 					return (number < 10 ? ('0' + number) : number);
 | ||
| 				};
 | ||
| 				return date.getFullYear() + '-' + _format(date.getMonth() + 1) + '-' + _format(date.getDate()) + ' ' +
 | ||
| 					_format(date.getHours()) + ':' + _format(date.getMinutes());
 | ||
| 			},
 | ||
| 			parse(str) { //将"yyyy-mm-dd HH:MM:ss"格式的字符串,转化为一个Date对象
 | ||
| 				var a = str.split(/[^0-9]/);
 | ||
| 				return new Date(a[0], a[1] - 1, a[2], a[3], a[4], a[5]);
 | ||
| 			},
 | ||
| 
 | ||
| 		}
 | ||
| 	}
 | ||
| </script>
 | ||
| 
 | ||
| <style lang="scss">
 | ||
| 	.chat-custom-right {
 | ||
| 		flex: 1;
 | ||
| 		/* #ifndef APP-NVUE */
 | ||
| 		display: flex;
 | ||
| 		/* #endif */
 | ||
| 		flex-direction: column;
 | ||
| 		justify-content: space-between;
 | ||
| 		align-items: flex-end;
 | ||
| 	}
 | ||
| 
 | ||
| 	.chat-custom-text {
 | ||
| 		font-size: 12px;
 | ||
| 		color: #999;
 | ||
| 	}
 | ||
| 
 | ||
| 	$nav-height: 30px;
 | ||
| 
 | ||
| 	.box-bg {
 | ||
| 		background-color: #F5F5F5;
 | ||
| 		padding: 5px 0;
 | ||
| 	}
 | ||
| 
 | ||
| 	.city {
 | ||
| 		/* #ifndef APP-PLUS-NVUE */
 | ||
| 		display: flex;
 | ||
| 		/* #endif */
 | ||
| 		flex-direction: row;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: flex-start;
 | ||
| 		// width: 160rpx;
 | ||
| 		margin-left: 4px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.input-view {
 | ||
| 		/* #ifndef APP-PLUS-NVUE */
 | ||
| 		display: flex;
 | ||
| 		/* #endif */
 | ||
| 		flex-direction: row;
 | ||
| 		// width: 500rpx;
 | ||
| 		flex: 1;
 | ||
| 		background-color: #f8f8f8;
 | ||
| 		height: $nav-height;
 | ||
| 		border-radius: 15px;
 | ||
| 		padding: 0 15px;
 | ||
| 		flex-wrap: nowrap;
 | ||
| 		margin: 7px 0;
 | ||
| 		line-height: $nav-height;
 | ||
| 	}
 | ||
| 
 | ||
| 	.input-uni-icon {
 | ||
| 		line-height: $nav-height;
 | ||
| 	}
 | ||
| 
 | ||
| 	.nav-bar-input {
 | ||
| 		height: $nav-height;
 | ||
| 		line-height: $nav-height;
 | ||
| 		/* #ifdef APP-PLUS-NVUE */
 | ||
| 		width: 370rpx;
 | ||
| 		/* #endif */
 | ||
| 		padding: 0 5px;
 | ||
| 		font-size: 12px;
 | ||
| 		background-color: #f8f8f8;
 | ||
| 	}
 | ||
| </style>
 |