在jsp开发中模拟.net webform(三)
至此,我们简化了 PageHandler使用。这样的模式使得页面具有了明显的生命周期(体现在P锾攒揉敫ageHandler中)。
onLoad():PageHandler的子类可在此方法中进行页面的初始化,获取页面参数并作初步处理。
服务器端事件:如JSPTest中定义的onTwo和onTen,如果在客户端触发了相应的事件的话,它们将在onLoad之后执行。
onUnload():页面执行完毕后被调用,可以作页面持有资源的清理工作。
在客户端的每一次请求中(包括回调),页面处理器都会按照onLoad、服务器端事件、onUnload的流程顺序运作。把握了这一点,就能很好地组织自己的代码,写出功能复杂的页面来。
这类似WebForm的运作方式,同样,要很好运用ASP.net,也必须注意到WebForm的运作流程。很多习惯于开发桌面应用的人在开始用WebForm时,会随意地说:太简单了,和我以前开发 CS没什么分别,孰不知当用户点击了WebForm中的一个按钮而引起回送时,不但事件函数会执行,onLoad和onUnload也将一前一后地又被调用(为什么说又,因为在回调之前页面初次被请求时,也肯定已经调 用了onLoad和onUnload)。而桌面应用中的窗体,在其显现时调用一次onLoad,关闭时调用onUnload,中间用户触发了事件只会调用对应的事件处理函数。道理虽简单,不知道的话却要吃大亏。
如果在这样的模型基础上,定义一套自定义标签集合,则能在Jsp中实现类似WebForm的功能。当然,我们的前提是不能改变现有jsp,Servlet容器的运行方式。
至此,我们还面临另外几个问题:在Jsp中实现类似WebForm中的服务器端控件、自动状态保持、数据绑定的功能,附带也可以实现类似ViewState的功能。虽然前面提出的页面控制器大大改善了传统jsp页面的组织方式,有了明显的生命周期函数,但如果没有服务器端控件、自动状态保持和数据绑定,则在实际的项目开发中我们还必须作大量繁重、重复的工作来实现类似的功能。
要想能够自动保持状态、进行数据绑定,前提是实现服务器端控件功能。我们首先会想到JSP中的自定义标记,实际也只有自定义标记才能实现类似服务器端控件的功能。
先说状态保持。例如,form中的text控件,用户更改了其value值,value在form被提交后会被送达服务器,但服务器如果重新将本页面送回客户端时,不将这个value值放在http文本流中的适当位置,那么,当客户端再次看到这个页面的时候,将看不到先前他所输入的值。也就是说,状态丢失了。而应用程序之所以成为应用程序,就要保持应用的状态,Web应用程序也不例外。
我们可以自定义标签来其自身来管理其自身的状态。当标签在执行其doStartTag或doEndTag时,应通过request对象获取其自身的值,并将这个值写回客户端。则这个标签就是一个可自动保持状态的标签。
WebForm的状态保持更进一步。如WebForm中的DataGrid控件,第一次加载页面的时候,我们从数据库中读取数据并绑定到DataGrid上,则页面传送到客户端,用户作些处理后重新请求服务器(再次请求本页面,连带DataGrid中的数据也会传送回服务器),服务器作完处理后需要将页面再次传回客户端,但此次我们不需要再次请求数据库了,DataGrid自动保持状态,因为它可以得到从客户端传回的自身的数据。但request对象仅能得到form控件的某些属性的值,而且是简单类型的值,DataGrid如何通过request得到从客户端传回的自身的值?!
总结:答案是用隐藏字段,绑定到DataGrid上的复杂数据(通常是个二维表)会被WebForm经过一些处理而赋给隐藏字段,隐藏字段的值当然会被request所得到,这样,DataGrid再将从隐藏字段得到的数据进行与刚才相反的逆向处理而被还原为DataGrid所能接受的数据。WebForm的ViewState功能同样是这样的办法实现的。