网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.最简单的asp.net分页 .
.ASP.NET 崩溃-SiteMap中疯狂的循.
.ASP.net组件编程中的两种事件编写.
.ASP.NET MasterPage 中图片路径的.
.提高ASP.Net应用程序性能的十大方.
.在ASP.NET 2.0中使用RDLC格式的报.
.ASP.NET 2.0中的Web和HTML服务器.
.用.net开发不同操作系统下应用的.
.用asp.net还原与恢复sqlserver数.
.动态改变asp.net网页的标题.
.结合JavaScript与ASP.NET Web窗体.
.在 ExcuteReader 中使用输出参数.
.在Asp.net的HttpCookie中写入汉字.
.梅花雨的日历控件在ASP.NET2.0下.
.解决网址参数获取乱码问题.
.ASP.NET页面的处理过程完全版.
.ASP.NET2.0服务器控件之捕获回传.
.asp.net连接Access数据库.
.asp.net中对数据库表插入null空值.
.设置页面buffer引出来的问题 .

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

发表日期:2006-6-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窗口,其标题栏是可以在页面生存期的任意时刻进行修改的。而模态窗口的标题栏,我们只能在其页面装载完成前(onload事件触发前)才能修改。非模态对话框,opend by showModelessDialog,对于标题栏的处理和模态对话框完全一样。

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

<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

上一篇:关闭按钮点击事件的捕捉 人气:7246
下一篇:ASP.Net2.0中自定义控件在page中的注册 人气:6568
浏览全部Ajax的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐