JavaScript面向对象之Windows对象

JavaScript之Window对象

首先我们先了解一个概念:事件。

事件,就是把一段代码设置好,满足条件时触发。或者说,事件是可以被 JavaScript 侦测到的行为。

网页中每个元素都可以触发JavaScript事件。

我们先来看一个简单的事件:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
    <input type="button" value="点击" onClick="dianJi()"/>
</body>
</html>
<script>
    function dianJi(){
        alert("这是函数dianJi");
    }
</script>

我们可以使用<input>标签的onClick属性来调用设置好的函数dianJi(),这就是一个简单的点击事件。

DOM对象之Windows对象

DOM对象:当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。

HTML DOM 模型被构造为对象的树。

打开网页后,首先看到的是浏览器窗口,即顶层的window对象。

其次,看到的是网页文档的内容,即document文档。

我们先来看一下Window对象。

Window有属性和方法:

属性(值或者子对象): opener:打开当前窗口的源窗口,如果当前窗口是首次启动浏览器打开的,则opener是null,可以利用这个属性来关闭源窗口。

方法(函数): 事件(事先设置好的程序,被触发):

window.open("第一部分","第二部分","第三部分","第四部分");

特征参数:

第一部分:写要打开的页面地址

第二部分:打开的方式,_blank 是在新窗口打开 _self

第三部分:控制打开的窗口,可以写多个,用空格隔开

toolbar=no新打开的窗口无工具条

menubar=no无菜单栏

status=no无状态栏

width=100 height=100 宽度高度

left=100 打开的窗口距离左边多少距离

resizable=no窗口大小不可调

scrollbars=yes 出现滚动条

location=yes 有地址栏

以上属性不常用,且多不兼容

返回值:新打开的窗口对象

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
    <input type="button" value="点击" onClick="show()"/>
</body>
</html>
<script>
    function show(){
    window.open("http://www.baidu.com","_blank","toolbar=no menubar=no status=no width=300 height=500 left=100 resizable=no scrollbars=yes location=yes ");
    }
</script>

打开的窗口还可以保存在一个变量中,并用另一个事件关闭,用close():关闭指定的窗口

close():关闭指定的窗口

window.close():关闭当前窗口 w.close():关闭w窗口

关闭多个子窗口:放在数组中的窗口:w[i].close();

关闭打开当前窗口的源窗口

window.opener.close();

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
    <input type="button" value="点击" onClick="show()"/>
    <input type="button" value="关闭" onclick="guanBi()" />
</body>
</html>
<script>
    var w;
    function show(){
    w = window.open("http://www.baidu.com","_blank");
    }
    function guanBi(){
    w.close();
    }
</script>

 在以上页面中我们可以通过点击关闭按钮关闭打开的页面。

这样打开可以多次打开,我们还可以通过if判断设置只能打开一次:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
    <input type="button" value="点击" onClick="show()"/>
    <input type="button" value="关闭" onclick="guanBi()" />
</body>
</html>
<script>
    var w;
    function show(){
        if(w==null){
            w = window.open("http://www.baidu.com","_blank");
        }
    }
    function guanBi(){
    w.close();
    }
</script>

这里用一个if语句,判断w的值是否为空,打开一个窗口之后w的值就不为空了,之后再点击鼠标调用此函数则不执行打开新窗口。

我们还可以用数组的push()方法将所有打开的页面存到一个数组里,然后用close()方法一起关闭:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
    <input type="button" value="点击" onClick="show()"/>
    <input type="button" value="关闭" onclick="guanBi()" />
</body>
</html>
<script>
    var w=new Array();
    function show(){
        w.push(window.open("http://www.baidu.com","_blank"));
    }
    function guanBi(){
        for(i=0;i<w.length;i++){
            w[i].close();
        }
    }
</script>

间隔:

window.setInterval("要执行的代码",间隔的毫秒数) window.clearInterval(间隔的id); 循环一次之后用来清除隔几秒执行的代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
    <input type="button" value="开始" onClick="start()" />
    <input type="button" value="停止" onClick="end()" />
</body>
</html>
<script>
    function show(){
        alert("hello");
    }
    var id;
    function start(){
        id = window.setInterval("show()",1000);
    }
    function end(){
        window.clearInterval(id);
    }
</script>

在window.setInterval("",  )中,前面是间隔时间执行的代码,后面是间隔的时间,单位是毫秒。

延迟:

window.setTimeout("要执行的代码",延迟的毫秒数) window.clearTimeout(延迟的id);清除setTimeout,一般延迟执行较为常用。

    window.setTimeout("show()",10000);
    window.clearTimeout();

使用延迟来做到间隔的效果:

    function show(){
        alert("hello");
        window.setTimeout("show()",1000);
    }
    show();

使用类似递归的方式,在函数中自己调用自己,从而使延迟不断地运行,来使用延迟做到间隔的效果。

页面操作:

window.moveTo(x,y); 移动页面

window.resizeTo(宽,高); 调整页面

window.scrollTo(x,y);滚动页面至哪里

以上方法多不兼容。

模态对话框

模态:打开对话框之后,对话框之后的内容是不能操作的。

window.showModalDialog("url","向目标对话框传的值","窗口特征参数") 打开模态对话框

模态对话框必须关掉才能对后端操作。 模块对话框和窗口的区别是永远置顶。

特征参数:用分号隔开,像素大小用px。dialogHeight,dialogWidth,center,等。

window.history对象

历史记录,通过历史记录可以操作页面前进或者后退

window.history.back();后退

window.history.forward();前进

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

window.location对象

location地址栏

页面的重定向

    function tiao(){
        window.location.href="index.html";
    }

var s = window.location.href;获取当前页面的地址

window.location.href="http://www.baidu.com";修改页面地址,会跳转页面

window.location.hostname: 主机名,域名,网站名,可用变量接收

window.location.pathname: 路径名,可用变量接收

window.status对象

status状态栏,可以给状态栏添加要显示的文字

window.status="要在状态栏显示的内容";设置状态栏文字

window.showModelessDialog("url","向目标对话框传的值","窗口特征参数")打开非模块对话框,不用关闭可以操作后面。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏vue学习

小程序 — 选项卡

(2)将用户点击传过来的index值赋给data中改变当前的索引值activeIndex

2172
来自专栏IMWeb前端团队

JavaScript强化教程——jQuery - 获得内容和属性

本文作者:IMWeb 王军 原文出处:IMWeb社区 未经同意,禁止转载 本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScr...

1825
来自专栏Flutter入门到实战

开发工具总结(5)之Markdown语法图文全面详解及其工具介绍

版权声明:本文为博主原创文章(少量文字参考他人博文,已加上引用说明),未经博主允许不得转载。https://www.jianshu.com/p/c0a2897a...

2194
来自专栏C语言及其他语言

【程序源码】C语言实现窗口抖动功能

程序源码 想必大家都知道QQ聊天对话框中,有一个窗口抖动的功能,相信大家也都用过,但能否用C语言做出来呢? 答案绝对是肯定的,但如何实...

34011
来自专栏mySoul

微信小程序自定义组件

其中,components为组件目录,nodemodules为模块目录,pages为小程序的页面目录,utils为一些基础功能的封装。好比安装的第三方百度统计功...

2843
来自专栏hbbliyong

Android Studio 快捷键

Alt+回车 导入包,自动修正 Ctrl+N   查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L  格式化代码 Ctrl+Alt+O 优化导入...

2976
来自专栏快乐八哥

使用jQuery Draggable和Droppable实现拖拽功能

上篇博客中已经介绍了web开发中基本拖放原理,现在给出需要完成的功能。最后运行的效果如下图所示: ? 主要功能需求说明: 1.左侧的元素结构最后会通过Ajax ...

2756
来自专栏更流畅、简洁的软件开发方式

.net firamework 框架里面的控件的继承关系。

     记得当初学习VB6.0的时候,入门的书,一上来就是控件的介绍,控件的属性、事件的使用,拖拽一个文本框、一个按钮,然后再双击按钮,在按钮的事件里面给文本...

2177
来自专栏一个会写诗的程序员的博客

JS如何模拟鼠标点击X,Y坐标

https://developer.mozilla.org/zh-CN/docs/Web/API/Document/createEvent

1.4K5
来自专栏静晴轩

Android Studio快捷键

最常用快捷键 Alt+回车 导入包,自动修正 Ctrl+N 查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L 格式化代码 Ctrl+Alt+O ...

3387

扫码关注云+社区