BOM中的那点事-location

      现在来了解一下JavaScript中的location对象。location记录了页面文档的位置信息,当然这个位置不是地址位置,而是指web中的文档位置。location其实是一个很特殊的对象,首先它是window的属性,同时也是document的属性,换句话说window.location和document.location引用的同一个对象。location的有用之处不仅仅是它记录文档信息,同时它还将文档的URL解析为不同的部分,编程时可以通过不同的属性方便地引用各个部分,下表列出来location中URL的各个部分:

 属性名称 示    例 描       述
 hash #test 返回URL中的hash值,#号后跟数字,如果URL中没有哈希值返回空字符串
 host www.test.com:80 返回服务器名称和端口号
 hostname www.test.com 返回不含端口号的服务器名称
 href http://www.test.com 返回加载文档的完整URL地址,location的toString函数返回该值
 pathname /admin/login.html 返回URL中除server名称和端口的目录和文件名称
 port 80 服务器端口
 protocol http 加载的文档URL所使用的协议
 search ?q=javascript 返回查询字符串

虽然通过location可以轻易访问到查询字符串,但是想获取查询字符串中的参数就没有这么方便,可以通过如下函数来分离各个参数的名称和值:

 1 function getQueryStringArgs() {
 2     //获取查询字符串,通过substring去掉最前面的问号
 3     var qs = (location.search.length > 0) ? location.search.substring(1) : "";
 4     //创建保存查询参数的对象
 5     var args = {};
 6     //获取参数每一项
 7     var argItems = qs.split('&');
 8     var item = null, name = null, value = null;
 9     //遍历每个项目,通过=号分隔参数名称和值
10     for (var i = 0; i < argItems.length; i++) {
11         item = argItems[i].split('=');
12         name = decodeURIComponent(item[0]);
13         value = decodeURIComponent(item[1]);
14         args[name] = value;
15     }
16 
17     return args;
18 }

通过location我们可以改变加载的文档。首先,也是最常用的方法就是使用assign,通过assign使窗体加载新指定的URL:

1 window.location.assign(http://www.google.com);

通过调用assign可以立即加载指定的URL,并且咋浏览器历史记录中增加一条,当然如果我们设置location.href属性的值或者直接设置location对象为一个URL,效果等同于调用assign一样,立即打开新的URL:

1 window.location = "http://www.google.com";
2 window.location.href = http://www.google.com;

href的方式似乎是我们最常用的了。另外修改location中其他的属性也会改变加载的页面,使浏览器重新加载页面,如下代码:

1 window.location = "http://www.test.com";
2 //修改hash
3 location.hash = "#section";
4 //修改查询字符串
5 location.search = "?q=javascript";
6 //修改服务器名称
7 location.hostname = "www.google.com";
8 //修改pathname
9 location.pathname = "test";

当然通过上面的方法加载新的URL时会为浏览器历史记录增加一条,那么点击向后的时候会退回的前一个地址,如果我们不想记录浏览历史,可以通过replace函数来实现该功能:

1 window.location.replace(http://www.cnblogs.com);

location还有一个有用的函数reload,通过reload可以从新加载文档,但是首先会检查缓存区是否有该地址的文档,如果有从缓存区加载,否则从服务器加载,但是可以通过参数来取消这一策略:

1 //从新加载,有可能从缓存加载
2 window.location.reload();
3 //从新加载,直接从服务器加载
4 window.location.reload(true);

location是一个非常有用的对象,在编程时经常会用到,在此仅当抛砖引玉。如果有其他值得注意的或者有错误欢迎指正。

 

有园友反应需要说明BOM和DOM,由于本文章不是介绍BOM和DOM,因此把相关链接贴出来,大家可以阅读:

关于JavaScript组成:http://javascript.about.com/od/browserobjectmodel/a/bom01.htm

关于BOM:http://msdn.microsoft.com/en-us/library/ms952643.aspx

也可以看:http://titan.iteye.com/blog/60389

关于DOM请看:http://en.wikipedia.org/wiki/Document_Object_Model

和:http://www.w3.org/DOM/

转载于:https://www.cnblogs.com/gyycyy/archive/2012/08/08/locationInBOM.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/403800.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python多线程编程(7):线程间通信

From: http://www.cnblogs.com/holbrook/archive/2012/03/21/2409031.html 很多时候&#xff0c;线程之间会有互相通信的需要。常见的情形是次要线程为主要线程执行特定的任务&#xff0c;在执行过程中需要不断报告执行的进度情况。前面的条件变量同步已经涉及到了线程间的通…

vue本地下载文件,解决ie浏览器本地下载文件无反应(已解决);vue-cli2本地下载文件,vue-cli3本地下载文件

1.vue-cli2vue 注意&#xff1a;vue-cli2本地文件需要放在静态文件static下<a href"javascript:void(0);" click"download">帮助文档</a>download(){axios.get(static/export.pdf, {responseType: blob, //重要}).then(response > {//判断…

CSS position 笔记+实验

目录&#xff1a;1.static2.relative3.absolute4.fixed5.实验&#xff1a;static, relative, absolute中&#xff0c;父元素-子元素高度关系6.z-index7.参考资料1.static默认的定位方式&#xff0c;不支持设置位移属性用来覆盖之前创建的 absolute, relative, fixed 2.relative…

Linux 查找指定文件并删除

find . -name *.png | xargs rm -fr

python多线程编程(8):线程的合并和后台线程

From: http://www.cnblogs.com/holbrook/archive/2012/03/21/2410120.html 线程的合并 python的Thread类中还提供了join()方法&#xff0c;使得一个线程可以等待另一个线程执行结束后再继续运行。这个方法还可以设定一个timeout参数&#xff0c;避免无休止的等待。因为两个线…

修改ant design vue中的Icon图标颜色

直接行内式即可 <a-icon type"file-text" style"color: rgba(28, 106, 235, 1)" />

学习进度条10

学习进度条 第 十一 周 星期一 星期二 星 期 三 星期四 星期五 星期六 所花时间 90 100 50 42 代码量 0 120 博客量 1 1 1 了解到的知识点 初次了解到典型用户和场景 进行对自己模块设定典型用例 复习了…

批量同时创建邮箱和AD账户

前面我写了关于批量创建AD账户的BLOG,http://mcmvp.blog.51cto.com/5497438/959289也写了用UI批量启用邮件的方法&#xff0c;http://mcmvp.blog.51cto.com/5497438/959314但是这还是要执行两步&#xff0c;我们能不能只要执行一下&#xff0c;AD账户建立成功&#xff0c;邮箱跟…

I/O多路转换 select

Linux驱动部分我们曾经使用了poll机制完成了在应用层代码读取按键值。这节课介绍的select也很相似。当我们要监控好几个文件描述符的读写呢&#xff1f;如果我们阻塞的去处理其中一个&#xff0c;那第二个怎么办呢&#xff1f;下面我们一起想想办法。 方法一&#xff1a;使用fo…

Python使用select实现异步通信

From: http://www.linuxidc.com/Linux/2014-02/97152.htm 当一个服务器需要与多个客户端进行通信时&#xff0c;可以使用多进程或者多线程的服务器&#xff0c;也可以使用select模块&#xff0c;它可以实现异步通信。Python中的select模块包含了poll()和select(),select的原型…

ant design vue中通知提醒框Notification的使用

效果&#xff1a;点击接口&#xff0c;出现提示弹框&#xff0c;数据获取到后在消失 <template><a-button type"primary" click"openNotification">Open the notification box</a-button> </template> <script> const clo…

Cocos2d-3.x目录介绍分析

一、下载cocos2d的框架 1.下载地址&#xff1a;http://www.cocos2d-x.org/download/version#Cocos2d-x 我们还是选择v3.11吧 比较新的框架 2.下载之后解压这个文件夹就可以了 cocos2d-x-3.11.zip这使我们下载的文件 解压之后&#xff1a; 3. 文件夹目录如图 接下来我们逐步来介…

Mongodb Replica Configure

Mongodb Replica Configure我在配置replica的时候&#xff0c;文档中也把官网的中一些重要解释放在里面了但是并没有用中文做必要的解释&#xff0c;不过都是很容易理解的。说一下环境&#xff0c;这里的环境是&#xff1a;system:centos 64bit 生产环境不用说&#xff0c;直接…

网络IPC非阻塞和异步I/O

通常&#xff0c;recv函数没有数据可用时会阻塞等待。同样地。当套接字输出队列没有祖公空间用来发送消息时&#xff0c;函数send会阻塞。在套接字非阻塞模式下&#xff0c;行为会改变。这种情况下&#xff0c;这些函数不会阻塞而失败&#xff0c;设置errno为EWOULDBLOCK或者EA…

Python网络编程中的select 和 poll I/O复用的简单使用

From: http://www.cnblogs.com/coser/archive/2012/01/06/2315216.html 首先列一下&#xff0c;sellect、poll、epoll三者的区别 select select最早于1983年出现在4.2BSD中&#xff0c;它通过一个select()系统调用来监视多个文件描述符的数组&#xff0c;当select()返回后&…

深拷贝与浅拷贝Object.assign()

深拷贝与浅拷贝 Object.assign()会身拷贝一个复杂类型 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title…

TableView的优化

一&#xff1a;什么是TableView的优化以及为什么要优化 1&#xff09;CPU&#xff08;中央处理器&#xff09;和GPU&#xff08;图形处理器&#xff09;&#xff1a;CPU主要从事逻辑计算的一些工作&#xff1b;GPU主要从事图形处理方面的工作。 2&#xff09;CPU和GPU的共同点&…

Python---静态Web服务器-面向对象开发

1. 以面向对象的方式开发静态Web服务器 实现步骤: 把提供服务的Web服务器抽象成一个类(HTTPWebServer)提供Web服务器的初始化方法&#xff0c;在初始化方法里面创建socket对象提供一个开启Web服务器的方法&#xff0c;让Web服务器处理客户端请求操作。 2. 静态Web服务器-面向…

Androidの网络Http之判断是否连接服务器

1.采用Http方式&#xff1a; public boolean isConnByHttp(){boolean isConn false;URL url;HttpURLConnection conn null;try {url new URL("ttp://wl.daishu001.com/YHDriver.asmx");conn (HttpURLConnection)url.openConnection();conn.setConnectTimeout(100…