关闭

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

500人阅读 评论(0) 收藏 举报

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

    好久没有更新博客了,想了想写一篇总结一下关于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);


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

 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:694506次
    • 积分:8143
    • 等级:
    • 排名:第2566名
    • 原创:3篇
    • 转载:584篇
    • 译文:0篇
    • 评论:129条
    最新评论