window对象

window属性:

opener:打开当前窗口的源窗口,如果这个窗口是由别的网页点击链接跳转过来的,或者是从另外一个页面点击打开窗口打开的,opener就是找到源页面的。如果当前窗口是首次启动浏览器打开的,则运行alert(window.opener);弹出窗口就会出现null,表示没有源网页。

window方法:

事件是先设置写好的程序代码(用函数封装),代码写好后先封装起来,被触发后执行该程序。

例如:

  1. <input type="button" value="执行事件" onclick="Show()"/>
  2. function Show()
  3. {
  4. alert(“aa”);
  5. }

上面这段函数写好以后不会执行,当点击“执行事件”这个按钮后才会执行,输出结果 aa。执行事件是这个按钮的名字,onclick表示指向的调用的函数的名称,Show就是函数的名称。

1.open:打开页面

open里面有四个参数,window.open("第一部分","第二部分","第三部分","第四部分"),第四个一般不会用到,不用写。

第一部分:写要打开的页面地址
    第二部分:打开的方式,_blank 是在新窗口打开 ;_self是在自身窗口打开。
    第三部分:控制打开的窗口,可以写多个,用空格隔开,控制的方式有以下几种

    toolbar=no新打开的窗口无工具条 
    menubar=no无菜单栏 status=no无状态栏 
    width=100 height=100 宽度高度
    left=100 打开的窗口距离左边多少距离
    resizable=no窗口大小不可调 
    scrollbars=yes 出现滚动条
    location=yes 有地址栏

    例如: 

  1. function Show()
  2. {
      window.open("http://www.baidu.com","_black","width=100,height=100");
  3. }

  上面代码会在新的窗口中打开一个100*100的百度页面。

window.open可以打开一个新的窗体,打开一个新的窗口之后会返回一个值,这个返回值叫窗体对象。有返回值就可以用一个变量接收,接收值的用处下面会提到。window.open打开窗口时会打开n个,点击一下按钮就会打开一次,如果想要只打开一次,用下面代码实现。

  1. var a;
  2. function Show()
  3. {
  4. if(a==null)
  5. {
  6.     a=window.open("http://www.baidu.com","_black","width=100,height=100");
  7. }
  8. }

表示用a接收打开网站时返回的变量值,如果变量值=null(没有变量),就打开新窗口,如果有变量值,就不再打开新的窗口。

2.close:关闭窗口

如果直接调用window.close();,作用是关闭当前页面,如果想关闭其他页面,例如关闭上面已经打开的页面,用下面代码实现。

   

  1. <input type="button" value="关闭" onclick="Guan()" />
  2. function Guan()
  3. {
  4. if(a!=null)
  5. {
  6. a.close();
  7. }
  8. }

做一个关闭按钮,如果返回的变量不等于null,证明网页在新的窗口打开了,直接用a.close();关闭,关闭返回量为a的窗口。

上面代码只能关闭一个窗口,如果在一个窗口中打开了n个窗口,可以用下面代码关闭所有打开的新的窗口。

  1. <input type="button" value="打开窗体" onclick="Opens()" />
  2. <input type="button" value="关闭窗体" onclick="Closes()" />
  3. var attr = Arry();
  4. function Opens()
  5. {
  6. var b = window.open("http://www.baidu.com","_blank");
  7. attr.push(b);
  8. }      
  9. function Closes()
  10. {
  11. for(var i=0;i<attr.length;i++)
  12. {
  13. attr[i].close();
  14. }
  15. }

关闭多个代码的方式是每当打开一个新的窗口时,就会有一个返回值,把这些返回值放到一个数组里面。关闭这个数组,就会把里面的所有元素关闭,同时也把各元素所关联的窗口关闭。

3.间隔和延迟

延迟不是一个循环,只是延迟多长时间去执行。函数命名一般是用名称的字母,首字母大写。变量命名一般是小写。window.setInterval("要执行的代码",间隔的毫秒数)

示例写法:window.setInterval("alert('aa')",1000);当双引号需要套用时,里面的双引号要写成单引号,例如("alert('aa')",如果写成两个“”,系统会认为相邻的两个“”之间是一个字符串,系统就会报错。

或者:window.setInterval("var c = 'hello';alert(c)",1000);  一般不用这种写法,显得太乱。

一般会这样写:

  1. <input type="button" value="间隔" onclick="JianGe()" />//放在body
  2. function JianGe()
  3. {
  4. window.setInterval("Jian",1000)
  5. }
  6. function Jian()
  7. {
  8. alert(“你好”);
  9. }

setInterval在执行时也会有个返回值,它返回的是一个间隔的id,每个间隔弹出的窗口的id是不一样的,可以通过返回值控制间隔。把这些返回值存到一个变量里面,当想结束间隔时,通过id结束就可以了。

window.clearInterval:(间隔的id); 循环一次之后用来清除隔几秒执行的代码

示例:

  1. var id;
  2. function JianGe()
  3. {
  4. id = window.setInterval("Jian('')",1000);
  5. }
  6. function Jian()
  7. {
  8. window.open("http://www.baidu.com","_blank","width=200 height=200");
  9. }
  10. function JieShu()
  11. {
  12. window.clearInterval(id);
  13. }

window.setTimeout  延迟执行("要执行的代码",延迟的毫秒数)

  1. <input type="button" value="延迟执行" onclick="YanChi"/>
  2. function YanChi()
  3. {
  4. window.setTimeout("alert('aa')",2000)
  5. }

延迟执行只弹出来一次,只是延迟,上面代码表示延迟2s执行。

另外,延迟也可以做成间隔的效果,下列代码可以实现该功能。其原理是每隔1s,函数YanJian()就自己调用自己一次,实现间隔的效果。

  1. <input type="button" value="延迟做间隔" onclick="YanJian" />
  2. function YanJian()
  3. {
  4. alert("aa");
  5. window.setTimeout("YanJian",1000)
  6. }
  7. //window.clearTimeout(延迟的id);清除setTimeout,一般延迟执行较为常用。

4.window.history.go(n); n是正数代表前进n个页面,n是负数代表后退n个页面。

9月22日上午JavaScript----window对象的更多相关文章

  1. 9月20日上午JavaScript函数

    函数 一.  函数定义 函数又叫方法,在程序里面函数是用来执行某些特定功能的代码.为了减少重复使用代码,可以把特定功能的代码做成函数,需要使用时拿出来调用.alert();就是一个很常见的.简单的函数 ...

  2. 9月19日上午JavaScript数组

    数组 一.定义 1.数组的文字定义 广义上说,数组是相同类型数据的集合.但是对于强类型语言和弱类型语言来说其特点是不一样的.强类型语言数组和集合有以下特点. 数组强类型语言:1.数组里面只能存放相同数 ...

  3. 12月22日《奥威Power-BI财务报表数据填报》腾讯课堂开课啦

    一扇可以通向任何地方的“任意门”,是我们多少人幼时最梦寐以求的道具之一.即使到了现在,工作中的我们还会时不时有“世界那么大,我想去看看”的念头,或者在突然不想工作的时刻,幻想着自己的家门变成了“任意门 ...

  4. Autodesk 最新开发技术研讨会 -8月22日-Autodesk北京办公室

    为了增进与广大中国地区Autodesk产品的二次开发人员的了解与互动,帮助中国地区的Autodesk产品二次开发人员了解Autodesk最新的二次开发技术动向,并获得Autodesk公司专业开发支持顾 ...

  5. 见见面、聊聊天 - 5月22日晚7点Meetup,三里屯绿树旁酒吧,畅谈云技术和应用

    总是邮件.QQ什么的线上聊,让我们见面吧,不怕见光死,呵呵.   我和同事会先抛砖引玉,给大家介绍一下Autodesk几款最新的云技术和解决方案,然后大家就可畅所欲言,自由交流.来自五湖四海的人,为了 ...

  6. 2016年12月22日 星期四 --出埃及记 Exodus 21:17

    2016年12月22日 星期四 --出埃及记 Exodus 21:17 "Anyone who curses his father or mother must be put to deat ...

  7. 转:[置顶] 从头到尾彻底理解KMP(2014年8月22日版)

    [置顶] 从头到尾彻底理解KMP(2014年8月22日版)

  8. 2016年11月22日 星期二 --出埃及记 Exodus 20:13

    2016年11月22日 星期二 --出埃及记 Exodus 20:13 "You shall not murder.不可杀人.

  9. 2016年10月22日 星期六 --出埃及记 Exodus 19:6

    2016年10月22日 星期六 --出埃及记 Exodus 19:6 you will be for me a kingdom of priests and a holy nation.' These ...

随机推荐

  1. Linux 安装mysql+apache+php

    安装mysql 1.  yum install mysql mysql-server 2. 修改mysql密码 >use mysql    >update user set passwor ...

  2. linux 设置日志编码

    打开linux的设置面板 在Appearance选项->Character encoding 设置为UTF-8

  3. 【SPOJ 1812】Longest Common Substring II

    http://www.spoj.com/problems/LCS2/ 这道题想了好久. 做法是对第一个串建后缀自动机,然后用后面的串去匹配它,并在走过的状态上记录走到这个状态时的最长距离.每匹配完一个 ...

  4. 树分治 点分治poj 2114

    存在2点间距离==k 输出AYE 否则输出NAY #include<stdio.h> #include<string.h> #include<algorithm> ...

  5. 通过JS实现网站繁体简体互换

    html部分 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  6. jQuery调用WebService实现增删改查的实现

    第一篇博客,发下我自己写的jQuery调用WebService实现增删改查的实现. 1 <!DOCTYPE html> 2 3 <html xmlns="http://ww ...

  7. perl 箭头操作符

    箭头操作符有两种用法. 第一种用法是访问引用中的数据元素: #!/usr/bin/perl -w use strict; my @a = (5, 6, 7,9); my $aref = \@a; pr ...

  8. windows下关闭进程

    1.首先查找到占用8080端口的进程号PID是多少 CMD>netstat -ano | findstr 8888 这个命令输出的最后一列表示占用8080端口的进程号是多少,这里是5880 2. ...

  9. (转)CSS的Sprites技术

    Css Sprites 技术逐渐流行,各大网站上都可以看到它的身影. 但从本质上,Css Sprites 只是 Css 技术的一个使用小窍门,初学者也能快速上手. Css Sprites 简单解释: ...

  10. dotnet反编译工具大全

    反编译不是为了破解软件,而是在开发时更好的读懂程序干了什么,比如MVC的源码,如果使用1和4的VS插件能更好的进行断点跟踪. 常用,效率最高: 1.[.NET Reflector]首选,能比较好的反编 ...