|  |  |  | <template> | 
					
						
							|  |  |  | 	<div class="bg"> | 
					
						
							|  |  |  | 		<div class="search-box"> | 
					
						
							|  |  |  | 			<img src="https://static.ticket.sz-trip.com/taizhou/images/search.png" alt=""> | 
					
						
							|  |  |  | 			<input type="text" class="input" placeholder="请输入关键字" v-model="keywords" @confirm="search()" /> | 
					
						
							|  |  |  | 			<div class="btn" @click="search()">搜索</div> | 
					
						
							|  |  |  | 		</div> | 
					
						
							|  |  |  | 		<div class="search-title com-flex-tao"> | 
					
						
							|  |  |  | 			搜索历史 | 
					
						
							|  |  |  | 			<img @click="delHis()" src="https://static.ticket.sz-trip.com/taizhou/images/delete.png" alt=""> | 
					
						
							|  |  |  | 		</div> | 
					
						
							|  |  |  | 		<div class="search-list"> | 
					
						
							|  |  |  | 			<div v-for="his,hisIndex in history.slice(0,10)" @click="gotoHot(his)" :key="hisIndex" | 
					
						
							|  |  |  | 				class="search-item textOver">{{his}}</div> | 
					
						
							|  |  |  | 		</div> | 
					
						
							|  |  |  | 	</div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | 	export default { | 
					
						
							|  |  |  | 		name: "Search", | 
					
						
							|  |  |  | 		data() { | 
					
						
							|  |  |  | 			return { | 
					
						
							|  |  |  | 				list: [], | 
					
						
							|  |  |  | 				keywords: '', | 
					
						
							|  |  |  | 				history: [], | 
					
						
							|  |  |  | 				hot: [], | 
					
						
							|  |  |  | 				keywords_name: 'tz_trip_jf_keyowrds', | 
					
						
							|  |  |  | 				options: {}, | 
					
						
							|  |  |  | 				type: '', // techan时跳转techanResult
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		onLoad(options) { | 
					
						
							|  |  |  | 			if (options.type) { | 
					
						
							|  |  |  | 				this.type = options.type | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		onShow() { | 
					
						
							|  |  |  | 			this.history = uni.getStorageSync(this.keywords_name) ? JSON.parse(uni.getStorageSync(this.keywords_name)) :[]; | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		methods: { | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			delHis() { | 
					
						
							|  |  |  | 				this.history = []; | 
					
						
							|  |  |  | 				uni.removeStorageSync(this.keywords_name) | 
					
						
							|  |  |  | 				uni.showToast({ | 
					
						
							|  |  |  | 					title: '删除成功' | 
					
						
							|  |  |  | 				}) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			search(e) { | 
					
						
							|  |  |  | 				let url = '/subPackages/pointsMall/searchResult' | 
					
						
							|  |  |  | 				if (this.keywords) { | 
					
						
							|  |  |  | 					this.pushHis(this.keywords); | 
					
						
							|  |  |  | 					uni.navigateTo({ | 
					
						
							|  |  |  | 						url: url+`?keywords=${this.keywords}` | 
					
						
							|  |  |  | 					}) | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			gotoHot(name) { | 
					
						
							|  |  |  | 				let url = '/subPackages/pointsMall/searchResult' | 
					
						
							|  |  |  | 				uni.navigateTo({ | 
					
						
							|  |  |  | 					url: url+`?keywords=${name}` | 
					
						
							|  |  |  | 				}) | 
					
						
							|  |  |  | 				this.pushHis(name) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			pushHis(keywords) { | 
					
						
							|  |  |  | 				let history = this.history; | 
					
						
							|  |  |  | 				let index = history.findIndex(item => item == keywords); | 
					
						
							|  |  |  | 				if (index >= 0) history.splice(index, 1); | 
					
						
							|  |  |  | 				history.unshift(keywords); | 
					
						
							|  |  |  | 				uni.setStorageSync(this.keywords_name, JSON.stringify(history)) | 
					
						
							|  |  |  | 				this.history = history; | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | 	.bg { | 
					
						
							|  |  |  | 		min-height: 100vh; | 
					
						
							|  |  |  | 		background: #FFFFFF; | 
					
						
							|  |  |  | 		padding: 20rpx 26rpx; | 
					
						
							|  |  |  | 		position: relative; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.search-box { | 
					
						
							|  |  |  | 		width: 697rpx; | 
					
						
							|  |  |  | 		height: 67rpx; | 
					
						
							|  |  |  | 		margin: 0 auto 30rpx; | 
					
						
							|  |  |  | 		background: #F2F2F2; | 
					
						
							|  |  |  | 		border-radius: 33rpx; | 
					
						
							|  |  |  | 		padding: 6rpx 7rpx 6rpx 26rpx; | 
					
						
							|  |  |  | 		font-size: 26rpx; | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		align-items: center; | 
					
						
							|  |  |  | 		box-sizing: border-box; | 
					
						
							|  |  |  | 		img { | 
					
						
							|  |  |  | 			width: 28rpx; | 
					
						
							|  |  |  | 			height: 30rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		.input { | 
					
						
							|  |  |  | 			flex: 1; | 
					
						
							|  |  |  | 			border: none; | 
					
						
							|  |  |  | 			outline: none; | 
					
						
							|  |  |  | 			background: none; | 
					
						
							|  |  |  | 			color: #666; | 
					
						
							|  |  |  | 			margin: 0 20rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		.btn { | 
					
						
							|  |  |  | 			background: #6A8A27; | 
					
						
							|  |  |  | 			border-radius: 27rpx; | 
					
						
							|  |  |  | 			font-size: 28rpx; | 
					
						
							|  |  |  | 			color: #FFFFFF; | 
					
						
							|  |  |  | 			padding: 10rpx 26rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.search-title { | 
					
						
							|  |  |  | 		color: #000000; | 
					
						
							|  |  |  | 		font-size: 32rpx; | 
					
						
							|  |  |  | 		margin: 36rpx 0; | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		justify-content: space-between; | 
					
						
							|  |  |  | 		align-items: center; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.search-title img { | 
					
						
							|  |  |  | 		width: 30rpx; | 
					
						
							|  |  |  | 		height: 32rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.search-list { | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		align-items: center; | 
					
						
							|  |  |  | 		flex-wrap: wrap; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.search-item { | 
					
						
							|  |  |  | 		padding: 0 25rpx; | 
					
						
							|  |  |  | 		font-size: 24rpx; | 
					
						
							|  |  |  | 		color: #000; | 
					
						
							|  |  |  | 		line-height: 42rpx; | 
					
						
							|  |  |  | 		border-radius: 7rpx; | 
					
						
							|  |  |  | 		background: #F1F1F1; | 
					
						
							|  |  |  | 		margin-right: 22rpx; | 
					
						
							|  |  |  | 		margin-bottom: 23rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.road-list { | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		margin: 20rpx 0; | 
					
						
							|  |  |  | 		justify-content: space-between; | 
					
						
							|  |  |  | 		flex-wrap: wrap; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.road-item { | 
					
						
							|  |  |  | 		width: 332rpx; | 
					
						
							|  |  |  | 		border-radius: 10rpx; | 
					
						
							|  |  |  | 		box-shadow: 0px 0px 10rpx 0px rgba(4, 0, 0, 0.16); | 
					
						
							|  |  |  | 		margin-bottom: 26rpx; | 
					
						
							|  |  |  | 		min-height: 156rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.road-item image { | 
					
						
							|  |  |  | 		border-top-right-radius: 10rpx; | 
					
						
							|  |  |  | 		border-top-left-radius: 10rpx; | 
					
						
							|  |  |  | 		width: 332rpx; | 
					
						
							|  |  |  | 		height: 246rpx; | 
					
						
							|  |  |  | 		object-fit: cover; | 
					
						
							|  |  |  | 		display: block; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.road-info { | 
					
						
							|  |  |  | 		padding: 10rpx 15rpx; | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		flex-direction: column; | 
					
						
							|  |  |  | 		justify-content: space-between; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.road-title { | 
					
						
							|  |  |  | 		font-size: 32rpx; | 
					
						
							|  |  |  | 		line-height: 32rpx; | 
					
						
							|  |  |  | 		font-weight: 500; | 
					
						
							|  |  |  | 		margin-top: 6rpx; | 
					
						
							|  |  |  | 		margin-bottom: 20rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.hotel-subtitle { | 
					
						
							|  |  |  | 		font-size: 24rpx; | 
					
						
							|  |  |  | 		color: #999; | 
					
						
							|  |  |  | 		line-height: 24rpx; | 
					
						
							|  |  |  | 		margin-bottom: 18rpx; | 
					
						
							|  |  |  | 		min-height: 48rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.hotel-price { | 
					
						
							|  |  |  | 		text-align: right; | 
					
						
							|  |  |  | 		color: #FC524B; | 
					
						
							|  |  |  | 		font-size: 36rpx; | 
					
						
							|  |  |  | 		font-weight: 500; | 
					
						
							|  |  |  | 		line-height: 30rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.hotel-price:after { | 
					
						
							|  |  |  | 		content: "起"; | 
					
						
							|  |  |  | 		font-size: 20rpx; | 
					
						
							|  |  |  | 		color: #999; | 
					
						
							|  |  |  | 		margin-left: 5rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | </style> |