【发布时间】:2011-02-04 14:15:40
【问题描述】:
我是一名前端开发人员,我发现自己经常在 jsp 视图层工作,并且看到了很多将数据(模型)推送到视图中的解决方案。最近遇到了一个taglib的方案,可以把数据拉到jsp里面,我觉得这个方案比较自然和合理。
首先是问题
鉴于单个页面并将其视为一个单独的实体,MVC 绝对有意义,但是单个页面可能非常复杂,并且很可能重用在其他页面上使用的组件/服务。因此,控制器也变得相当复杂。
根据我的经验,页面也是可变的,因为客户喜欢在下一次“重新设计”时改变功能或将整个网站翻过来。这通常会导致一个相当繁琐的重构项目,实际上所有东西都需要重写。
然后是一致性问题,在一个页面上,数据集作为“列表”放入 ModelView,而在另一个页面上,“列表”可能是抽象的,它作为“特定列表”放入 ModelView。在项目生命周期中保持一致性成为一项乏味的日常任务,通常可以避免,但这正是纯 MVC 解决方案所发生的事情。
解决方案?
所以在我最近继承的一个项目中,我看到了两种将数据提取到 pageView 中的解决方案。第一个是使用 jsp:include 来调用 jsp 页面并触发另一个控制器相当难看。
我发现第二个相当优雅,他们使用 taglib 将特定数据集拉入 pageView。 taglib 记录在 TLD 中,使用起来很愉快。突然之间,我可以在多个页面上重复使用数据,而无需使用控制器。
因此,在这个项目中,我不得不实施“重新设计”,所有数据提取解决方案都让我的工作变得轻松了很多,但是在他们使用数据注入 (MVC) 的地方,这让我很头疼(我我不是 Java 开发人员)和 Java 开发人员来帮助解决很少到没有的地方。
正确编写的 taglib 也可以只写入一次,而使用数据注入 (MVC) 可能会成为您经常需要照顾的孩子(在 jsp 之上)。
标签库示例
假设我们有带有以下标签定义/实现的 services.tld。
- 获取员工地址
- 获取员工
<services:getEmployees filter="a">
<!-- loop, get addresses, otherwise if empty list, render nothing -->
</services:getEmployees>
这使我(前端)可以在几乎任何页面上显示员工及其地址,从而腾出 Java 开发人员来完成更重要的任务。该服务可独立于 pageView 控制器进行测试,pageView 控制器变得不那么复杂(例如,仅处理身份验证和站点范围的功能)并且生活(至少对我而言)似乎更有趣。
我的问题
实际上是多部分:
1.) 我的推理是废话吗?如果是,为什么以及从什么角度? =P
2.) 有更好的选择吗? (例如,我也使用了瓷砖)。
3.) 您是否在使用上述 taglib 解决方案?您对此有何体验?
4.) 从 java 开发人员的角度来看,上述 taglib 解决方案的成本/收益/风险是什么?
我理解为什么 MVC 让 Java 开发人员变得简单,但根据我的经验(到目前为止),它只是将困难转移到了 jsp 层,就像我有时需要为每个页面学习一个单独的 API...作为一名前端开发人员,我承认使用 Ajax 和所有那些令人毛骨悚然的东西对我来说数据拉取更自然,在页面加载时拥有所有可用数据在我的领域是一种反模式......
【问题讨论】:
-
哦,请随意全力以赴地讨论业务逻辑的归属=P
标签: java model-view-controller taglib