JS之window对象
window对象
window属性:
opener:打开当前窗口的源窗口,如果这个窗口是由别的网页点击链接跳转过来的,或者是从另外一个页面点击打开窗口打开的,opener就是找到源页面的。如果当前窗口是首次启动浏览器打开的,则运行alert(window.opener);弹出窗口就会出现null,表示没有源网页。
window方法:
事件是先设置写好的程序代码(用函数封装),代码写好后先封装起来,被触发后执行该程序。
例如:
<input type="button" value="执行事件" onclick="Show()"/>
function Show()
{
alert("aa");
}
上面这段函数写好以后不会执行,当点击“执行事件”这个按钮后才会执行,输出结果 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 有地址栏
例如:
function Show()
{
window.open("http://www.baidu.com","_black","width=100,height=100");
}
上面代码会在新的窗口中打开一个100*100的百度页面。
window.open可以打开一个新的窗体,打开一个新的窗口之后会返回一个值,这个返回值叫窗体对象。有返回值就可以用一个变量接收,接收值的用处下面会提到。window.open打开窗口时会打开n个,点击一下按钮就会打开一次,如果想要只打开一次,用下面代码实现。
var a;
function Show()
{
if(a==null)
{
a=window.open("http://www.baidu.com","_black","width=100,height=100");
}
}
表示用a接收打开网站时返回的变量值,如果变量值=null(没有变量),就打开新窗口,如果有变量值,就不再打开新的窗口。
2.close:关闭窗口
如果直接调用window.close();,作用是关闭当前页面,如果想关闭其他页面,例如关闭上面已经打开的页面,用下面代码实现。
<input type="button" value="关闭" onclick="Guan()" />
function Guan()
{
if(a!=null)
{
a.close();
}
}
做一个关闭按钮,如果返回的变量不等于null,证明网页在新的窗口打开了,直接用a.close();关闭,关闭返回量为a的窗口。
上面代码只能关闭一个窗口,如果在一个窗口中打开了n个窗口,可以用下面代码关闭所有打开的新的窗口。
<input type="button" value="打开窗体" onclick="Opens()" />
<input type="button" value="关闭窗体" onclick="Closes()" />
var attr = Arry();
function Opens()
{
var b = window.open("http://www.baidu.com","_blank");
attr.push(b);
}
function Closes()
{
for(var i=0;i<attr.length;i++)
{
attr[i].close();
}
}
关闭多个代码的方式是每当打开一个新的窗口时,就会有一个返回值,把这些返回值放到一个数组里面。关闭这个数组,就会把里面的所有元素关闭,同时也把各元素所关联的窗口关闭。
3.间隔和延迟
延迟不是一个循环,只是延迟多长时间去执行。函数命名一般是用名称的字母,首字母大写。变量命名一般是小写。window.setInterval("要执行的代码",间隔的毫秒数)
示例写法:window.setInterval("alert('aa')",1000);当双引号需要套用时,里面的双引号要写成单引号,例如("alert('aa')",如果写成两个“”,系统会认为相邻的两个“”之间是一个字符串,系统就会报错。
或者:window.setInterval("var c = 'hello';alert(c)",1000); 一般不用这种写法,显得太乱。
一般会这样写:
<input type="button" value="间隔" onclick="JianGe()" />//放在body
function JianGe()
{
window.setInterval("Jian()",1000)
}
function Jian()
{
alert("你好");
}
setInterval在执行时也会有个返回值,它返回的是一个间隔的id,每个间隔弹出的窗口的id是不一样的,可以通过返回值控制间隔。把这些返回值存到一个变量里面,当想结束间隔时,通过id结束就可以了。
window.clearInterval:(间隔的id); 循环一次之后用来清除隔几秒执行的代码
示例:
var id;
function JianGe()
{
id = window.setInterval("Jian('')",1000);
}
function Jian()
{
window.open("http://www.baidu.com","_blank","width=200 height=200");
}
function JieShu()
{
window.clearInterval(id);
}
window.setTimeout 延迟执行("要执行的代码",延迟的毫秒数)
<input type="button" value="延迟执行" onclick="YanChi"/>
function YanChi()
{
window.setTimeout("alert('aa')",2000)
}
延迟执行只弹出来一次,只是延迟,上面代码表示延迟2s执行。
另外,延迟也可以做成间隔的效果,下列代码可以实现该功能。其原理是每隔1s,函数YanJian()就自己调用自己一次,实现间隔的效果。
<input type="button" value="延迟做间隔" onclick="YanJian" />
function YanJian()
{
alert("aa");
window.setTimeout("YanJian",1000)
}
//window.clearTimeout(延迟的id);清除setTimeout,一般延迟执行较为常用。
4.window.history.go(n); n是正数代表前进n个页面,n是负数代表后退n个页面。
JS之window对象的更多相关文章
- js的window对象
		
js的window对象 1.子窗口方法 function testOpen(){ window.open('son.html','newwindow','height=400, width=600, ...
 - js中window对象详解以及页面跳转
		
1.window.top.window.location = "index.asp"; 2.window.top.location.href="index.asp&quo ...
 - js中Window 对象及其的方法
		
window.location 对象 window.location 对象用于获得当前页面的地址 (URL),并把浏览器重定向到新的页面.window.location 对象在编写时可不使用 wind ...
 - JS day01——window对象、执行顺序、线程模型
		
1.window对象 window对象表示当前浏览器的窗口,它是一个顶级对象,我们创建的所有对象.函数.变量都是window对象的成员. window对象自带了一些非常有用的方法.属性. window ...
 - js中window对象的opener属性的一个坑
		
2018-05-08 17:48:33 今天我编写代码碰到了一个让我纠结了很久的坑,特别想在此说一下,让其他人避免我踏过的这个坑. 这个坑就是:在我自己写的子窗口中用opener属性却获取不到父窗口的 ...
 - 转-JS之Window对象
		
一.说明:他是JS中最大的对象,它描述的是一个浏览器窗口,一般要引用他的属性和方法时,不需要用“Window.XXX”这种形式,而是直接使用“XXX”.一个框架页面也是一个窗口. 二.Window窗口 ...
 - js之window对象(慕课网学习笔记)
		
javaScript定义了一个变量一个函数都会变成window中的一个成员 var a=1; alert(window.a) //会输出a的值 window基础 创建窗口.调整窗口.移动窗口.关闭窗口 ...
 - js修改window对象中的url历史记录
		
//页面地址:http://localhost/11/account.html//访问页面后,地址变为:http://localhost/11/account.html?type=banana con ...
 - Javascript高级编程学习笔记(28)—— BOM(2)window对象2
		
今天讲一下window对象和浏览器导航,弹窗等有关的内容 导航和打开窗口 window.open() 用于导航到某个特定 url 该方法接收四个参数 1.url 2.窗口目标(当页面中有多个框架fra ...
 
随机推荐
- lintcode-149-买卖股票的最佳时机
			
149-买卖股票的最佳时机 假设有一个数组,它的第i个元素是一支给定的股票在第i天的价格.如果你最多只允许完成一次交易(例如,一次买卖股票),设计一个算法来找出最大利润. 样例 给出一个数组样例 [3 ...
 - 【MVC4升级到MVC5】ASP.Net MVC 4项目升级MVC 5的方法
			
1.备份你的项目 2.从Web API升级到Web API 2,修改global.asax,将 ? 1 WebApiConfig.Register(GlobalConfiguration.Config ...
 - web前端之路 - 开篇
			
一 web发展历程 了解事物的历史有助于我们渐进式的从发展的思路清楚了解事物的来龙去脉. 这里有一篇网文写得比较清晰和完整:https://www.tianmaying.com/tutorial/we ...
 - 【Linux】- Ubuntu守护进程supervisor
			
linux的守护进程类似于windows的服务.linux通过supervisor创建守护进程. 1.安装supervisor sudo apt-get install supervisor 安装成功 ...
 - java基础--逻辑运算符-- 002
			
1:int a = 10;int b = 20;boolean flag = (a == b) //falseboolean flag = (a = b) //报错,不兼容的类型 2: &, ...
 - [剑指Offer] 54.字符流中的第一个不重复的字符
			
题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出 ...
 - 【EF】Entity Framework Core 2.0 特性介绍和使用指南
			
阅读目录 前言 获取和使用 新特性 项目升级和核心API变化 下一步计划 遗憾的地方 回到目录 前言 这是.Net Core 2.0生态生态介绍的最后一篇,EF一直是我喜欢的一个ORM框架,随着版本升 ...
 - BZOJ 2333 棘手的操作(离线+线段树+带权并查集)
			
这题搞了我一天啊...拍不出错原来是因为极限数据就RE了啊,竟然返回WA啊.我的线段树要开8倍才能过啊... 首先可以发现除了那个加边操作,其他的操作有点像线段树啊.如果我们把每次询问的联通块都放在一 ...
 - BZOJ4850/BZOJ2216 JSOI2016灯塔/Poi2011Lightning Conductor(决策单调性)
			
即对每个i最大化hj-hi+sqrt(|i-j|).先把绝对值去掉,正反各做一次即可.注意到当x>y时,sqrt(x+1)-sqrt(x)<sqrt(y+1)-sqrt(y),所以若对于i ...
 - Mysql 基本语句练习
			
一.怎样查看数据库信息? desc 数据库名; 二.怎样查看数据表信息? desc 表名: //查看表的属性和属性值 或者用select语句: //查看表的行记录信息 select ...