学习分享——location.hash的用法「建议收藏」

学习分享——location.hash的用法「建议收藏」【学习分享】location.hash的用法location对象:设置或获取当前URL的信息使用location对象可以设置或返回URL中的一些信息,一个完整的URL地址的格式为:协议://主机:端口

大家好,又见面了,我是你们的朋友全栈君。

学习分享】location.hash的用法

location对象:设置或获取当前URL的信息

使用location对象可以设置或返回URL中的一些信息,一个完整的URL地址的格式为:
协议://主机:端口/路径名称?搜索条件#hash标识
其中,协议是URL的起始部分,用于指定该URL地 址所采用的通信协议,比如http、ftp等;主机是指该URL所对应的服务器的名称;端口用于指定服务器用于通信的端口号,与主机名之间使用冒号隔开; 路径名称是指该URL所对应的网页文件在服务器上的虚拟路径;如果页面中含有锚点连接,可以使用hash标志指定页面中的锚点标志,该标志以“#”开头; 搜索条件是指URL中所含有的查询条件,该查询条件以“?”开头,以“变量名称=值”的形式出现,多个查询条件之间使用连接符“&”连接。比如http://www.webtest.com/help/index.php?act=detail2#h1

利用location对象可以方便地设置或获取URL中的各种信息,本节将详细介绍location对象的一些常用属性和方法。

 

1.hash属性
【功能说明】设置或获取URL中的锚点名称,如果Web页面中使用的锚点连接,通过设置location对象的hash属性可以方便的跳转到页面中的不同部分。
【基本语法】location.hash
下面的代码演示了如何在网页中使用location对象的hash标志快速定位页面中的 内容。
<html>
<head><title>home</title></head>
<body>
<a href=”#t1″>home</a>
<a href=”#t2″>contact</a>
<a href=”#t3″>about</a>
<a name=”t1″>………</a>
<a name=”t2″>………</a>
<a name=”t3″>………</a>
</body>
</html>

当点击home链接时页面会自动跳转到name=”t1″的位置,同理点击contact,about时页面会定位到name=”t2″或name=”t3″的位置。

 

2.hash属性在富Ajax页面中的应用
很多Web应用采用Ajax技术来增强Web体验,富Ajax应用具有如下优点:
1)减少对服务器端的连接并减轻服务器端的带宽压力,页面中的图片,脚本,样式只会被下载一次。
2)减少加载延迟,用户没有必要不断重新加载页面,所有的Ajax请为都发生在当前页面中。
当然使用Ajax技术也有很明显的缺陷。对于Ajax页面来说的话,一般用一个页面来处理所有的事务,也就是说,如果你浏览到一个Ajax页面里边有意思的内容,想将它收藏起来,可是地址只有一个呀,下次你打开这个地址,还是得像以往一样不断地去点击网页,找到你想要的那个页面。另外的话,浏览器上的“前进”“后退”按钮也会失效,这于很多习惯了传统页面的用户来说,是一个很大的使用障碍。
那么,怎么用location.hash来解决这两个问题呢?其实一点也不神秘。如下例中,通过hash调整地址栏的地址,使得浏览器里边的“前进”、“后退”按钮能正常使用(实质上欺骗了浏览器)。然后再根据hash值的不同来显示不同的内容,这就使得Ajax页面的浏览趋于传统化了。
——————————————————————————————————
hash.html
——————————————————————————————————
<html>
<head>
<title>location hash</title>
</head>
<body>
<!– Just a simple navigation —>
<ul id=”navigation”>
<li><a href=”index.html”>Home</a></li>
<li><a href=”about.html”>About</a></li>
<li><a href=”service.html”>Service</a></li>
<li><a href=”contact.html”>Contact</a></li>
</ul>
<div id=”content”></div>
<script type=”text/javascript” src=”http://www.google.com/jsapi”></script>
<script>
google.load(“jquery”,”1.3.2″,{uncompressed:true});
</script>
<script>
$(document).ready(function(){
     if(window.location.hash!=””){

        var hashpage = window.location.hash.split(“#”);

        $(“#navigation a”).each(function() {

              if($(this).attr(‘href’) == hashpage[1]) {
                   $(this).addClass(“curr”);
                   return false;
              }
         });
         $(“#content”).load(hashpage[1]);
     }
     //navigation
     $(“#navigation a”).unbind(“click”).click(function(){
        var page = $(this).attr(“href”);
        $(“#content”).load(page);
        window.location.hash=”#”+page;
        return false;
     });
});

</script>
</body>
</html>
——————————————————————————————————
about.html
——————————————————————————————————
<html>
<head>
<title>about</title>
</head>
<body>
<div id=”content”>
hi, my name is bill Zhan.
</div>
</body>
</html>
——————————————————————————————————
contact.html
——————————————————————————————————
<html>
<head>
<title>contact</title>
</head>
<body>
<div id=”content”>
tel:15986773928
</div>
</body>
</html>
——————————————————————————————————
home.html
——————————————————————————————————
<html>
<head>
<title>home</title>
</head>
<body>
<div id=”content”>
Welcome to the Harray Port World!
</div>
</body>
</html>
——————————————————————————————————
service.html
——————————————————————————————————
<html>
<head>
<title>service</title>
</head>
<body>
<div id=”content”>
Go,Go,Go.
</div>
</body>
</html>

——————————————————————————————————

 

3.利用hash技术解决以上提到的Ajax的两个缺陷比较成熟的应用举例
1)Gmail
Gmail可以说是把Ajax技术用到了极致,Google采用hash来解决Ajax技术的两大缺陷。

2)Greader
Google Reader同样采用hash来解决Ajax技术的两大缺陷。通过分析URL来异步加载页面元素。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154364.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c#/winform中InitializeComponent()函数的作用[通俗易懂]

    InitializeComponent()方法写在前面和后面是有区别的。InitializeComponent()方法是用来初始化窗体组件的,在InitializeComponent之前,窗体的各个控件还没有进行初始化,比如说窗体上有一个TextBoxUserName,在InitializeComponent之前它还只是一个TextBox类型的变量而已,如果在InitializeComponent之前调用这个TextBox的属性或方法,就会出错。再比如说你拖上取一个TextBox,它放在Form的位置,Te

    2022年4月14日
    70
  • VMM分类_nmm组合

    VMM分类_nmm组合VMM可以分为:完全虚拟化(基于硬件)、宿主虚拟化、混合虚拟化 (1).完全虚拟化VMM虚拟的是现实存在的平台,在客户及操作系统看来,虚拟的平台和现实的平台是一样的,客户机操作系统察觉不到市运行在一个虚拟平台上X86架构的完全虚拟化,经历了两个阶段:软件辅助的完全虚拟化Ringcompression   VMM运行在Ring0,客户及操作系统运行在V

    2022年9月22日
    5
  • attempted to return null from_unable to process jar entry

    attempted to return null from_unable to process jar entry**Springboot启动时报错Ifyouwantanembeddeddatabase(H2,HSQLorDerby),pleaseputitontheclasspath.**产生这个错误的原因是springboot的自动配置,如果你没有配置DataSource就会导致下图这个错误解决方案1@SpringBootApplication(exclude…

    2022年9月23日
    4
  • Loading class `com.mysql.jdbc.Driver’. This is deprecated警告处理,jdbc更新处

    Loading class `com.mysql.jdbc.Driver’. This is deprecated警告处理,jdbc更新处声明:使用JDK9、MYSQL8、idea  1.报错信息是这样的;处理:提示信息表明数据库驱动com.mysql.jdbc.Driver’已经被弃用了、应当使用新的驱动com.mysql.cj.jdbc.Driver’所以,按照提示更改jdbc.properties配置 .com.mysql.jdbc.Driver 改为 com.mysql.cj.jdbc.Driver…

    2022年6月23日
    39
  • 基于Auto.js的萌猫跳辅助

    基于Auto.js的萌猫跳辅助许久不见,甚是想念被学长唤醒的博客魂ing…这次是一个失去时效性的小脚本,但是其中包括一些东西或许对你们可以有帮助撒一些要点因为Auto.js并没有直接的对于触控位置的监听,所以需要对安卓API进行调用2.涉及对于画布的使用importClass(android.graphics.PorterDuffXfermode);importClass(android.graphics.PorterDuff);constBG_COLOR=colors.parseColor(“#2d

    2022年6月6日
    41
  • c++语言计算2的n次方,2的N次方

    c++语言计算2的n次方,2的N次方题目的链接为 http acm njupt edu cn acmhome problemdetai do amp method showdetail amp id 1009 题目为 2 的 N 次方时间限制 普通 Java 1000MS 3000MS 运行内存限制 65536KByte 总提交 999 测试通过 500 描述编程精确计算 2 的 N 次方 N 是介于 1

    2025年8月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号