细说JavaScript BOM之window对象_js window对象

window对象是JavaScript中最大的对象,其他对象都是window对象的一部分,window对象表示浏览器的一个实例,在浏览器中它有双重身份,既是通过JavaScript访问浏览器窗口的一个接口,又是ECMAScript标准中规定的Globel(全局)对象。第二个身份说明了我们在网页中定义的任何一个变量、函数和对象都会以window作为其全局对象

细说JavaScript BOM之window对象_window对象_02

一、window对象

1、全局作用域

window对象是全局对象,因此所有在全局作用域中声明的变量、函数、对象都会变成window对象的属性、方法、对象

var name = "知数SEO";
var array = new Array('1','2','3','4');
function demo(){
	alert("myName this.name" + this.name);
	alert("muName window.name" + window.name);
}
alert(window.name);  // 知数SEO
window.demo();
alert(array);
alert(window.array);

基于window对象是全局对象的概念,它下属的所有全局变量和函数都是它的属性,并且基于所有原生的构造函数及其他函数都存在于它的命名空间下,因此在调用window对象的方法和属性时,可以省略window对象的引用。
需要注意的是只有在全局作用域中定义才会被自动归入window对象名下,而在局部作用域中定义不会归入window对象名下。

2、window对象常用属性

window.name属性在跨域交互上起到很大的作用,因为name在完成载入新页面或刷新功能时,其值依旧是上次页面设置的值,并且这个值可以支持2MB的数据大小

属性名称

功能描述

name

窗口的名称,由打开这个窗口的连接(a target=“”)或框架(<iframe>)或某个窗口调用的open()方法来决定

status

窗口下面的状态栏所显示的内容,通过对window.status赋值,可以改变状态栏的显示

opener

window.opener返回打开本窗口的对象,如果这个窗口不是由其他窗口打开的,则返回null

self

指窗口本身,如最常见的window.self.close()和window.close()方法,用于关闭窗口

parent

返回窗口所属的父窗口

top

返回占据整个浏览器窗口顶端的框架页对象

innerheight

返回窗口的文档显示取的宽度

innerwidth

返回窗口的文档显示区的宽度

history

对history对象的只读引用

document

对document对象的只读引用

location

用于窗口或框架的location对象

navigator

对navigator对象的只读引用

screen

对screen对象的只读引用

3、定时器和周期事件

名称

描述

setTimeout()

在指定的毫秒数后调用函数或计算表达式

clearTimeout()

取消setTimeout()对象

setInterval()

按照指定的周期(以毫秒计)来调用函数或计算表达式

clearInterval()

取消setInterval()实例

3.1、setTimeout()

js是单线程语言,在执行程序时按照顺序排下来,前面的程序必须处理好,后面的程序才会被执行。因此js中允许通过设置超时值和间时间值来调度代码在特定的时刻被执行,以打破执行顺序的限制。
超时值指在指定的时间后执行某段代码,仅执行一次
间时间值是指每隔指定的时间段就会执行一次某一段代码

// 	settimeout()接收两个参数
// 参数一:要执行的调用函数或计算表达式
// 参数二:以毫秒表示的时间
// 语法格式
setTimeout(code,milliseconds);

// 例子
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>知数SEO_专注搜索引擎优化和品牌推广</title>
</head>
<body>
<input type="button" onclick="demo()" value="获取3秒后的时间是">
<p></p>
<script>
        function demo() {
            var op = document.getElementsByTagName('p')[0];  // 获取p标签对象
            var curTime = new Date(); // 获取当前时间
            op.innerHTML = "当前时间是:" + curTime;  // 添加当前时间为p标签里的内容
            setTimeout(function(){
                var curTime2 = new Date();  // 获取3秒后的时间
                alert(curTime2);
            },3000);
        }
</script>
</script>
</body>
</html>
3.2、clearTimeout()

在调用setTimeout()方法后会返回一个数值ID,表示超时调用,这个ID是计划执行代码的唯一标识符,可以通过它来取消未执行的超时调用计划,这时我们可以获取到这个id然后将这个id作为clearTimeout()方法的参数进行传递,销毁、关闭这个定时器事件

// 语法
clearTimeout(id);

// 例子
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>知数SEO_专注搜索引擎优化和品牌推广</title>
</head>
<body>
<input type="button" onclick="demo()" value="获取3秒后的时间是">
<input type="button" onclick="stop()" value="取消执行超时调用">
<p></p>
<script>
        var timer;
        function demo() {
            var op = document.getElementsByTagName('p')[0];  // 获取p标签对象
            var curTime = new Date(); // 获取当前时间
            op.innerHTML = "当前时间是:" + curTime;  // 添加当前时间为p标签里的内容
            timer = setTimeout(function(){
                var curTime2 = new Date();  // 获取3秒后的时间
                alert(curTime2);
            },3000);
        }

        function stop(){
            clearTimeout(timer);
            alert("取消成功");
        }
</script>
</script>
</body>
</html>
3.3、setInterval()
// 语法
// 参数1: 要执行的调用函数或计算表达式
// 参数2:以毫秒表示的事件
setInterval(code,milliseconds);

// 例子
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>知数SEO_专注搜索引擎优化和品牌推广</title>
</head>
<body>
<p>距离活动结束时间还有:</p>
<p id="restTime"></p>
<script>
    setInterval(function(){
        var dateTime = countDown();
        var restTime = document.getElementById('restTime');
        restTime.innerHTML = dateTime;
    },1000);
    function countDown(){
        // 设置未来时间
        var setTime = new Date('2024-1-28 08:00:00');
        // 获取当前时间
        var nowTime = new Date();
        // 时差
        var rest = setTime.getTime() - nowTime.getTime();
        // 计算时间
        var day = parseInt(rest/1000/60/60/24);
        var hour = parseInt(rest/1000/60/60%24);
        var minute = parseInt(rest/1000/60%60);
        var second = parseInt(rest/1000%60);
        var mydate = day + "日" + hour + "时" + minute + "分" + second + "秒";
        return mydate;
    }
</script>
</script>
</body>
</html>
3.4、claerInterval()
// 语法
// 调用clearInterval()方法同样会返回一个间歇调用id
clearInterval(id);

// 例子
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>知数SEO_专注搜索引擎优化和品牌推广</title>
</head>
<body>
<p>距离活动事件结束还有:</p>
<p id="restTime"></p>
<input type="button" value="取消倒计时" id="clear">
<script>
    // 获取取消按钮对象
    var oClear = document.getElementById('clear');
    var timer = setInterval(function (){
        var dateTime = countDown();
        var restTime = document.getElementById('restTime');
        restTime.innerHTML = dateTime;
    },1000);
    oClear.onclick = function (){
        clearInterval(timer);
        alert("取消成功");
    };
    function countDown(){
        // 设置未来时间
        var setTime = new Date('2024-1-28 08:00:00');
        // 获取当前时间
        var nowTime = new Date();
        // 时差
        var rest = setTime.getTime() - nowTime.getTime();
        // 计算时间
        var day = parseInt(rest/1000/60/60/24);
        var hour = parseInt(rest/1000/60/60%24);
        var minute = parseInt(rest/1000/60%60);
        var second = parseInt(rest/1000%60);
        var mydate = day + "日" + hour + "时" + minute + "分" + second + "秒";
        return mydate;
    }

</script>
</script>
</body>
</html>
4、其他常用方法
4.1、窗口焦点控制方法

名称

描述

focus()

把键盘焦点给予某一个窗口

blur()

把键盘焦点从顶层窗口移开

4.2、新建窗口方法

名称

描述

opener()

通过opener可以实现跨窗体之间的通信,但要保证是在统一域名下,而且一个窗体要包含另一个窗体

open()

打开一个新的浏览器窗口或查找一个已命名的窗口

close()

关闭浏览器窗口

4.3、对话框方法

名称

描述

alert()

显示带有一段消息和一个确认按钮的警报框

confirm()

显示带有一段消息及确认按钮和取消按钮的对话框

prompt()

显示可提示用户输入的对话框

4.4、控制窗口大小和位置方法

名称

描述

resizeBy()

按照指定的像素调整窗口的大小

resizeTo()

把窗口的大小调整到指定的宽度和高度

moveBy()

可相对窗口的当前坐标把它移动指定的像素

moveTo()

把窗口的左上角移动到一个指定的坐标

5、窗口操作–分帧
5.1、窗口分帧

什么是窗口:我们可以通过窗口显示信息或者操作获取信息
窗口可分为不同类型,例如:通过window.open()来打开一个新的可定义宽度和高度的窗口;alert() confirm() prompt()这种弹窗;
什么是分帧:浏览器窗口显示的内容我们称为页面,这个页面就叫帧。窗口分帧就是把一个浏览器文档窗口分隔成多个窗口,使得每个窗口都可以显示一个独立的网页文件,而且每个帧(页面)都有自己的url

5.2、如何分帧

通常用<frameset> 和 <frame> 创建。
<frameset>标签的常用属性

// 1、cols和rows,决定页面如何分隔的两个参数
// 分隔左右窗口用cols,各帧的左右宽度用占总窗口宽度的百分比表示 cols="30%,40%,*"
// 分隔上下窗口用rows

// 2、frameborder,指定各窗口是(yes)否(no)要加边框
// 如果要加边框则用border参数指定边框的宽度,bordercolor参数指定边框的颜色

// 3、framespacing,用户设定各窗口之间的间隔大小,默认为0

<frame>标签的常用属性

// 1、align,设定分窗口的位置是靠左(left)、靠右(rignt)、居中(center)、靠上(top)、靠下(bottom)

// 2、name,用于指定分窗口的名字,src则用于指定分窗口所对应的url

// 3、noresize,对于用户来说,当\<frame\>标签中包含此参数的时候,用户就不能用鼠标调整各分窗口的大小

// 4、scrolling,设定分窗口是否需要滚动条
// 当scrolling=no时表示不需要滚动条
// 当scrolling=yes时表示需要滚动条
// 当scrolling=auto时表示根据实际情况自动设置滚动条

// 5、frameborder 和 framecolor,分表表示设置窗口有无边框和边框颜色

// 6、marginheiht 和 marginwidth,分别用于设定分窗口的上下边缘和左右宽度
5.3、如何操作分帧