一、window对象

  window对象代表当前窗口,所有全局对象都是windows的属性,

  例如document是window的属性,window.document.writer("");

  可以将window看做最外层的对象,其他一些了对象都是windows的属性。

  window对象有很多属性,这些属性提供了对交互的支持(例如document、location...)

二、document对象

  document是平时使用较多的对象,代表当前HTML文档.

  window.document,前面的window可省略。

  document也是window对象的一个属性。

  每个载入浏览器的 HTML 文档都会成为 Document 对象。

  Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。

  典型方法:document.getElementById(id);//返回指定id的HTML标签对象。

       document.getElementByName();//返回指定名称的HTML对象集合。

       document.write("");//向文档写入内容 

  document对象属性及方法可参阅:w3shcool document对象参考手册

<!DOCTYPE html>
<html>
<head> </head> <body >
<input name="box" type = "checkbox" value = "1">1</input>
<input name="box" type = "checkbox" value = "2">2</input>
<input name="box" type = "checkbox" value = "3">3</input>
<button onclick ="f()" >test</button>
<p id = "content"></p>
<script>
function f(){
var i = 0;
var boxs = document.getElementsByName("box");
var con = document.getElementById("content");
var info = "选择了";
for(var i = 0; i <boxs.length; i++){
if(boxs[i].checked == true){
info += boxs[i].value + ",";
}
}
con.innerHTML = info;
} </script>
</body>
</html>

  

document.write()在文档加载完毕后再次调用会覆盖原有HTML文档内容。

<!DOCTYPE html>
<html>
<head> </head> <body > <p id = "content">内容内容内容</p>
<button onclick = "f()">test</button>
<script>
function f(){
document.write("");
alert("清除内容");
} </script>
</body>
</html>

HTML文档加载完毕后,关闭了输出流。

在输出流关闭后,重写调用document.write写入会先调用open方法,而open会先将页面清除。

如果是在输入流未结束的过程中,调用document.write写入则不会发生覆盖的情况。

<!DOCTYPE html>
<html>
<head> </head> <body > <p id = "content">内容内容内容</p>
<script>
document.write("111");
alert("清除内容");
</script>
</body>
</html>

JavaScript代码执行时,文档尚未加载完毕,输出流没有关闭,

此时调用就不会重写打开输出流导致文档被覆盖。

不想被write覆盖可预先设置信息区块,后续通过innerHTM修改信息区块中内容,如第一个例子所示。

三、location对象

  location对象主要提供获取当前url地址,设置页面url跳转等功能。

  window.location前面的window可省略不写。 

<!DOCTYPE html>
<html>
<head> </head> <body >
<button onclick = "f()">修改url为https://cn.bing.com/</button>
<button onclick = "location.reload()">重新加载页面</button>
<script>
function f(){
location.href = "https://cn.bing.com/";//href代表完整的url路径
} </script>
</body>
</html>

  

location其他属性及方法可参阅:w3school location对象参考手册  

 

四、screen对象

  screen对象主要包含当前浏览器的屏幕信息,例如可用的高、框为多少。

  

<!DOCTYPE html>
<html>
<head> </head> <body > <script>
document.write("屏幕高度" + screen.height + "<br>");
document.write("返回显示屏幕的高度 (除 Windows 任务栏之外)" + screen.availHeight); </script>
</body>
</html>

  

    当前电脑分辨率为1366x768

screen其他属性及方法可参阅: w3school screen对象参考手册

五、history对象

  history代表浏览器的历史记录,可以进行回退等操作。

<!DOCTYPE html>
<html>
<head> </head> <body >
<button onclick = "history.back()">返回上一级</button>
<script>
document.write("共有" + history.length +"条历史记录")
</script>
</body>
</html>

  

六、消息框

  6.1警告框

  window.alert(content);//window可省略。  

  content可为对象或字符串或数字,各个类型之间用‘+’连接。

  支持转义字符,例如‘\n’代表换行。

  警告框需点击确认后方可继续。 

<!DOCTYPE html>
<html>
<head> </head> <body >
<script>
var i = 3;
window.alert("12" + '\n'+ i);//等价alert("12" + '\n' + i);
</script>
</body>
</html>

  

  

  6.2确认框

  确认框需等待用户点击确认或取消后方可继续。

  点击确认返回true,点击取消返回false。

  

<!DOCTYPE html>
<html>
<head> </head> <body >
<script>
var i = 3;
var flag = window.confirm("测试确认框");
if(flag){
document.write("选择了确认");
}else{
document.write("选择了取消");
}
</script>
</body>
</html>

  6.3 提示框

  提示框提供一个输入框,需点击确认或取消后方可继续。

  如果点击确认返回的值为输入内容,如果点击取消返回null.

  window.prompt("提示信息",默认值),默认值可不指定,不指定为空白。

  

<!DOCTYPE html>
<html>
<head> </head> <body >
<script>
var i = 3;
var info = window.prompt("测试确认框", i);//window可省略
if(info == null){
document.write("没有输入");
}else{
document.write("输入了:" + info);
}
</script>
</body>
</html>

  

七、JavaScript计时

 当需要在某一个固定时间后执行某一段代码或某个函数,可以采用JavaScript提供的计时函数。

 window.setTimeout("执行的代码或函数名",多长时间后执行(单位毫秒ms))  1000ms = 1s (秒)

    

<!DOCTYPE html>
<html>
<head>
<script> function redirect(){
//获取<p>标签中的值,并将其-1,如果为0则跳转页面
if((document.getElementById("p1").innerHTML-=1) == 0){
location.href = "http://www.baidu.com";
}
setTimeout("redirect()",1000);//每隔一秒调用redirect() window.setTimeout()等价
} </script>
</head> <body onload = "redirect()">
<p id = "p1">5</p>
</body>
</html>

上例中页面加载及执行redirect函数,先将<p>内部的值-1,并判断是否大于0,大于0继续定时函数。

定时函数调用redirect函数(也可以使用循环调用)。知道时间为0跳转页面。

设置了定时函数,有时需要将其取消,可以使用clearTimeout()函数即可。

var a = setTimeout(xxxx); clearTimeout(a);

设置定时函数会返回一个对象,将这个对象作为clearTimeout()函数的参数,当执行clearTimeout时

就会取消执行参数对象所代表的定时函数。

<!DOCTYPE html>
<html>
<head>
<script>
var to;
function redirect(){
//获取<p>标签中的值,并将其-1,如果为0则跳转页面
if((document.getElementById("p1").innerHTML-=1) == 0){
location.href = "http://www.baidu.com";
}
to = window.setTimeout("redirect()",1000);//每隔一秒调用redirect()
} function cancel(){
document.getElementById("p1").innerHTML += "停止成功";
window.clearTimeout(to);//停止执行
} </script> </head> <body onload = "redirect()">
<p id = "p1">5</p>
<button onclick ="cancel()">停止跳转</button>
</body>
</html>

 

参考资料:

w3shool JavaScript 

1.4(JavaScript学习笔记) window对象的属性及方法的更多相关文章

  1. JavaScript中的window对象的属性和方法;JavaScript中如何选取文档元素

    一.window对象的属性和方法 ①setTimeout()方法用来实现一个函数在指定毫秒之后运行,该方法返回一个值,这个值可以传递给clearTimeout()用于取消这个函数的执行. ②setIn ...

  2. Javascript学习笔记:对象的属性类型

    在ECMAScript中有两种属性:数据属性和访问器属性 1.数据属性 configurable:表示能否通过delete删除属性从而重新定义属性:或者能否修改属性的特性:或者能否把属性修改为访问器属 ...

  3. JavaScript:学习笔记(8)——对象扩展运算符

    JavaScript:学习笔记(8)——扩展运算符 对象的扩展运算符 扩展运算符是三个点(...).用于取出参数对象的所有可遍历属性,然后拷贝到当前对象之中. 如上图所示,新建了一个对象a,然后通过扩 ...

  4. javascript面向对象(给对象添加属性和方法的方式)

    1.在定义对象时,直接把属性和方法添加 <script type="text/JavaScript"> //给对象直接在定义时添加属性和方法         var g ...

  5. JavaScript学习笔记——BOM_window对象

    javascript浏览器对象模型-windwo对象 BOM Browser Object Model window对象 是BOM中所有对象的核心. 一.属性 1.(位置类型-获得浏览器的位置) IE ...

  6. JavaScript学习笔记-JSON对象

    JSON 是一种用来序列化对象.数组.数值.字符串.布尔值和 null 的语法.它基于 JavaScript 语法,但是又有区别:一些 JavaScript 值不是 JSON,而某些 JSON 不是 ...

  7. JavaScript学习笔记——3.对象

    JavaScript 对象 - 创建对象 1- var obj = new Object(); 2- var obj = {}; *例子:var person = {Name:"Hack&q ...

  8. JavaScript学习笔记之对象

    目录 1.自定义对象 2.Array 3.Boolean 4.Date 5.Math 6.Number 7.String 8.RegExp 9.Function 10.Event 在 JavaScri ...

  9. JavaScript学习笔记:数组reduce()和reduceRight()方法

    很多时候需要累加数组项的得到一个值(比如说求和).如果你碰到一个类似的问题,你想到的方法是什么呢?会不会和我一样,想到的就是使用for或while循环,对数组进行迭代,依次将他们的值加起来.比如: v ...

随机推荐

  1. 读书笔记 ~ Python黑帽子 黑客与渗透测试编程之道

    Python黑帽子  黑客与渗透测试编程之道   <<< 持续更新中>>> 第一章: 设置python 环境 1.python软件包管理工具安装 root@star ...

  2. NYOJ 1022 合纵连横 (并查集)

    题目链接 描述 乱世天下,诸侯割据.每个诸侯王都有一片自己的领土.但是不是所有的诸侯王都是安分守己的,实力强大的诸侯国会设法吞并那些实力弱的,让自己的领土面积不断扩大.而实力弱的诸侯王为了不让自己的领 ...

  3. spring-boot 更换依赖版本

    创建Spring Boot操作步骤如下: 在File菜单里面选择 New > Project,然后选择Spring Initializr 更换版本 或 pom spring-boot-start ...

  4. PHP对象2: 构造函数与析构函数

    当一个对象的所有引用都没有时, 一个对象才消失, 这时才执行析构函数 <?php class firecat{ public $name; function say(){ echo 'I lov ...

  5. 初识smarty

    个人体会(不完全正确):就是smarty就是为了更好的使得php/html结合做出来的一个框架. ,

  6. 工具===激活xmind 8

      [下载jar包]: https://stormxing.oss-cn-beijing.aliyuncs.com/files/XMindCrack.jar   方法: 打开xmind 8 安装目录的 ...

  7. UVA题解二

    UVA题解二 UVA 110 题目描述:输出一个Pascal程序,该程序能读入不多于\(8\)个数,并输出从小到大排好序后的数.注意:该程序只能用读入语句,输出语句,if语句. solution 模仿 ...

  8. log4j生成日志

    Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护进程等:我们也可 ...

  9. IDE按住ctrl 打开单元 无效时 的方法

    一般打开单元无效时 是由于程序有错误,若程序没有错误 可以重新build一下 再试. 若实在不行 就右键---open at cursor

  10. 字节对齐&&sizeof

    转:http://blog.chinaunix.net/uid-722885-id-124878.html 1. sizeof应用在结构上的情况 请看下面的结构: struct MyStruct { ...