怎样在Web开发中完美控制IE标题栏

来源:网络整理 责任编辑:栏目编辑 发表时间:2013-07-01 15:24 点击:
    IE以及任何目前浏览器的标题栏,原本都应该是由<title>这个HTML标签来控制的,当然现在仍然也是。只是目前的鬼趋势是,你最好不要再刷新你的网页页面了,然后还需要接受用户的任意蹂躏。这也就是传说中神龙见首不见尾,杀人于无影无形的悖时Ajax技术!
  
   在浏览器的标题栏中显示贴切的页面标题,是一个网页专业的表现,同时也能对搜索引擎友好。当然如果放上适当的提示信息,也会很有意义。那么怎么"动态"的来定制这个标题内容呢?
  
   我们知道使用ASP动态修改浏览器title,大概是这样的语句:
  
   <title><% = GenerateTitle %></title>
  
   而在ASP.NET 1.1中,除了仍可以使用上面的方法外,我们多了一个看起来"很美"的方法:
  
   In aspx page:
   <title id="cltTitle" runat="server"></title>
   In CS file:
   protected HtmlGeneralControl cltTitle;
   . . .
   cltTitle.innerHtml = "birdshome's homepage";
  
   今天到了ASP.NET 2.0时代,除了上面的两种方法,我们还可以更容易的修改<title>内容:
  
   Page.Title = "birdshome's homepage";
  
   不过上面的"动态"都是在服务器端修改<title>的内容,实际上对于浏览器来说<title>标签内的内容是完全固定的了。下面言归正传,仔细来说说在客户端对IE浏览器标题栏的控制:
  
   对于IE窗口中的页面,在页面DOM对象中,document.title属性是用来代替<title>元素的innerHTML获取和设置IE窗口标题栏内容的。请看下面这个示例:
  
  <html>
  <body>
   <!-- page content -->
   <script language="javascript">
   document.body.onload = function()
   {
   document.title = "birdshome's homepage";
   };
   </script>
  </body>
  </html>
  
   对,就是这么简单就可以设置好普通IE窗口的标题栏。那么这有什么好说的呢?这时候如果我们把完全相同的代码放入模态窗口中执行呢?模态窗口的标题栏是否会被修改?试验结果却是让人沮丧的,完全相同的这段代码,在模态窗口中就失灵了。难道模态窗口提供的DOM和普通窗口不同吗?其实模态窗口的DOM和普通窗口是相同的,而不同之处是当模态窗口中的页面装载完成后,document.title属性确实会失效。这就是为什么在上面的示例代码onload事件中的语句无效的原因。解决这个限制的方法很简单,就是要在页面还未装载完成时就修改document.title,所以在模态窗口中修改IE标题栏就因该使用这样的代码:
  
  <html>
  <body>
   <!-- page content -->
   <script language="javascript">
   document.title = "birdshome's homepage";
   </script>
  </body>
  </html>
  
   下面是一个包含了以上两种修改浏览器标题栏方法的示例,将其保存为"abc.htm"文件,使用IE打开你就能很直观看到区别:
  
  <html>
  <body>
   <button onclick="foo()">
   Open</button>
   <script language="javascript">
   document.body.onload = function()
   {
   document.title = "birdshome's homepage (rewrite)" + unescape(H_A0);
   };
  
   document.title = "birdshome's homepage (first)" + unescape(H_A0);
  
   function foo()
   {
   window.showModalDialog("abc.htm");
   }
   </script>
  </body>
  </html>
  
   结果是普通IE窗口的标题栏会从"birdshome's homepage (first)"快速的变为"birdshome's homepage (rewrite)",而使用Open按钮开启的模态对话框的标题将一直是"birdshome's homepage (first)"。从这个示例中我们可以看出来,对于普通IE窗口,其标题栏是可以在页面生存期的任
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • 浅析.NET下XML数据访问新机制
    • asp.net 面试+笔试题目第1/2页
    • C# 邮件地址是否合法的验证
    • asp.net 设置GridView的选中行的实现代码
    • C#高级编程:数据库连接[1]
    • 经典C++程序1
    • IIS 自动回收导致后台定时器失效的问题解决
    • ASP.NET&#160;GridView列表代码示例
    • Asp.net MVC源码分析--Action Filter的链式调用
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1