租房小程序前端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

272 lines
8.3 KiB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
  1. <template>
  2. <view>
  3. <view class="se-px-40 se-py-20">
  4. <view class="se-bgc-white se-br-50 se-c-black se-px-20 se-py-5 se-flex se-flex-h-sb se-fs-26">
  5. <view class="se-b-r se-pl-10 se-pr-20 se-flex se-flex-h se-h-40 se-lh-40 " @click="handleAreaChange()">
  6. <text class="se-pr-20 nobreak">{{city}}</text>
  7. <uv-icon name="arrow-down-fill"></uv-icon>
  8. </view>
  9. <view class="se-ml-20" @click="onLogin()">
  10. <uv-search :showAction="false" bgColor="transparent" placeholder="请输入租房信息" v-model="keyword"></uv-search>
  11. </view>
  12. </view>
  13. </view>
  14. <view class="backdrop se-mb-20">
  15. <image class="se-w-vw-100 se-h-400" src="@/static/image/banner.png" mode=""></image>
  16. </view>
  17. <view class="se-grid se-bgc-white se-py-30 se-mt-300">
  18. <navigator url="/pages_subpack/category/index" v-for="(item, index) in nav" :key="index" class="se-flex-v-c se-mb-20">
  19. <image class="se-a-100 se-br-20" :src="item.img" mode=""></image>
  20. <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>
  21. </navigator>
  22. <!-- <view v-for="(item, index) in nav" :key="index" class="se-flex-v-c se-mb-20" @click="onNav">
  23. <image class="se-a-100 se-br-20" :src="item.img" mode=""></image>
  24. <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>
  25. </view> -->
  26. </view>
  27. <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">
  28. <image class="se-a-80" src="@/static/image/aed60x.png" mode=""></image>
  29. <text class="se-ml-10">{{noticeObj.title}}</text>
  30. </view>
  31. <view class="se-bgc-white se-my-20">
  32. <uv-tabs @click="onClickHouseType" :list="houseTypeList" keyName="title" :activeStyle="{color:'#000000'}" :inactiveStyle="{color:'#666666'}" :lineColor="`url(${lineBg}) 100% 100%`"></uv-tabs>
  33. </view>
  34. <view class="se-pb-200">
  35. <view v-if="list.length>0">
  36. <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">
  37. <view class="se-pos se-w-260 se-h-180">
  38. <image v-if="item.iconImage" class="se-a-80 se-pos-lt" :src="item.iconImage" mode=""></image>
  39. <image class="se-w-260 se-h-180 se-br-10" :src="item.images[0]" mode=""></image>
  40. </view>
  41. <view class="se-pl-10 se-w-p-100">
  42. <view class="se-c-black se-fs-28">
  43. {{item.title}}
  44. </view>
  45. <view class="se-flex se-flex-h-sb se-flex-ai-c se-fs-24 se-mt-10 se-c-66">
  46. <text>{{item.homeType}}</text>
  47. <text>{{item.timeGo}}</text>
  48. </view>
  49. <view class="se-flex se-flex-h-sb se-flex-ai-c se-mt-10">
  50. <template v-if="item.iconTitles.length>0">
  51. <view class="se-flex">
  52. <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">
  53. {{items}}
  54. </view>
  55. </view>
  56. </template>
  57. <template v-else><view></view></template>
  58. <view class="se-c-66 se-flex se-flex-ai-c">
  59. <uv-icon name="eye"></uv-icon>
  60. <text class="se-ml-5 se-fs-18">{{item.num}}</text>
  61. </view>
  62. </view>
  63. <view class="se-flex se-flex-h-sb se-flex-ai-c se-mt-10">
  64. <text class="se-c-red se-fs-24 se-fw-6 se-toe-1">{{item.price}}/{{item.unit}}</text>
  65. <text class="se-c-66 se-fs-22 se-toe-1">{{item.address}}</text>
  66. </view>
  67. </view>
  68. </view>
  69. </view>
  70. <view v-else>
  71. <uv-empty mode="list" ></uv-empty>
  72. </view>
  73. </view>
  74. <!-- 地址 -->
  75. <citySelect ref="citySelectRef" :zIndex="0" @city-change="handleCityChange"></citySelect>
  76. </view>
  77. </template>
  78. <script>
  79. import { housePageList,houseType,noticeObjApi,getConfig } from "@/common/api.js"
  80. import citySelect from "@/components/cityselect/index.vue"
  81. 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==";
  82. export default{
  83. components:{
  84. citySelect
  85. },
  86. data(){
  87. return{
  88. city:"长沙市",
  89. keyword:"",
  90. lineBg: lineBg,
  91. nav:[
  92. {
  93. img:"../../static/image/nav1.png",
  94. name:"闲置散居农房"
  95. },
  96. {
  97. img:"../../static/image/nav2.png",
  98. name:"集体建设用地"
  99. },
  100. {
  101. img:"../../static/image/nav3.png",
  102. name:"鱼塘"
  103. },
  104. {
  105. img:"../../static/image/nav4.png",
  106. name:"林地"
  107. },
  108. {
  109. img:"../../static/image/nav5.png",
  110. name:"经营性建设用地"
  111. },
  112. {
  113. img:"../../static/image/nav6.png",
  114. name:"耕地"
  115. },
  116. {
  117. img:"../../static/image/nav7.png",
  118. name:"出租房"
  119. },
  120. {
  121. img:"../../static/image/nav8.png",
  122. name:"二手房"
  123. }
  124. ],
  125. noticeObj:{},
  126. houseTypeList:[],
  127. classId:null,
  128. pageNo:1,
  129. pageSize:10,
  130. list:[]
  131. }
  132. },
  133. mounted() {
  134. this.onNotice();
  135. this.onHousePageList();
  136. this.onHouseType();
  137. // this.onGetConfig()
  138. this.$store.commit('initConfig')
  139. },
  140. onPullDownRefresh() {
  141. let that = this
  142. that.pageNo = 1
  143. that.list = []
  144. that.onHousePageList()
  145. },
  146. onReachBottom() {
  147. let that = this
  148. that.pageNo = that.pageNo + 1
  149. that.onHousePageList()
  150. },
  151. methods:{
  152. onLogin(){
  153. console.info("onLogin")
  154. uni.navigateTo({
  155. url:"/pages/auth/index"
  156. })
  157. },
  158. onGetConfig(){
  159. console.log('App Show')
  160. getConfig({}).then(response=>{
  161. console.info(response)
  162. // that.commit('setUserInfo',{userInfo:response.result.userInfo,token:response.result.token})
  163. }).catch(error=>{
  164. })
  165. },
  166. onNotice(){
  167. noticeObjApi({}).then(response=>{
  168. console.info('noticeObj',response)
  169. this.noticeObj = response.result
  170. }).catch(error=>{
  171. })
  172. },
  173. onHouseType(){
  174. houseType({}).then(response=>{
  175. console.info('houseType',response)
  176. this.houseTypeList = response.result
  177. }).catch(error=>{
  178. })
  179. },
  180. onClickHouseType(event){
  181. console.info(event)
  182. let that = this
  183. that.pageNo = 1
  184. that.classId = event.id
  185. that.list =[]
  186. that.onHousePageList()
  187. },
  188. onHousePageList(){
  189. let that = this
  190. let params={
  191. classId:that.classId,
  192. pageNo:that.pageNo,
  193. pageSize:that.pageSize
  194. }
  195. housePageList(params).then((response) => {
  196. console.info("responseindexsindexsindexs",response.result.records)
  197. response.result.records.forEach((items,indexs)=>{
  198. if(items.image){
  199. items.images = items.image.split(',')
  200. }else{
  201. items.images = []
  202. }
  203. if(items.homeImage){
  204. items.homeImages = items.homeImage.split(',')
  205. }else{
  206. items.homeImages = []
  207. }
  208. if(items.iconTitle){
  209. items.iconTitles = items.iconTitle.split(',')
  210. }else{
  211. items.iconTitles = []
  212. }
  213. })
  214. console.info('response.resultindexsindexsindexs',response.result.records)
  215. that.list = that.list.concat(response.result.records)
  216. }).catch((error) =>{
  217. })
  218. },
  219. handleAreaChange(){
  220. this.$refs.citySelectRef.open()
  221. },
  222. handleCityChange(e) {
  223. console.info(e)
  224. this.city = e.city.label
  225. // this.form.area = e.province.label + '-' + e.city.label + '-' + e.area.label;
  226. },
  227. onDetail(event){
  228. uni.navigateTo({
  229. url:"/pages_subpack/detail/index"
  230. })
  231. },
  232. toNotice(){
  233. uni.navigateTo({
  234. url:"/pages_subpack/notice/index"
  235. })
  236. }
  237. }
  238. }
  239. </script>
  240. <style>
  241. page{
  242. background-color: #f5f5f5;
  243. }
  244. .se-grid{
  245. border-top-right-radius: 50rpx;
  246. border-top-left-radius: 50rpx;
  247. }
  248. .backdrop{
  249. width: 750rpx;
  250. height: 350rpx;
  251. position: absolute;
  252. top: 0;
  253. left: 0;
  254. z-index: -1;
  255. /* border-radius: 0 0 14% 14%; */
  256. }
  257. .nobreak {
  258. white-space: nowrap;
  259. }
  260. </style>