web项目设计文档_谈Web项目框架的搭建和设计

当前web端框架日益丰富,有react、vue、angular等,而且使用方式也比较容易上手,只要根据说明文档走你就能搭建起一个自己的框架。但是这样简单搭建起来的框架就真的可以用于项目开发吗?答案当然是NO。其实这只能算成搭建开发环境的一部分,就像web开发人员在电脑上安装node.js一样,因为这种框架的开发规则的并不是我们设计的,而是用的外部第三方的。引用完这个第三方框架后,剩下的内容才是真正能够展示你架构设计和实现能力的地方!

当然有些人会问,第三方框架引入后还剩下啥?不就是功能实现了嘛,没啥好设计的。这样想的人其实不在少数,我遇到的好多前端开发人员虽然嘴上没这样说过,但是他们思想和开发工作其实都在证明。

引入第三方框架后还有很多事情要干,基于react、vue等框架的思想,我们要开发的是组件而不是平铺开来流水式实现整个页面,也不是把流水式实现的代码切割一下装作是组件,然后做简单的拼接形成页面。所以要根据项目的具体需要设计一套组件实现方式。组件有了我们的页面呢?既然有了一套组件,我们的页面最好是通过配置化的方式组装实现,这样的话开发效率也就自然提升上去,可扩展性应该也能做到最好。总结下来除了引用第三方框架,前端架构设计更重要的内容应该是结构设计和代码设计。

首先是结构设计,好的工程结构可以提高项目的可阅读性,使用起来方便从而提高开发效率。下面是我对一个项目结构的理解:

4cb59675c4255aae18f3a4662c7050eb.png

然后是代码设计,JS的语法导致前端代码的书写比较随意,因此为了提高项目的质量,架构设计中必须加入代码设计。目前typescript是可以提高前端代码书写规范的重要工具,推荐使用。代码设计可以包括以下几个方面:

1.一定要定义类似于强类型语言的数据结构,在定义变量和函数参数时,使用数据结构做类型限制。这样可以让对象的内容清晰明了,不用看代码也知道对象中有那些属性。

2.一定要定义静态常量,比较时使用静态常量作比较。

3.由于前端主要是做数据展示,因此可以根据项目特点定义数据处理中心,数据处理中心的目的主要是为了定义格式化函数,这样数据展示就走一个格式化函数,再次修改展示格式只需要改一个地方,避免全局搜索。

4.在开发过程中要注重每个细节的设计实现,多用配置化的方式实现页面的展示,这样可以提高开发效率和扩展性。比如可以通过配置化方式设定页面布局,可以预先定义好所有列然后通过配置化方式设定每个表格的列,可以通过配置化方式定义导出文件的列信息等等。

5.在做字段信息配置时,考虑在字段信息中添加format、isInclude等属性方法函数,做格式化、是否包含等逻辑处理。在定义回调函数时,可以采用nodejs回调函数的设计思路,把isError作为第一个参数,只有isError是null时,才认为是正常返回,否则为异常。

6.可以根据业务模块的特点为每个业务模块定义各自通用的数据处理方法,在这个层次中定义这些函数方法既不会过于抽象,也可以提供适当的通用性,在适当的取舍中为开发提供便利。

7.如果项目允许的话,可以全局统一定义页面操作行为,为每个操作定义行为信息,使用的时候只需要把操作行为代码传入,整个系统都可以根据根据行为代码找到对应的行为信息,这样可以抽象出所有操作,数据在系统中流转时可以随时获取处理规则。

8.react中的静态成员变量和静态成员函数,在做多个组件实例的数据共享时会有大的用途,请注意使用。

9.发送请求时可以定义三个状态,pending、success、failed。同时对应的定义三个回调函数,onPending、onSuccess、onFailed,这样可以让数据的处理更加方便,切记不要只定义一个回调函数,这样会导致返回的数据不知处于什么状态,还要不停地做逻辑处理分析,而且不够清楚明了。每个状态地回调函数可以允许业务强相关组件做相应地展示处理。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目录 1. 介绍 5 1.1 项目概述 5 1.2 范围 5 1.3 参考 5 2. 用例视图 6 2.1 WAS - SAP R/3 集成用例 6 2.1.1 车辆列表功能 6 2.1.2 车辆订购申请单的创建功能 7 2.1.3 车辆订购申请单查询功能 7 2.1.4 车辆订购申请单的修改功能 7 2.1.5 索赔单的创建 8 2.1.6 数据交换需求 8 2.2 PORTAL集成的用例 8 2.2.1 经销商 Portal 框架 9 2.2.2 车辆销售系统和Portal的整合 9 2.2.3 Nadcon system 和Portal系统的整合 10 2.2.4 车辆销售系统和Nadcon 的整合 10 3. 逻辑视图 10 3.1 兼容性 10 3.2 系统架构 10 3.2.1 逻辑架构 10 3.2.2 Web 应用的包设计 12 3.3 组件设计 - J2EE WEB APPLICATION 13 3.3.1 MVC 框架 – Struts 13 3.3.2 日志 14 3.3.3 BAPI代理结构 15 3.3.4 销售商用户信息组件和安全组件 16 3.3.5 页面表现框架 17 3.3.6 车辆列表功能 18 3.3.7 车辆订购请求单创建 24 3.3.8 车辆订购申请单查询列表 32 3.3.9 车辆订购申 请单修改 37 3.3.10 索赔单创建 43 3.3.11 数据交换 50 3.3.12 登录 & 退出 53 4. 数据视图 56 4.1 车辆列一表 57 4.2 车辆订购申请单创建 58 4.3 车辆订购申请单列表 59 4.4 车辆订购申请单修改 60 4.5 索赔单创建 61 5. 实现视图 62 5.1 缓存策略 62 5.2 会话管理 62 5.3 连接管理 62 5.4 集成的需要 62 5.4.1 WAS – SAP 集成 63 5.4.2 单点登陆 63 5.4.3 Vehicle Sale 系统 和 Nadcon的集成 63 6. 部署视图 64 6.1 安装需求 64 6.1.1 服务器的安装 64 6.2 服务支持的考虑 64 6.2.1 安全 64 6.2.2 服务器管理 64 7. 实现环境视图 64 7.1 开发环境 64 7.2 测试环境 64 7.3 生产环境 65 7.3.1 网络 65 7.4 域信息 65
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值