谈谈ASP.NET中的“地址决定内容”问题
什么是地址决定内容?
你在网上逛,看到一个有趣的页面,于是你把地址栏里的内容复制下来,发给正在跟你聊天的网友:“看看这个页面,有趣极了”,你的朋友打开你发的链接,看到的内容应该和你正在看的一样。也即,页面的主要内容应当取决于地址栏中的地址。但在ASP.NET中,由于其独特的WebForm模型,可能会使得开发人员忽略了这重要的一点。
比如某在线小说网站的小说阅读界面是这样的:
页面分为二块,左块是目录列表,右块为正文,点击目录里的章节链接,右块里就显示对应章节的正文内容。
思路一:目录块和正文块都用GridView来做,GridView1绑定到目录表,用LinkButton显示章节标题,点击LinkButton后,在相关的事件处理函数里会查询对应的正文表,并绑定到GridView2上。
这个思路貌似OK,但是:无论你看的是哪一章节,地址栏里的地址都是不变的!这意味着,你无法把单独的一章的地址和别人分享,也不能把看到一半的章节添加到收藏夹里。在这个方案中,页面的主要内容——章节正文,与页面地址没有对应关系,所有章节都对应于同一地址。
改进:用url查询字符串标识章节,类似于xxx.aspx?chapter=1&……的形式,后台从查询参数获得章节号。所以GridView1里不用LinkButton,而改用HyperLink;并在Page_Load中取得查询串,查表,绑定GridView2。
总结:一个页面的“主要内容”一般对应于数据库中的某条记录,为了“地址决定内容”,可能需要把“键”放到地址中。
补充:在改进后的方案中,由于GridView2不在回传时绑定,所以可关闭其ViewState,以缩减生成的html页。