js中的 window.location、document.location、document.URL 对像的区别(转载)

原文:http://www.cr173.com/html/18417_1.html

当我们需要对html网页进行转向的时候或是读取当前网页的时候可以用到下面三个对像:

window.locationdocument.locationdocument.URL 对当前网页进行跳转

我们先来看看 document 与 window对象:

[window 对象] 
  它是一个顶层对象,而不是另一个对象的属性即浏览器的窗口。

[document 对象] 
该对象是window和frames对象的一个属性,是显示于窗口或框架内的一个文档。

document 只是属于window 的一个子对像。

window.location 包含 href 属性,直接取值赋值时相当于 window.location.href。
window.location.href  当前页面完整 URL。
document.location 包含 href 属性,直接取值赋值时相当于 document.location.href。
document.location.href 当前页面完整 URL。
document.href 没有这个属性。
document.URL 取值时等价于 window.location.href 或 document.location.href。在某些浏览器中通过对 document.URL 赋值来实现页面跳转,但某些浏览器中不行。
那么 window.location 和 document.location 有什么区别呢?我认为是没有区别的,我已经在多个浏览器中不同页面(包括 iframe、frame)中测试了。有人说一个可写,一个只读,这一点也在我的测试中被否定了。同样在 MSDN 中说 location 应用于 window 和 document,但并未提出二者有区别。所以我认为二者是没有区别的。

[document对象] 

  该对象是window和frames对象的一个属性,是显示于窗口或框架内的一个文档。 
  属性 
  alinkColor 活动链接的颜色(ALINK) 
  anchor 一个HTMI锚点,使用<A NAME=>标记创建(该属性本身也是一个对象) 
  anchors array 列出文档锚点对象的数组(<A NAME=>)(该属性本身也是一个对象) 
  bgColor 文档的背景颜色(BGCOLOR) 
  cookie 存储于cookie.txt文件内的一段信息,它是该文档对象的一个属性 
  fgColor 文档的文本颜色(<BODY>标记里的TEXT特性) 
  form 文档中的一个窗体(<FORM>)(该属性本身也是一个对象) 
  forms anay 按照其出现在文档中的顺序列出窗体对象的一个数组(该属性本身也是一个对象) 
  lastModified 文档最后的修改日期 
  linkColor 文档的链接的颜色,即<BODY>标记中的LINK特性(链接到用户没有观察到的文档) 
  link 文档中的一个<A HREF=>标记(该属性本身也是一个对象) 
  links array 文档中link对象的一个数组,按照它们出现在文档中的顺序排列(该属性本身也是一个对象) 
  location 当前显示文档的URL。用户不能改变document.location(因为这是当前显示文档的位置)。但是, 
可以改变 window.location (用其它文档取代当前文档)window.location本身也是一个对象,而 
document.location不是对象 
  referrer 包含链接的文档的URL,用户单击该链接可到达当前文档 
  title 文档的标题((TITLE>) 
  vlinkColor 指向用户已观察过的文档的链接文本颜色,即<BODY>标记的VLINK特性 
  方法 
  clear 清除指定文档的内容 
  close 关闭文档流 
  open 打开文档流 
  write 把文本写入文档 
  writeln 把文本写入文档,并以换行符结尾

[window对象] 
  它是一个顶层对象,而不是另一个对象的属性即浏览器的窗口。 
  属性 
  defaultStatus 缺省的状态条消息 
  document 当前显示的文档(该属性本身也是一个对象) 
  frame 窗口里的一个框架((FRAME>)(该属性本身也是一个对象) 
  frames array 列举窗口的框架对象的数组,按照这些对象在文档中出现的顺序列出(该属性本身也是一个 
对象) 
  history 窗口的历史列表(该属性本身也是一个对象) 
  length 窗口内的框架数 
  location 窗口所显示文档的完整(绝对)URL(该属性本身也是一个对象)不要把它与如document.location 
混淆,后者是当前显示文档的URL。用户可以改变window.location(用另一个文档取代当前文档),但却不能改变 
document.location (因为这是当前显示文档的位置) 
  name 窗口打开时,赋予该窗口的名字 
  opener 代表使用window.open打开当前窗口的脚本所在的窗口(这是Netscape Navigator 3.0beta 3所引 
入的一个新属性) 
  parent 包含当前框架的窗口的同义词。frame和window对象的一个属性 
  self 当前窗口或框架的同义词 
  status 状态条中的消息 
  top 包含当前框架的最顶层浏览器窗口的同义词 
  window 当前窗口或框架的同义词,与self相同 
  方法 
  alert() 打开一个Alert消息框 
  clearTimeout() 用来终止setTimeout方法的工作 
  close() 关闭窗口 
  confirm() 打开一个Confirm消息框,用户可以选择OK或Cancel,如果用户单击OK,该方法返回true,单击 
Cancel返回false 
  blur() 把焦点从指定窗口移开(这是Netscape Navigator 3.0 beta 3引入的新方法) 
  focus() 把指定的窗口带到前台(另一个新方法) 
  open() 打开一个新窗口 
  prompt() 打开一个Prompt对话框,用户可向该框键入文本,并把键入的文本返回到脚本 
  setTimeout() 等待一段指定的毫秒数时间,然后运行指令事件处理程序事件处理程序 
  Onload() 页面载入时触发 
  Onunload() 页面关闭时触发
区别:用户不能改变document.location(因为这是当前显示文档的位置)。但是,可以改变window.location (用其它文档取代当前文档)window.location本身也是一个对象,而document.location不是对象

时间: 2024-07-28 21:55:03

js中的 window.location、document.location、document.URL 对像的区别(转载)的相关文章

springMVC框架在js中使用window.location.href请求url时IE不兼容问题解决

是使用springMVC框架时,有时候需要在js中使用window.location.href来请求url,比如下面的路径: window.location.href = 'forecast/download.do' 在谷歌浏览器下,实际请求的路径是:项目名/forecast/download.do 而在IE下访问时在中间多了好几层文件夹: 造成这种情况的原因是各种浏览器在使用window.localtion.href请求相对路径时处理方法不同 IE是从当前当前路径开始跳转 谷歌是从根目录开始跳

转载:Js中的window.parent ,window.top,window.self 详解

原文地址  <Js中的window.parent ,window.top,window.self 详解> 在应用有frameset或者iframe的页面时, parent是父窗口,top是最顶级父窗口(有的窗口中套了好几层frameset或者iframe),self是当前窗口, opener是用open方法打开当前窗口的那个窗口. window.self 功能:是对当前窗口自身的引用.它和window属性是等价的. 语法:window.self 注:window.self.window.sel

js中的window.open返回object的错误

系统中用javascript中的window.open后,页面返回了一个[object].因为系统的原因,必需使用href="javascript:window.open()"这样的格式.所以只能通过以下办法解决. 解决window.open后返回object的错误 <a href="javascript:void(window.open('','','width=200,height=200'))">window.open()</a> 只在

JS中innerHTML、outerHTML、innerText 、outerText、value的区别与联系? jQuery中的text()、html()和val()

一.JS中innerHTML.outerHTML.innerText .outerText.value的区别与联系?jS中设置或者获取所选内容的值:①innerHTML :属性设置或返回该标签内的HTML.也就是从对象的起始位置到终止位置的全部内容,包括Html标签.②outerHTML:属性设置或返回该标签及标签内的HTML.也就是从对象的该标签起始到终止位置的全部内容,包括Html标签.如果要输出不含HTML标签的内容,可以使用innerHTML取得包含HTML标签的内容后,再用正则表达式去

JS中innerHTML、outerHTML、innerText 、outerText、value的区别与联系?jQuery中的text()、html()和val() ?

作者赵晓盼课程任务一:零基础JavaScript编码(一)2809次浏览70赞2017-03-02 10:49 一.JS中innerHTML.outerHTML.innerText .outerText.value的区别与联系?jS中设置或者获取所选内容的值:①innerHTML :属性设置或返回该标签内的HTML.也就是从对象的起始位置到终止位置的全部内容,包括Html标签.②outerHTML:属性设置或返回该标签及标签内的HTML.也就是从对象的该标签起始到终止位置的全部内容,包括Html

JS中基本window.document对象操作以及常用事件!

一.找到元素 1.document.getELementById("id"):根据id找,最多找一个. var a=document.getELementById("id"):把找到的元素放在变量a中. 2.getElementsByClassName()根据class找,找出来的是数组. 3.getElementsByName()根据name找,找出来的是数组. 4.getElementsByTagName()根据标签名找,找出来的是数组. 二.操作内容 1.非表

js中的window对象:打开窗口

~~ window.open():打开一个窗口 里面需要放三个参数: 1.打开窗口(网页)的位置: 2.打开的方式(自身页面,新开页面): 其中_blank新开一个窗口 3.打开网页的属性: window.open("http://www.baidu.com","_blank","width=500 height=500") window.close():关闭一个窗口 window.opener.close:关闭打开的窗口(关闭源窗口) ~~ 间

JS中innerHTML、outerHTML、innerText 、outerText、value的区别与联系?

jS中设置或者获取所选内容的值: ①innerHTML :属性设置或返回该标签内的HTML.也就是从对象的起始位置到终止位置的全部内容,包括Html标签. ②outerHTML:属性设置或返回该标签及标签内的HTML.也就是从对象的该标签起始到终止位置的全部内容,包括Html标签. 如果要输出不含HTML标签的内容,可以使用innerHTML取得包含HTML标签的内容后,再用正则表达式去除HTML标签, ③inneText:从起始位置到终止位置的内容,但它去除html标签.(只能在IE和chro

【微信小程序】在js中导入第三方js或自己写的js,使用外部js中的function的两种方法 import和require的区别使用方法

如下 定义了一个外部js文件,其中有一个function import lunaCommon from '../lunaCommon.js'; var ctx = wx.getStorageSync("ctx"); var filter = "/ms-code"; var apis = { //根据sc获取发货单 "findDispatchBill": function (data, success) { var url = ctx + filt