| 
						 | 
						- <template>
 - 	<view>
 - 		<view class="se-px-40 se-py-20" style="background-color: #1EC77A;">
 - 			<view class="se-bgc-white se-br-50 se-c-black se-px-20 se-py-5 se-flex se-flex-ai-c se-fs-26">
 - 				<view class="location-container se-b-r se-pl-10 se-pr-20 se-flex se-flex-h se-h-40 se-lh-40" @click="handleAreaChange()">
 - 					<text class="location-text se-pr-20">{{city?city:'未知'}}</text>
 - 					<!-- <uv-icon name="arrow-down-fill"></uv-icon> -->
 - 				</view>
 - 				<view class="search-container se-flex-1 se-ml-20">
 - 					<uv-search :disabled="true" @click="onSearch()" :showAction="false" bgColor="transparent" placeholder="请输入租房信息" v-model="keyword"></uv-search>
 - 				</view>
 - 			</view>
 - 		</view>
 - 		<!-- backdrop -->
 - 		<view class=" se-mb-20">
 - 			<uv-swiper height="300rpx" 
 - 			keyName="image"
 - 			:list="bannerList"></uv-swiper>
 - 			<!-- <image class="se-w-vw-100 se-h-400" src="@/static/image/banner.png" mode=""></image> -->
 - 		</view>
 - 		 <!-- se-mt-300 -->
 - 		<view class="se-grid se-bgc-white se-py-30">
 - 			<!-- <navigator url="/pages_subpack/category/index" v-for="(item, index) in nav" :key="index" class="se-flex-v-c se-mb-20">
 - 				<image class="se-a-100 se-br-20" :src="item.img" mode=""></image>
 - 				<text class="se-w-150 se-h-60 se-lh-30 se-c-black se-fs-22 se-ta-c se-mt-10 se-toe-2">{{item.name}}</text>
 - 			</navigator> -->
 - 			<navigator :url="item.url+`?id=`+item.id+`&title=`+item.title" v-for="(item, index) in nav" :key="index" class="se-flex-v-c se-mb-20">
 - 				<image class="se-a-100 se-br-20" :src="item.image" mode=""></image>
 - 				<text class="se-w-150 se-h-60 se-lh-30 se-c-black se-fs-22 se-ta-c se-mt-10 se-toe-2">{{item.title}}</text>
 - 			</navigator>
 - 		</view>
 - 		<view class="se-mt-20 se-bgc-white se-px-20 se-py-10 se-ta-l se-c-orange se-flex se-flex-ai-c se-fs-24" @click="toNotice">
 - 			<image class="se-a-80" src="@/static/image/aed60x.png" mode=""></image>
 - 			<text class="se-ml-10">{{noticeObj.title}}</text>
 - 		</view>
 - 		<view class="se-bgc-white se-my-20">
 - 			<uv-tabs @click="onClickHouseType" :list="houseTypeList" keyName="title" :activeStyle="{color:'#000000'}" :inactiveStyle="{color:'#666666'}" :lineColor="`url(${lineBg}) 100% 100%`"></uv-tabs>
 - 		</view>
 - 		<!-- <view class="se-pb-200">
 - 			<view v-if="list.length>0">
 - 				<view @click="onDetail(item)" class="se-my-10 se-mx-20 se-px-20 se-py-20 se-br-20 se-bgc-white se-flex" v-for="(item,index) in list" :key="index">
 - 					<view class="se-pos se-w-260 se-h-180">
 - 						<image v-if="item.iconImage" class="se-a-80 se-pos-lt" :src="item.iconImage" mode=""></image>
 - 						<image class="se-w-260 se-h-180 se-br-10" :src="item.images[0]" mode=""></image>
 - 					</view>
 - 					<view class="se-pl-10 se-w-p-100">
 - 						<view class="se-c-black se-fs-28">
 - 							{{item.title}}
 - 						</view>
 - 						<view class="se-flex se-flex-h-sb se-flex-ai-c se-fs-24 se-mt-10 se-c-66">
 - 							<text>{{item.homeType}}</text>
 - 							<text>{{item.timeGo}}年</text>
 - 						</view>
 - 						<view class="se-flex se-flex-h-sb se-flex-ai-c se-mt-10">
 - 							<template v-if="item.iconTitles.length>0">
 - 								<view class="se-flex">
 - 									<view class="se-display-ib se-c-white se-bgc-orange se-fs-22 se-br-8 se-px-10 se-py-5 se-mr-10" v-for="(items,indexs) in item.iconTitles" :key="indexs">
 - 										{{items}}
 - 									</view>
 - 								</view>
 - 							</template>
 - 							<template v-else><view></view></template>
 - 							<view class="se-c-66 se-flex se-flex-ai-c">
 - 								<uv-icon name="eye"></uv-icon>
 - 								<text class="se-ml-5 se-fs-18">{{item.num}}</text>
 - 							</view>
 - 						</view>
 - 						<view class="se-flex  se-flex-h-sb se-flex-ai-c se-mt-10">
 - 							<text class="se-c-red se-fs-24 se-fw-6 se-toe-1">¥{{item.price}}元/{{item.unit}}</text>
 - 							<text class="se-c-66 se-fs-22 se-toe-1">{{item.address}}</text>
 - 						</view>
 - 					</view>
 - 				</view>
 - 			</view>
 - 			<view v-else>
 - 				<uv-empty mode="list" ></uv-empty>
 - 			</view>
 - 		</view> -->
 - 		
 - 		<homeList :list="list" />
 - 		
 - 		<!-- 发布房源 -->
 - 		<view class="se-pos-fixed se-pos-rc" style="right: 30rpx;top: 70vh;">
 - 			<image @click="onNavigator()" class="se-a-150" src="@/static/image/discover.png" mode=""></image>
 - 		</view>
 - 		
 - 		<!-- 地址 -->
 - 		<citySelect ref="citySelectRef" :zIndex="0" @city-change="handleCityChange"></citySelect>
 - 	</view>
 - </template>
 - 
 - <script>
 - 	import { housePageList,houseType,noticeObjApi,getConfig,commonIndexIndexIcon, getInfo, getBanner } from "@/common/api.js"
 - 	import citySelect from "@/components/cityselect/index.vue"
 - 	const lineBg = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAANCAYAAAC3mX7tAAAAAXNSR0IArs4c6QAAAbxJREFUOE+lk0FrE1EUhc+ZDOhMigjZdNcWdCPJqNCdlkZw4TKL2mVwkKLQ/gAFRcEu/AEKuumDrEopNEsXSlNoV+2iTYIbBdNdNwGpmRmFyVx5oQk6mYSpvt1799z7zTnvDQPlBAJcRGxZOLXotn7Gz8ftZePaROCZP+IaEh36a04LxFS8mMmgcKFcb54H9Kvi5LtdNIZ6BMf0lVMDMD88UJ7abuP1eUDeWuEZyVcJPZ/oKeclgRcJxRMrG17l4udOGthZbF8ATMb1IvKcXiU/y66xnziM2LQf1O+nAfnq+hYgpSStCeMmdcFXzi6AWyMGrlvZcGmUs54T31QQLIzo37Pd+u0eKFD5osDYHvPlJyLyNopYnbgUtrSuc2pOG4aUSC4nxTWYFXHOfni02wPp5anCO4KP0sSUViOQ91m38VjrByDZLprBt/ZHkAkvMO3oP3QiO9ZM7i7v1MK/QHoj6sblQLrV/4ZpCDMluoff++iBo/6Bdua32m/+NUYdlz2dW+k7GQnqF84eyOqY1xjPcw8Rn+iLTwp6yFFcpP8zhLxHsgjBFRrI9WKO0AbxVURqMOVDttw8GHeTvwFKoZ4cmcUYJAAAAABJRU5ErkJggg==";
 - 	import QQMapWX from "@/util/qqmap-wx-jssdk.min.js"
 - 	import homeList from '@/components/home/homeList.vue'
 - 	export default{
 - 		components:{
 - 			citySelect,
 - 			homeList,
 - 		},
 - 		data(){
 - 			return{
 - 				city:"",
 - 				keyword:"",
 - 				lineBg: lineBg,
 - 				bannerList:[
 - 					{
 - 						image : "https://image.hhlm1688.com/2025-08-05/b9b3d015-fcaf-4667-8946-ad9436503a25.jpg"
 - 					}
 - 				],
 - 				nav:[],
 - 				noticeObj:{},
 - 				houseTypeList:[],
 - 				classId:null,
 - 				pageNo:1,
 - 				pageSize:10,
 - 				list:[]
 - 			}
 - 		},
 - 		onShareAppMessage() {
 - 			let share = {
 - 				title:this.$utils.getkeyContent('logo_name').keyContent,
 - 				path:"/pages/home/index?userId="+uni.getStorageSync('userInfo').id,
 - 				success:(res) => {
 - 					console.info(res)
 - 				},
 - 				fail:(err)=>{
 - 					console.info(err)
 - 				}
 - 			}
 - 			console.info(share)
 - 			return share
 - 		},
 - 		onLoad(options) {
 - 			//#ifdef MP-WEIXIN
 - 			wx.showShareMenu({
 - 				withShareTicket: true,
 - 				menus: ['shareAppMessage', 'shareTimeline']
 - 			});
 - 			//#endif
 - 			if(options.userId){
 - 				uni.setStorageSync('userId',options.userId)
 - 			}
 - 			uni.chooseAddress({
 - 				success(res) {
 - 					console.info(res)
 - 				}
 - 			})
 - 			this.getLocation()
 - 			this.onCommonIndexIndexIcon()
 - 			this.onNotice();
 - 			this.onHousePageList();
 - 			this.onHouseType();
 - 			this.getBanner();
 - 			// this.onGetConfig()
 - 		},
 - 
 - 		onPullDownRefresh() {
 - 			let that = this
 - 			that.pageNo =  1
 - 			that.list = []
 - 			that.onHousePageList()
 - 		},
 - 		onReachBottom() {
 - 			let that = this
 - 			that.pageNo = that.pageNo + 1
 - 			that.onHousePageList()
 - 		},
 - 		methods:{
 - 			getLocation(){
 - 			    const that = this;
 - 			    wx.getLocation({
 - 			        type: 'wgs84',
 - 					success: function (res) {
 - 						console.log('当前位置的经度:' + res.longitude);
 - 						console.log('当前位置的纬度:' + res.latitude);
 - 						const qqmapsdk = new QQMapWX({
 - 						    key: 'TT7BZ-Z3LW4-KOAUB-KWHOA-SBJJ6-Y5B6R' // 必填
 - 						});
 - 						qqmapsdk.reverseGeocoder({
 - 						    location: {
 - 						        latitude: res.latitude,
 - 						        longitude: res.longitude
 - 						    },
 - 						    success: function(response) {
 - 								that.city = response.result.ad_info.city
 - 						        console.log('逆地理编码结果:', response);
 - 						    },
 - 						    fail: function(error) {
 - 						        console.error('逆地理编码失败:', error);
 - 						    }
 - 						});
 - 					}
 - 				})
 - 			},
 - 			getBanner(){
 - 				getBanner()
 - 				.then(res => {
 - 					this.bannerList = res.result.records
 - 				})
 - 			},
 - 			onNavigator(){
 - 				let token =  uni.getStorageSync('token');
 - 				if(!token){
 - 					uni.navigateTo({
 - 						url:"/pages/auth/index"
 - 					})
 - 					return ;
 - 				}
 - 				getInfo({}).then(result=>{
 - 					uni.navigateTo({
 - 						// url:"/pages_subpack/house/index"
 - 						url:"/pages_subpack/house/select"
 - 					})
 - 				}).catch(err=>{
 - 					
 - 				})
 - 			},
 - 			onCommonIndexIndexIcon(){
 - 				let that = this
 - 				commonIndexIndexIcon({}).then(response=>{
 - 					console.info('onCommonIndexIndexIcon',response)
 - 					that.nav = response.result
 - 					// 检查是否已存在地图导览入口
 - 					let hasMapGuide = that.nav.some(item => item.url === '/pages_subpack/tourGuide/tourGuide')
 - 					if(!hasMapGuide) {
 - 						// 添加地图导览入口
 - 						// that.nav.push({
 - 						// 	id: 'map_guide',
 - 						// 	title: '地图导览',
 - 						// 	image: 'https://tennis-oss.xzaiyp.top/2024-12-08/9704d4a0-e8d8-40fc-a2b6-28b928013a60.png',
 - 						// 	url: '/pages/tourGuide/tourGuide'
 - 						// })
 - 					}
 - 				}).catch(error=>{
 - 					
 - 				})
 - 			},
 - 			onSearch(){
 - 				uni.navigateTo({
 - 					url:"/pages_subpack/category/index"
 - 				})
 - 			},
 - 			onLogin(){
 - 				console.info("onLogin")
 - 					uni.navigateTo({
 - 						url:"/pages/auth/index"
 - 					})
 - 			},
 - 			
 - 			onNotice(){
 - 				noticeObjApi({}).then(response=>{
 - 					console.info('noticeObj',response)
 - 					this.noticeObj = response.result
 - 				}).catch(error=>{
 - 					
 - 				})
 - 			},
 - 			
 - 			onHouseType(){
 - 				houseType({}).then(response=>{
 - 					console.info('houseType',response)
 - 					this.houseTypeList = response.result
 - 				}).catch(error=>{
 - 					
 - 				})
 - 			},
 - 			onClickHouseType(event){
 - 				console.info(event)
 - 				let that = this
 - 				that.pageNo =  1
 - 				that.classId = event.id
 - 				that.list =[]
 - 				that.onHousePageList()
 - 			},
 - 			onHousePageList(){
 - 				let that = this
 - 				let params={
 - 					classId:that.classId,
 - 					pageNo:that.pageNo,
 - 					pageSize:that.pageSize
 - 				}
 - 				housePageList(params).then((response) => {
 - 					uni.stopPullDownRefresh()
 - 					console.info("responseindexsindexsindexs",response.result.records)
 - 					response.result.records.forEach((items,indexs)=>{
 - 						if(items.image){
 - 							items.images = items.image.split(',')
 - 						}else{
 - 							items.images = []
 - 						}
 - 						if(items.homeImage){
 - 							items.homeImages = items.homeImage.split(',')
 - 						}else{
 - 							items.homeImages = []
 - 						}
 - 						if(items.iconTitle){
 - 							items.iconTitles = items.iconTitle.split(',')
 - 						}else{
 - 							items.iconTitles = []
 - 						}
 - 						
 - 					})
 - 					console.info('response.resultindexsindexsindexs',response.result.records)
 - 					that.list = that.list.concat(response.result.records) 
 - 				}).catch((error) =>{
 - 					
 - 				})
 - 			},
 - 			
 - 			handleAreaChange(){
 - 				// uni.chooseAddress({
 - 				// 	success(res) {
 - 				// 		console.info(res)
 - 				// 	}
 - 				// })
 - 				uni.navigateTo({
 - 					url:"/pages_subpack/tourGuide/tourGuide"
 - 				})
 - 				// this.$refs.citySelectRef.open()
 - 			},
 - 			handleCityChange(e) {
 - 				console.info(e)
 - 				this.city = e.city.label
 - 				// this.form.area = e.province.label + '-' + e.city.label + '-' + e.area.label;
 - 			},
 - 			onDetail(event){
 - 				uni.navigateTo({
 - 					url:"/pages_subpack/detail/index?id="+event.id
 - 				})
 - 			},
 - 			toNotice(){
 - 				uni.navigateTo({
 - 					url:"/pages_subpack/notice/index"
 - 				})
 - 			}
 - 		}
 - 	}
 - </script>
 - 
 - <style>
 - 	page{
 - 		background-color: #f5f5f5;
 - 	}
 - 	.se-grid{
 - 		border-top-right-radius: 50rpx;
 - 		border-top-left-radius: 50rpx;
 - 	}
 - 	.backdrop{
 - 		width: 750rpx;
 - 		height: 350rpx;
 - 		position: absolute;
 - 		top: 0;
 - 		left: 0;
 - 		z-index: -1;
 - 		/* border-radius: 0 0 14% 14%; */
 - 	}
 - 	.nobreak {
 - 	  white-space: nowrap;
 - 	}
 - 	
 - 	/* 位置显示优化 */
 - 	.location-container {
 - 		min-width: 0;
 - 		max-width: 200rpx;
 - 		flex-shrink: 0;
 - 	}
 - 	
 - 	.location-text {
 - 		white-space: nowrap;
 - 		overflow: hidden;
 - 		text-overflow: ellipsis;
 - 		max-width: 140rpx;
 - 		display: inline-block;
 - 	}
 - 	
 - 	.search-container {
 - 		min-width: 0;
 - 	}
 - </style>
 
 
  |