当前位置: 首页 > news >正文

从0到100:房产中介小程序开发笔记(中)

背景调研

为中介带来诸多优势,能借助它打造专属小程序,方便及时更新核实租赁信息,确保信息准确无误,像房屋的大致地址、租金数额、租赁条件、房源优缺点等关键信息都能清晰呈现。还可上传房屋拍摄照片,这样用户能提前了解房屋状况,从而减少实地看房时间,中介也能借此降低人力成本,实现双赢。

功能规划

  • 小区管理:后台录入小区的地图位置,地段,主要特点,户型,交通地铁,外观图片,在售在租房源等。
  • 房源管理:后台录入房源的地图位置,地段,主要特点,水电气费用,户型,面积,楼层,上传室内图片等。
  • 中介管理:后台录入金牌中介经纪人的信息,包括特点,联系方式等。
    用户端:根据多种条件查看房源信息,地图导航位置等
    在这里插入图片描述

数据字典

ProductModel.DB_STRUCTURE = {_pid: 'string|true',PRODUCT_ID: 'string|true',PRODUCT_TITLE: 'string|true|comment=标题',PRODUCT_STATUS: 'int|true|default=1|comment=状态 0=未启用,1=使用中',PRODUCT_CATE_ID: 'string|true|default=0|comment=分类',PRODUCT_CATE_NAME: 'string|false|comment=分类冗余',PRODUCT_ORDER: 'int|true|default=9999',PRODUCT_VOUCH: 'int|true|default=0', PRODUCT_FORMS: 'array|true|default=[]',PRODUCT_OBJ: 'object|true|default={}',PRODUCT_QR: 'string|false',PRODUCT_VIEW_CNT: 'int|true|default=0',PRODUCT_ADD_TIME: 'int|true',PRODUCT_EDIT_TIME: 'int|true',PRODUCT_ADD_IP: 'string|false',PRODUCT_EDIT_IP: 'string|false',
};
CateModel.DB_STRUCTURE = {_pid: 'string|true',CATE_ID: 'string|true',CATE_TITLE: 'string|false|comment=标题',CATE_STATUS: 'int|true|default=1|comment=状态 0/1',CATE_CNT: 'int|true|default=0',CATE_FORMS: 'array|true|default=[]',CATE_OBJ: 'object|true|default={}',CATE_ADDRESS_DETAIL: 'string|false|comment=详细地址',CATE_ADDRESS: 'object|false|comment=详细地址坐标参数', CATE_ORDER: 'int|true|default=9999',CATE_VOUCH: 'int|true|default=0',CATE_QR: 'string|false',CATE_ADD_TIME: 'int|true',CATE_EDIT_TIME: 'int|true',CATE_ADD_IP: 'string|false',CATE_EDIT_IP: 'string|false',
};

代码实现

在这里插入代码片

class CateService extends BaseProjectService {

async getAllCateOptions(status = 1) {let cateList = await CateModel.getAll({ CATE_STATUS: status }, '*', { 'CATE_ORDER': 'asc', 'CATE_ADD_TIME': 'desc' });let arr = [];for (let k in cateList) {let cateId = cateList[k]._id;let cateNode = {level: 1,label: cateList[k].CATE_TITLE,val: cateId,order: cateList[k].CATE_ORDER,obj: cateList[k].CATE_OBJ,parentId: ''}arr.push(cateNode);}return arr;
}async getCateList({query,search, // 搜索条件sortType, // 搜索菜单sortVal, // 搜索菜单orderBy, // 排序 page,size,isTotal = true,oldTotal
}) {orderBy = orderBy || {'CATE_ORDER': 'asc','CATE_ADD_TIME': 'desc'};let fields = '*';let where = {};where.and = {_pid: this.getProjectId() //复杂的查询在此处标注PID};where.and.CATE_STATUS = 1; // 状态    if (query && query.line && query.line.length > 0) {where.and['CATE_OBJ.line'] = ['in', query.line];}if (query && query.tag && query.tag.length > 0) {where.and['CATE_OBJ.tag'] = ['in', query.tag];}if (query && query.type && query.type.length > 0) {where.and['CATE_OBJ.type'] = ['in', query.type];}if (query && query.area && query.area.length > 0) {where.and['CATE_OBJ.area'] = ['in', query.area];}if (query && query.cate && query.cate.length > 0) {where.and['CATE_OBJ.cate'] = ['in', query.cate];}where.and['CATE_OBJ.rentmin'] = ['>=', Number(query.rentmin)];where.and['CATE_OBJ.rentmax'] = ['<=', Number(query.rentmax)];if (util.isDefined(search) && search) {where.or = [{ 'CATE_OBJ.station': ['like', search] },{ CATE_TITLE: ['like', search] },];} else if (sortType && util.isDefined(sortVal)) {// 搜索菜单switch (sortType) {case 'sort': {// 排序orderBy = this.fmtOrderBySort(sortVal, 'CATE_ADD_TIME');break;}case 'trade': {where.and['CATE_OBJ.trade'] = sortVal;break;}case 'size': {where.and['CATE_OBJ.size'] = sortVal;break;}case 'type': {where.and['CATE_OBJ.type'] = sortVal;break;}case 'star': {where.and['CATE_OBJ.star'] = sortVal;break;}}}return await CateModel.getList(where, fields, orderBy, page, size, isTotal, oldTotal);
}async viewCate(id) {let fields = '*';let where = {_id: id,CATE_STATUS: 1}let cate = await CateModel.getOne(where, fields);if (!cate) return null;let list = await ProductModel.getAll({ PRODUCT_CATE_ID: id, PRODUCT_STATUS: 1 });cate.list = list;return cate;
}

}

UI设计

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

管理系统

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

git代码下载

点击下载

http://www.lqws.cn/news/546589.html

相关文章:

  • css去掉换行小工具 去掉css换行 style样式去掉换行
  • flink同步kafka到paimon,doris加速查询
  • 大数据赋能智能家居:打造你贴心的“数字管家”
  • 飞往大厂梦之算法提升-day09
  • ssh -T git@github.com失败后解决方案
  • Google机器学习实践指南(逻辑回归损失函数)
  • RabitQ 量化:既省内存又提性能
  • 华为云Flexus+DeepSeek征文 | 基于华为云ModelArts Studio平台搭建AI Markdown编辑器
  • 【iSAQB软件架构】四大架构视图利益相关者
  • 【开源项目】「安卓原生3D开源渲染引擎」:Sceneform‑EQR
  • 机器学习6——线性分类函数
  • PHP「Not enough Memory」实战排错笔记
  • 小程序 API 开发手册:从入门到高级应用一网打尽
  • 基于[coze][dify]搭建一个智能体工作流,抓取热门视频数据,自动存入在线表格
  • Python打卡:Day38
  • 华为数通认证:适合谁的技术进阶之路?
  • 基于MySQL的分布式锁实现(Spring Boot + MyBatis)
  • 【数据分析,相关性分析】Matlab代码#数学建模#创新算法
  • 【C语言】知识总结·指针篇
  • 关于SAP产品名称变更通知 SAP云认证实施商工博科技
  • 动态控制click事件绑定
  • H.264中片数据分割(Slice Data Partitioning)介绍
  • Decoder-only PLM GPT1
  • c++异常
  • LINUX625 DNS反向解析
  • gemini-cli 踩坑实录
  • Windows VMWare Centos环境下安装Docker并配置MySql
  • PART 7 视频
  • web布局25
  • iOS打包流程中的安全处理实践:集成IPA混淆保护的自动化方案