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

2016-02-19 16:08 6 1 收藏

在这个颜值当道,屌丝闪边的时代,拼不过颜值拼内涵,只有知识丰富才能提升一个人的内在气质和修养,所谓人丑就要多学习,今天图老师给大家分享怎样在Web开发中完美控制IE标题栏,希望可以对大家能有小小的帮助。

【 tulaoshi.com - Web开发 】

  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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

      结果是普通IE窗口的标题栏会从"birdshome's homepage (first)"快速的变为"birdshome's homepage (rewrite)",而使用Open按钮开启的模态对话框的标题将一直是"birdshome's homepage (first)"。从这个示例中我们可以看出来,对于普通IE窗口,其标题栏是可以在页面生存期的任意时刻进行修改的。而模态窗口的标题栏,我们只能在其页面装载完成前(onload事件触发前)才能修改。非模态对话框,opend by showModelessDialog,对于标题栏的处理和模态对话框完全一样。

      最后再说一个document.title使用中的技巧,我们知道如果在服务器端"动态"修改页面title时,我们可以向title/title标签间写入&nbps;来在标题栏上产生连续的空格输入效果。这个技巧在模态窗口中尤为有用,这样一来我们就可以把那讨厌的" - Web Page Dialog"字样用连续空格推到标题栏外去。使用document.title属性来修改页面标题栏后,不管是普通窗口还是模态窗口," "和" "(空格)都不能用了,前者会被直接当字符串显示在标题栏上,后者添加再多也只有一个" "(空格)的宽度效果。这里我们又要使用另一个空格,实体 来解决这个问题。代码如下:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

  html
  body
      script language="javascript"
      var HexA0s = "%A0 %A0 %A0 %A0";
     
      document.body.onload = function()
      {
          document.title = "birdshome's homepage (rewrite)" + unescape(HexA0s);
      };
      /script
  /body
  /html

  http://birdshome.cnblogs.com/archive/2006/06/23/control_browser_title.html

来源:https://www.tulaoshi.com/n/20160219/1611134.html

延伸阅读
一、隐藏标题栏 代码如下:         //隐藏标题栏        this.requestWindowFeature(Window.FEATURE_NO_TITLE); 二、隐藏状态栏 代码如下:         //隐藏状态栏        this.getWindow()....
  1.添加引用:DBClient 2.置DBGridEh控件属性:   设置dghAutoSortMarking属性为true  设置希望排序的Column的TitleButton属性为true 3.//表格排序过程 procedure OrderGrid(dataSet:TClientDataset;orderField:string); var   i:integer; begin   if dataSet.IndexFieldNames'' then ...
很多人都在问怎么更改java应用程序标题栏默认图标,如果你用过Toolkit类,这将是一件很简单的事情: Toolkit tk=Toolkit.getDefaultToolkit() Image image=tk.createImage("image.gif"); /*image.gif是你的图标*/ this.setIconImage(image); 就这么简单,看看,已经变成你自己的图标了。Toolkit是个很有用类...
在VB中可以通过设置Form的属性,制作无系统标题栏的窗口。可是,由于失去了系统标题栏,如何使用鼠标拖动窗口便成了一个棘手的问题。其实,借助API函数ReleaseCapture和SendMessage,这个问题便可迎刃而解了。 首先,在module文件中加入下列声明语句: Declare Sub ReleaseCapture Lib"User"() Declare Func...
标签: windows 操作系统
用过Windows XP系统的用户都知道,Windows XP有专用的窗口主题,很具特色。可是,Windows XP样式的窗口主题在默认的情况下,其标题栏都比较宽,尤其是显示器的分辨率为800×600的时候,用IE浏览器或资源管理器时,其占用的空间让网页和文件显示的空间变少了。有些用户为了让标题栏变窄一些,甚至放弃Windows XP的样式,而转用Windows经典模...

经验教程

133

收藏

5
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部