热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

勿以恶小而为之,勿以善小而不为

之前我有提到做过的一个demo类的项目,因为觉得一个demo能跑就行,没有必要把日志之类的功能加上去,结果把别人给坑了。现在我发现,某个项目因为自己当初偷懒,如今把自己坑了。起因大概两个月前,

之前我有提到做过的一个demo类的项目,因为觉得一个demo能跑就行,没有必要把日志之类的功能加上去,结果把别人给坑了。现在我发现,某个项目因为自己当初偷懒,如今把自己坑了。

起因

大概两个月前,我接手了一个转手了好几个人的项目。主要需求就是处理一下数据库的数据,然后在页面上展示一下。前端没有什么要求,用easyui套一下就行,页面也就一两个。项目的前端是用JSP做的,而且貌似每一个接手的人都做了一些页面,但这些页面大都样式丑陋,基本没法看,而且现在也完全没有用了。
因为考虑到页面不多,而且项目持续时间也不会太长,需求没有几个,所以我决定前端沿用JSP,尽管我觉得thymleaf更好用。而且,因为只有两个页面,我也懒得去做组件化,layout了,代码大量复制粘贴

接下来的两个月里,陆陆续续接到了一些需求,增加了一些功能和页面,代码渐渐膨胀了起来。今天,当我再次接到了新需求,打开项目的时候,我发现代码已经变得有点难维护了。
首先是自己粘贴的大量重复代码,看到就头疼,但好歹是自己写的,里面的逻辑还看得懂;其次是页面没有layout和组件化,实现新页面的时候又要做之前做过的重复工作;最重要的是当我想用JSP自定义tag实现layout功能的时候,发现jstl嵌套进自定义的tag之后居然失效(最后发现其实是easyui的问题),因为对JSP不熟悉,找到这个问题花了我很多时间。

反思

其实我也没有料到,当初一个简简单单的小项目会变成现在这样。如果早知道的话,我就不会这么随意地去做了。结果现在又要花大量的时间去对代码进行重构。由此我想到了当前还在专职做前端开发的时候参与的一个app项目。项目初期是用jQuery快速搭建的原型,之后在原型的基础上,不断新增功能,但又没有及时进行重构,结果后来积重难返,前端开发们只能痛苦地用jQuery操作着DOM,而无法享受到MVVM框架带来的便利。

对于每一个接手的项目,我们其实无法预测最后它会发展成什么样,是做完就再也不会碰了还是会一直有新需求。既然如此,我们对任何一个项目都不该偷懒,该做的事情要做到位,该有的功能一个不能落下,代码规范不能放松。否则,我们坑的可能不是别人,而是未来看到当初写的代码后悔不已的自己。

该重构的还是要重构,希望类似的错误自己以后不再犯。


推荐阅读
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 本文详细探讨了 Django 的 ORM(对象关系映射)机制,重点介绍了其如何通过 Python 元类技术实现数据库表与 Python 类的映射。此外,文章还分析了 Django 中各种字段类型的继承结构及其与数据库数据类型的对应关系。 ... [详细]
  • 探讨了在有序数列中实现多种查询和修改操作的高效数据结构设计,主要使用线段树与平衡树(Treap)结合的方法。 ... [详细]
  • 深入理解T-SQL中的NULL与三值逻辑
    本文探讨了SQL Server中的三值逻辑,解释了谓词计算结果为TRUE、FALSE和UNKNOWN的规则。通过具体示例,详细说明了如何正确处理NULL值,并探讨了在不同约束条件下的行为。 ... [详细]
  • Redis Hash 数据结构详解
    本文详细介绍了 Redis 中的 Hash 数据类型及其常用命令。Hash 类型用于存储键值对集合,支持多种操作如插入、查询、更新和删除字段值。此外,文章还探讨了 Hash 类型在实际业务场景中的应用,并提供了优化建议。 ... [详细]
  • 解决U盘安装系统后无法重启的问题
    本文详细探讨了运维新手常遇到的U盘安装系统后无法正常重启的问题,提供了从问题分析到具体解决方案的完整步骤。通过理解Boot Loader的工作原理和正确配置启动项,帮助用户顺利解决问题。 ... [详细]
  • 本文介绍了 Winter-1-C A + B II 问题的详细解题思路和测试数据。该问题要求计算两个大整数的和,并输出结果。我们将深入探讨如何处理大整数运算,确保在给定的时间和内存限制下正确求解。 ... [详细]
  • 本文详细介绍超文本标记语言(HTML)的基本概念与语法结构。HTML是构建网页的核心语言,通过标记标签描述页面内容,帮助开发者创建结构化、语义化的Web页面。 ... [详细]
  • 哈密顿回路问题旨在寻找一个简单回路,该回路包含图中的每个顶点。本文将介绍如何判断给定的路径是否构成哈密顿回路。 ... [详细]
  • JavaScript 中创建对象的多种方式
    本文介绍了 JavaScript 中创建对象的几种常见方法,包括字面量形式、构造函数、原型对象等。每种方法都有其特点和适用场景,通过对比分析,帮助开发者选择最适合的方式。 ... [详细]
  • 本文探讨了在使用Selenium进行自动化测试时,由于webdriver对象实例化位置不同而导致浏览器闪退的问题,并提供了详细的代码示例和解决方案。 ... [详细]
  • 算法题解析:最短无序连续子数组
    本题探讨如何通过单调栈的方法,找到一个数组中最短的需要排序的连续子数组。通过正向和反向遍历,分别使用单调递增栈和单调递减栈来确定边界索引,从而定位出最小的无序子数组。 ... [详细]
  • 本文深入探讨了线性代数中向量的线性关系,包括线性相关性和极大线性无关组的概念。通过分析线性方程组和向量组的秩,帮助读者理解这些概念在实际问题中的应用。 ... [详细]
  • 本文介绍如何在 C++ 中使用链表结构存储和管理数据。通过具体示例,展示了静态链表的基本操作,包括节点的创建、链接及遍历。 ... [详细]
  • 本文旨在提供一套高效的面试方法,帮助企业在短时间内找到合适的产品经理。虽然观点较为直接,但其方法已被实践证明有效,尤其适用于初创公司和新项目的需求。 ... [详细]
author-avatar
手机用户2502921663
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有