javascript入门之window对象【新手必看】

window :window对象是BOM中所有对象的核心,除了是BOM中所有对象的父对象外,还包含一些窗口控制函数

1、全局的window对象

JavaScript中的任何一个全局函数或变量都是window的属性

rush:js;">   window、self、window.self三者是等价的。

3、window的子对象

 window的主对象主要有如下几个:

JavaScript document 对象 JavaScript frames 对象 JavaScript history 对象 JavaScript location 对象 JavaScript navigator 对象 JavaScript screen 对象

4、window函数索引(仅对IE有效)

  窗体控制函数

JavaScript moveBy() 函数:从当前位置水平移动窗体x个像素,垂直移动窗体y个像素,x为负数,将向左移动窗体,y为负数,将向上移动窗体。

JavaScript moveto() 函数:移动窗体左上角到相对于屏幕左上角的(x,y)点,当使用负数做为参数时会把窗体移出屏幕的可视区域。

JavaScript resizeBy() 函数:相对窗体当前的大小,宽度调整w个像素,高度调整h个像素。如果参数为负值,将缩小窗体,反之扩大窗体。

JavaScript resizeto() 函数:把窗体宽度调整为w个像素,高度调整为h个像素。

rush:js;">

 窗体滚动轴控制函数

JavaScript scrollTo() 函数:在窗体中如果有滚动条,将横向滚动条移动到相对于窗体宽度为x个像素的位置,将纵向滚动条移动到相对于窗体高度为y个像素的位置。

JavaScript scrollBy() 函数:如果有滚动条,将横向滚动条移动到相对于当前横向滚动条的x个像素的位置(就是向左移动x像素),将纵向滚动条移动到相对于当前纵向滚动条高度为y个像素的位置(就是向下移动y像素)。

注意区别,一个是相对当前窗口,一个是相当现在滚动条的位置。

rush:js;">
  //相当于设置绝对位置   //相当于累加

窗体焦点控制函数

JavaScript focus() 函数:使窗体或空间获得焦点

JavaScript blur() 函数:使窗体或控件失去焦点

rush:js;">

 新建窗体函数

JavaScript open() 函数:打开(弹出)一个新的窗体 JavaScript close() 函数关闭窗体 JavaScript opener 属性:通过opener可以实现跨窗体之间的通讯,但是要保证是在同一域名下,而且一个窗体要包含另一个窗体的opener。

 window.open(url,name,features,replace);

函数参数说明:

url -- 要载入窗体的URL; name -- 新建窗体的名称(也可以是HTML target属性的取值,目标); features -- 代表窗体特性的字符串,字符串中每个特性使用逗号分隔; replace -- 一个布尔值,说明新载入的页面是否替换当前载入的页面,此参数通常不用指定。

方法示例:

rush:js;">

  首先使用普通HTML链接打开一个页面(target名为dreamdu),之后使用open函数打开另一个页面,浏览器首先要查找是否有名称为dreamdu的窗体,如果有,就在这个窗体中加载open的地址。

  经过设置的open

rush:js;"> window.open ('page.html','newwindow','height=100,width=400,top=0,left=0,toolbar=no,menubar=no,scrollbars=no,resizable=no,location=no,status=no')

  弹窗方法:

方法一:页面时弹出窗口;

方法二:页面时弹出窗口;

  open函数第三个参数features说明:

函数features参数说明"> 参数名称显示地址栏,认值为no默认值为no默认值为no显示工具栏,认值为no显示状态栏,认值为no

  特性字符串中的每个特性使用逗号分隔,每个特性之间不允许有空格。

  window.open函数新建立窗体后会返回新建窗体的window对象,通过此对象可以控制窗体(移动,改变大小,关闭)。

  close函数

rush:js;">

  self.close();配合上setTimeout()可以实现,打开的窗口定时关闭效果

  对话框函数

JavaScript alert() 函数:弹出消息对话框(对话框中有一个OK按钮) JavaScript confirm() 函数:弹出消息对话框(对话框中包含一个OK按钮与Cancel按钮) JavaScript prompt() 函数:弹出消息对话框(对话框中包含一个OK按钮、Cancel按钮与一个文本输入框)   alert();

  不说。

  confirm(str);

  confirm()消息对话框是排它的,也就是在用户点击对话框的按钮前,不能进行任何其它操作。

rush:js;"> if(confirm("确定跳大?")) { alert("果断跳大"); } else { alert("猥琐打钱"); }

 显示如下:

prompt(str1,str2);

  函数有两个参数

str1 -- 要显示在消息对话框中的文本,不可修改 str2 -- 文本框中的内容,可以修改

rush:js;"> var sResult=prompt("请在下面输入你的姓名","撼地神牛"); if(sResult!=null) { alert(sResult + "已经超越神的杀戮"); } else { alert("无名氏已经超越神的杀戮"); }

 显示如下:

 时间等待与间隔函数

JavaScript setTimeout() 函数 JavaScript clearTimeout() 函数 JavaScript setInterval() 函数 JavaScript clearInterval() 函数

  

1、setTimeout()、clearTimeout()  在指定的时间后调用函数

  语法:

setTimeout(fun,time);  fun:函数体或函数名,time指定时间,单位为毫秒。 clearTimeout(id);  取消指定的setTimeout函数将要执行的代码

rush:js;"> setTimeout(function () { document.write("隔3秒后触发"); },3000) //在3秒后输出

setTimeout(fun1,5000); //在5秒后输出
function fun1() {
document.write("函数名的方式5秒后触发");
}

 

2、setInterval()、clearInterval(value)  在间隔指定的事件后重复调用函数

  语法:

setInterval(fun1,time)  fun:函数体或函数名,time指定的时间,单位为毫秒。会返回一个值,这个值是统计函数的个数用的,第一个是1,第二个就是2,指明是第几个setInterval函数。 clearInterval(value)    value:setInterval()函数返回的值,根据这个值可以停止setInterval()的重复。 

rush:js;"> var i = 0; var h = setInterval(function () { document.write("3秒输出一次
"); i++; if (i >= 3) { clearInterval(h); document.write("停止输出"); } },3000);

 注意,javascript是单线程的,因此,这个定时函数实际上是通过插入执行队列的方式来实现。

  如下面的代码

rush:js;"> function fn() {   setTimeout(function(){alert('can you see me?');},1000);   while(true) {} }  

alert();永远都不会执行,因为线程一直被死循环占用了。

window.location子对象

  解析URL对象location

  location对象的属性有:href,protocal,host,hostname,port,pathname,search,hash

rush:js;"> document.write(location.href + "
"); // http://localhost:4889/javascriptTest.html document.write(location.protocol + "
"); // http: document.write(location.host + "
"); // localhost:4889 document.write(location.hostname + "
"); // localhost document.write(location.port + "
"); // 4889 document.write(location.pathname + "
"); // /javascriptTest.html document.write(location.search + "换行
"); //http://localhost:4889/javascriptTest.html?id=1&name=张三 如果路径是这样,则输出 ?id=1&name=%E5%BC%A0%E4%B8%89 document.write(location.hash); //http: //localhost:4889/javascriptTest.html#kk=你好?id=1&name=张三 如果路径是这样,则输出 #kk=你好?id=1&name=张三

 载入新文档

    location.reload()  重新加载页面

    location.replace()  本窗口载入新文档

    location.assign()  本窗口载入新文档

    location = ""  //跳转到指定网址

    location = "search.html"        //相对路径跳转

    location = "#top"      //跳转页面顶部

  浏览历史

    History()对象的back()与forward()  与浏览器的“后退”,"前进"功能一样。

    history.go(-2);  后退两个历史记录

  浏览器和屏幕信息

    navigator.appName  Web浏览器全称

    navigator.appVersion  Web浏览器厂商和版本的详细字符串

    navigator.userAgent  客户端绝大部分信息

    navagator.platform   浏览器运行所在的操作系统

rush:js;"> document.write(navigator.userAgent + "
"); // Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML,like Gecko) Chrome/23.0.1271.97 Safari/537.11 document.write(navigator.appName + "
"); //netscape document.write(navigator.appVersion + "
"); //5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML,like Gecko) Chrome/23.0.1271.97 Safari/537.11 document.write(navigator.platform); //Win32

窗口的关系

    parent == self  只有顶级窗口才返回true

     parent和top属性允许脚本引用它的窗体的祖先,通常窗体是通过

类型 说明