TonyWang的专栏

力争成为最优秀的.NET程序员

ASP.NET2.0MasterPage使用技巧总结

来源: 博客园  作者: 漂泊雪狼的博客

    好久没有更新博客了,想了想写一篇总结一下关于MasterPage的小技巧,都是自己在实际工作中遇到问题->解决问题发现,有更好的方法大家可直接指出。
    1、关于MasterPage和Frameset的使用:网上很多帖子争论到底用MasterPage还是Frameset,我觉得导航树的系统还是Frameset好,尤其数导航树非常复杂的时候,虽然VS.NET 2005不支持它的可视化设计,自己手写html就行了,其实MasterPage就是继承自UserControl做了一些扩展,也不是什么新东西,MasterPage每次刷新整个页面,感觉效率低。
   2、关于MasterPage中引用Javascript,CSS的问题:如果所有套用模板的页面都在同一个路径,这个问题就不存在了,但实际中为了方便管理,往往会建立一些文件夹,将引用模板的页面放在不同的文件加,这时在模板中引用的JS、CSS文件,由于路径的问题,在套用它的页面中不一定能用有用,可以用一下的方法在masterpage中来动态的添加JS、CSS文件的引用:
    方法一:
   

string JSFile = "<script language=/"javascript/" src=/"{0}/" type=/"text/javascript/"></script>";
Response.Write(
string.Format(JSFile,ResolveUrl("~/Javascript/jquery.js")));


这种方法虽然可以快速解决问题,但是Response.Write是将脚本的引用写到html的最开始,这就破坏了xhtml的格式,会带来各种存在的隐患,记得过去这么做的时候,同时在用asp.net ajax做开发的时候,发现ASP.NET AJAX AjaxControlToolkit中很多的控件不起作用了,后来发现是用了Response.Write的结果。
方法二:
 

string JSFile = "<script language=/"javascript/" src=/"{0}/" type=/"text/javascript/"></script>";
 Page.Header.InnerHtml 
= string.Format(JSFile,ResolveUrl("~/Javascript/jquery.js"));


 这种方法也可以实现而且可以很好的解决方法中的问题。
方法三: 

 HtmlLink link = new HtmlLink();
 link.Href 
=  string.Format(JSFile,ResolveUrl("~/CSS/base.css"));;
 link.Attributes[
"rel"= "stylesheet";
 link.Attributes[
"type"= "text/css";
 page.Header.Controls.Add(link);


 这是注册样式的一种方法。

 

阅读更多
上一篇.NET中Cache的使用
下一篇多线程、Socket技术及委托技术的关系
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭