基于若依框架的二次开发——“智慧管家“物流管理系统

基于若依框架的二次开发——"智慧管家"物流管理系统

一、引言

随着信息技术的飞速发展,物业管理行业也迎来了数字化转型的浪潮。传统的物业管理方式已经无法满足现代小区高效、便捷的管理需求。因此,我们选择了若依框架作为基础,进行物业管理系统的二次开发,旨在打造一个功能全面、操作简便、安全可靠的物业管理平台。

二、框架简介

若依框架是一个基于Spring Boot的快速开发平台,它集成了众多优秀的开源技术,如MyBatis、Shiro、Swagger等,提供了丰富的功能模块和完善的权限管理功能。通过若依框架,我们可以快速搭建起一个稳定、高效、可扩展的Web应用。

三、项目开发

1、目的背景

  • 提升物业管理效率:通过引入信息化管理系统,提高物业管理的效率和准确性,降低人力成本。
  • 加强业主满意程度:通过优化服务流程,提高服务质量,增强业主对物业管理的满意度。
  • 推动智慧型社区建设:作为智慧型社区的重要组成部分,小区物业管理系统有助于实现社区智能化、便捷化和安全化。

2、项目介绍

该系统运用Spring Boot和Vue框架,采用前后端分离的开发模式,旨在实现对小区内建筑物、公共设施、业主信息以及各项服务的高效便捷地管理。项目分为前台模块和后套模块,前台是一个租房网站,使用html5和Ajax实现,游客可以通过注册获取账号登录后即可浏览小区的房源信息;
后台模块是管理系统,运用Spring Boot和Vue3来实现,物业和业主可以使用已有的账号登录后台对数据进行管理和维护。
在这里插入图片描述

3、小组分工

在这里插入图片描述
小组由四人组成,以上的分工是最初小组会议讨论时定下的,在开发的过程中根据需求和功能有所细微的增加与变动。

4、功能实现

1)前台模块

为了体验从0到1的过程,开发时没有使用前端页面的模版,采用原生js的方式手写html5页面,因而比较简陋,以下是列出的几个页面:
首页
在这里插入图片描述
房屋出租
在这里插入图片描述
个人中心
在这里插入图片描述

2)添加收藏

用户只用登录后才能使用该网站,游客是无法访问的。登录后,用户可以浏览未出租状态的房屋,对自己喜欢的房屋可以添加收藏,对已经收藏的房屋信息会展示在个人中心的收藏里。若用户想要租下这套房可以查看详情跳转到详情页面提交订单;对不想再收藏的房屋信息可以移除。
在这里插入图片描述
部分代码展示:

// 查询收藏列表
        function loadCollect(tId) {
            $.ajax({
                url: "collect/8080/select",
                type: "get",
                data: {
                    tId: tId
                },
                dataType: "json",
                success: function (result) {
                    if (result.code == 200) {
                        var jsons = result.data;


                        //清空表格主体内容
                        $("#collect-list").empty();
                        var str = "";
                        for (let i = 0; i < jsons.length; i++) {
                            //获取循环的某一个json对象  {}
                            var room = jsons[i];

                            str = "<tr>\n" +
                                "<td>\n" +
                                "<img src='" + room.img + "' alt=\"租房图片\" class=\"rental-image\"/>\n" +
                                "</td>\n" +
                                "<td>幸福里" + room.name + "</td>\n" +
                                "<td>" + room.unitName + "</td>\n" +
                                "<td>" + room.roomNum + "</td>\n" +
                                "<td>" + room.userName + "</td>\n" +
                                "<td>\n" +
                                "<a href='javascript:void(0)' style=\"color:black\" οnclick='details(" + room.id + ")'><button>查看详情</button></a>" +
                                "<a href='javascript:void(0)' style=\"color:black\" οnclick='deleteCollect(" + room.id + ")'><button>删除</button></a>" +
                                "</td>\n" +
                                "</tr>";
                            //循环向指定标签对象中追加元素内容
                            $("#collect-list").append(str);
                        }
                    }
                }
            })
        }

        //查看详情
        function details(id) {
            location.href = 'details.html?id=' + id;
        }

        //删除收藏
        function deleteCollect(id) {
            var flag = window.confirm("是否需要删除");
            if (flag == true) {
                //获取需要删除的房源编号
                $.post("collect/8080/delete", {
                    id: id
                }, function (data) {
                    loadCollect(tId)
                }, "json");
            }
        }
3)收费管理

这一功能属于后台的管理系统,租户租赁房屋后会产生水电等一系列费用。这一模块就是对租户产生的费用以及缴费记录进行展示。业主及物业可以对其进行维护。
在这里插入图片描述
在这里插入图片描述
部分代码展示:

<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px">
      <el-form-item label="房间号" prop="roomNum">
        <el-input
            v-model="queryParams.roomNum"
            placeholder="请输入房间号"
            clearable
            @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item label="余量" prop="remain">
        <el-input
            v-model="queryParams.remain"
            placeholder="请输入余量"
            clearable
            @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item>
        <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
        <el-button icon="Refresh" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
            type="primary"
            plain
            icon="Plus"
            @click="handleAdd"
            v-hasPermi="['payment:ecCost:add']"
        >新增</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
            type="success"
            plain
            icon="Edit"
            :disabled="single"
            @click="handleUpdate"
            v-hasPermi="['payment:ecCost:edit']"
        >修改</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
            type="danger"
            plain
            icon="Delete"
            :disabled="multiple"
            @click="handleDelete"
            v-hasPermi="['payment:ecCost:remove']"
        >删除</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
            type="warning"
            plain
            icon="Download"
            @click="handleExport"
            v-hasPermi="['payment:ecCost:export']"
        >导出</el-button>
      </el-col>
      <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>

    <el-table v-loading="loading" :data="costList" @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="费用编号" align="center" prop="id" />
      <el-table-column label="房间号" align="center" prop="roomNum" />
      <el-table-column label="余量" align="center" prop="remain" />
      <el-table-column label="单价" align="center" prop="price" />
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
        <template #default="scope">
          <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['payment:ecCost:edit']">修改</el-button>
          <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['payment:ecCost:remove']">删除</el-button>
        </template>
      </el-table-column>
    </el-table>

    <pagination
        v-show="total>0"
        :total="total"
        v-model:page="queryParams.pageNum"
        v-model:limit="queryParams.pageSize"
        @pagination="getList"
    />

    <!-- 添加或修改电费余额对话框 -->
    <el-dialog :title="title" v-model="open" width="500px" append-to-body>
      <el-form ref="costRef" :model="form" :rules="rules" label-width="80px">
        <el-form-item label="房间ID" prop="roomNum">
          <el-input v-model="form.roomId" placeholder="请输入房间ID" />
        </el-form-item>
        <el-form-item label="余量" prop="remain">
          <el-input v-model="form.remain" placeholder="请输入余量" />
        </el-form-item>
        <el-form-item label="单价" prop="price">
          <el-input v-model="form.price" placeholder="请输入单价" />
        </el-form-item>
      </el-form>
      <template #footer>
        <div class="dialog-footer">
          <el-button type="primary" @click="submitForm">确 定</el-button>
          <el-button @click="cancel">取 消</el-button>
        </div>
      </template>
    </el-dialog>
  </div>
</template>

<script setup name="Cost">
import { listCost, getCost, delCost, addCost, updateCost } from "@/api/payment/ecCost";

const { proxy } = getCurrentInstance();

const costList = ref([]);
const open = ref(false);
const loading = ref(true);
const showSearch = ref(true);
const ids = ref([]);
const single = ref(true);
const multiple = ref(true);
const total = ref(0);
const title = ref("");

const data = reactive({
  form: {},
  queryParams: {
    pageNum: 1,
    pageSize: 10,
    roomId: null,
    remain: null,
    price: null
  },
  rules: {
  }
});

const { queryParams, form, rules } = toRefs(data);

/** 查询电费余额列表 */
function getList() {
  loading.value = true;
  listCost(queryParams.value).then(response => {
    costList.value = response.data;
    total.value = response.total;
    loading.value = false;
  });
}

// 取消按钮
function cancel() {
  open.value = false;
  reset();
}

// 表单重置
function reset() {
  form.value = {
    id: null,
    roomNum: null,
  };
  proxy.resetForm("costRef");
}

/** 搜索按钮操作 */
function handleQuery() {
  queryParams.value.pageNum = 1;
  getList();
}

/** 重置按钮操作 */
function resetQuery() {
  proxy.resetForm("queryRef");
  handleQuery();
}

// 多选框选中数据
function handleSelectionChange(selection) {
  ids.value = selection.map(item => item.id);
  single.value = selection.length != 1;
  multiple.value = !selection.length;
}

/** 新增按钮操作 */
function handleAdd() {
  reset();
  open.value = true;
  title.value = "添加电费余额";
}

/** 修改按钮操作 */
function handleUpdate(row) {
  reset();
  const _id = row.id || ids.value
  getCost(_id).then(response => {
    form.value = response.data;
    open.value = true;
    title.value = "修改电费余额";
  });
}

/** 提交按钮 */
function submitForm() {
  proxy.$refs["costRef"].validate(valid => {
    if (valid) {
      if (form.value.id != null) {
        updateCost(form.value).then(response => {
          proxy.$modal.msgSuccess("修改成功");
          open.value = false;
          getList();
        });
      } else {
        addCost(form.value).then(response => {
          proxy.$modal.msgSuccess("新增成功");
          open.value = false;
          getList();
        });
      }
    }
  });
}

/** 删除按钮操作 */
function handleDelete(row) {
  const _ids = row.id || ids.value;
  proxy.$modal.confirm('是否确认删除电费余额编号为"' + _ids + '"的数据项?').then(function() {
    return delCost(_ids);
  }).then(() => {
    getList();
    proxy.$modal.msgSuccess("删除成功");
  }).catch(() => {});
}

/** 导出按钮操作 */
function handleExport() {
  proxy.download('system/cost/export', {
    ...queryParams.value
  }, `cost_${new Date().getTime()}.xlsx`)
}

getList();
</script>

四、总结

半个月来,我们都沉浸在系统的开发中。在项目启动之初,我们小组尽可能地想要打造一款功能全面、操作简便、安全可靠的物业管理系统。,旨在满足对小区的管理需求,通过集成先进的技术和创新的解决方案,极大地提升了物业管理的效率和服务质量。
当然,经过这次开发我学到了很多,特别是累积的项目开发经验,这将会是我以后的职业生涯中不可磨灭的一笔。还有之前对于ajax的运用还不太熟悉,在这次开发中对于我的ajax编码能力也有所提高。也许这个系统的功能比较简单,但还是实现了一些功能,也不能否定这半个月来小组的劳动成果,特别是两个男生,经常加班到很晚。但也存在着一些不足之处,主要分为三个方面:
(1)前端页面编写过于粗糙,由于功能的过于简单,老师建议我们增加一个前台的租房系统。刚开始没想那么多,就想着能够实现简单的租房功能就好,在网上搜寻无果后便决定自己手写静态页面。结果显而易见,耗时又低效。
(2)由于自己的知识体系不够完备熟练,在开发过程中发现很多小问题而导致效率较低,到后阶段甚至不能按时完成每日的分工,致使工程一拖再拖。
(3)团队缺乏及时的沟通,在开发项目是出现了很多很多意料之外的问题,当然这跟缺乏开发项目也有一定的关系。比如在讨论阶段,老师就跟我们说过,先不要编码,数据库的设计是重中之重的,一旦数据库设计有问题后期就会花费大量的时间来返工。事实证明,好的数据库设计真的能省下大量的时间,提高开发效率。
对于项目中发现的问题我会吸取教训,牢记在心,争取在下次的项目开发中避免这些问题。

  • 24
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值