JavaScript 第二章 使用window对象

 

JavaScript 第一章 基本语法

JavaScript 第三章 DOM编程基础 使用document对象

JavaScript 第二章 使用window对象


1、技术目标

  • window对象的open()方法打开并定制窗口
  • Date对象处理日期
  • window对象的setInterval()函数设置定时器
  • window对象的setTimeout()函数设置延时器
  • history、location对象的使用


2、window对象的常用属性、方法、事件

常用属性:

 
名称 说明
screen 有关客户端的屏幕和显示性能的信息
history 有关客户访问过的URL的信息
location 有关当前 URL 的信息



常用方法:

名称 说明
prompt 显示可提示用户输入的对话框
alert 显示带有一个提示信息和一个确定按钮的警示框
confirm 显示一个带有提示信息、确定和取消按钮的对话框
close 关闭浏览器窗口
open 打开一个新的浏览器窗口,加载给定 URL 所指定的文档
setTimeout 在指定的毫秒数后调用函数或计算表达式
setInterval 按照指定的周期(以毫秒计)来调用函数或表达式



常用事件:

名称 说明
onload 一个页面或一幅图像完成加载
onmouseover 鼠标移到某元素之上
onclick 当用户单击某个对象时调用的事件句柄
onkeydown 某个键盘按键被按下时
onchange 域的内容被改



3、使用confirm()方法

confirm方法的返回值为true或者false,当你点"确定"按钮时返回true,
否则false

示例代码:
<script language="javascript" type="text/javascript">
    var flag = confirm ("确认要删除此条信息吗?");
    if(flag == true){
        alert("删除成功!");
    }else{
        alert("你取消了删除");
    }
</script>

4、使用open()方法

open方法可打开一个浏览器窗口并在窗口中加载你指定的页面,语法为:
window.open("弹出窗口的url","窗口名称","窗口特征“)


窗口特征有如下可选设置:

名称
说明
height、width                      
窗口文档显示区的高度、宽度,以像素计
left、top 窗口的x坐标、y坐标,以像素计
toolbar=yes | no  |1 | 0 是否显示浏览器的工具栏,黙认是yes
scrollbars=yes | no  |1 | 0 是否显示滚动条,黙认是yes
location=yes | no  |1 | 0 是否显示地址地段,黙认是yes
status=yes | no  |1 | 0 是否添加状态栏,黙认是yes
menubar=yes | no  |1 | 0 是否显示菜单栏,黙认是yes
resizable=yes | no  |1 | 0 窗口是否可调节尺寸,黙认是yes
titlebar=yes | no  |1 | 0 是否显示标题栏,黙认是yes
fullscreen=yes | no  |1 | 0
是否使用全屏模式显示浏览器,黙认是no,处于全屏模式的窗口必须同时处于剧院模式



5、window对象的属性、方法综合应用

  • 使用winow对象完成如下功能:
  • 弹出窗口
  • 弹出固定大小且无菜单栏的窗口
  • 当前页面全屏显示,使用快捷键Alt + F4退出全屏
  • 弹出确认消息框
  • 关闭窗口

示例代码:
<!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=gb2312" />
<title>window对象演示例子</title>
<script type="text/javascript">
/*弹出窗口*/
function open_adv(){
    window.open("adv.html");   
}
/*弹出固定大小窗口,并且无菜单栏等*/
function open_fix_adv(){
    window.open("adv.html", "", "height=380,width=320,toolbar=0,scrollbars=0,location=0,status=0,menubar=0,resizable=0");   
}
/*全屏显示*/
function fullscreen(){
    window.open("plan.html","","fullscreen=yes");
}
/*弹出确认消息框*/
function confirm_msg(){
    if(confirm("你相信自己是最棒的吗?")){
       alert("有信心必定会赢,没信心一定会输!");
    }
}
/*关闭窗口*/
function close_plan(){
    window.close();   
}
</script>
</head>
<body>
<form action="" method="post">
  <p><input name="open1" type="button" value="弹出窗口"
          onclick="open_adv()" /></p>
  <p><input name="open2" type="button" value="弹出固定大小窗口,且无菜单栏等"
          onclick="open_fix_adv()"/></p>
  <p><input name="full" type="button" value="全屏显示"
          onclick="fullscreen()"/></p>
  <p><input name="con" type="button" value="打开确认窗口" 
          onclick="confirm_msg()"/></p>
  <p><input name="c" type="button" value="关闭窗口"
          onclick="close_plan()"/></p>
</form>
</body>
</html>

6、关于匿名函数

顾名思义,匿名函数就是没有函数名的函数,其语法如下:

语法1, 直接定义:
    (function(){JavaScript代码;}())
语法1,示例:
<input type="button" value="Test"
onclick="(function(){alert('Test');}()); " />

语法2, 事件处理中使用匿名函数:
    事件名 = function(){…};
语法2,示例:
<input id="testId" type="button" value="Test" />
<script type="text/javascript">
    document.getElementById("testId").onclick = function(){
        alert("Test");

    };
</script>

7、window对象的onload事件

onload事件在HTML文档加载完成后触发 ,如,
<body onload="事件处理函数();...">...</body>
或者
<script type="text/javascript">
    //设置onload事件处理函数
    window.onload = function(){
        ...
    };
</script>

8、Date对象

Date 对象存储的日期为自 1970年1月1日00:00:00 以来的毫秒数
创建Date对象有如下语法,

语法1: var 对象名 = new Date("日期字符串");
语法1说明:
    日期字符串的格式为,"MM DD, YYYY, hh:mm:ss",
    无日期字符串表示当前日期

语法2: var 对象名 = new Date(毫秒数);
语法2说明:
    参数为自1970年1月1日00:00:00以来的毫秒数
   
语法3: var 对象名 = new Date(年, 月, 日, 时, 分, 秒, 毫秒);
语法3说明:时、分、秒、毫秒可选

Date对象的常用方法有get开头的方法和set开头的方法,
get方法用于获取日期中的时间信息,set方法用于设置,如下:

Date方法分组    说 明
setXxx             这些方法用于设置时间和日期值
getXxx             这些方法用于获取时间和日期值

部分get或set方法说明:

值(指上表中的Xxx) 整数
Seconds 和 Minutes 0 至 59
Hours 0 至 23
Day 0 至 6(星期几)
Date 1 至 31(月份中的天数)
Months 0 至 11(一月至十二月)


比如:getDay(),返回值为0 ~ 6,0表示星期天

9、延时器与定时器

设置延时器: var 延时器对象 = setTimeout("函数()", 间隔时间);
延时器说明:
时间间隔的单位是毫秒,在一定的时间间隔后执行函数,执行后
延时器停止执行(只执行1次),好比是空调的"定时关闭"功能

设置定时器: var 定时器对象 = setInterval("函数()", 间隔时间);
定时器说明:
时间间隔的单位是毫秒,按时间间隔定时执行函数(反复执行)

关闭定时器或延时器:
clearTimeout(定时器/延时器对象);

10、使用Date对象与定时器制作动态时钟效果

示例代码:
<!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=gb2312" />
<title>时钟特效</title>
<script type="text/javascript">
function disptime(){

    var today = new Date(); //获得当前日期
    var hh = today.getHours();  //获得小时、分钟、秒
    var mm = today.getMinutes();
    var ss = today.getSeconds();
   
    /*设置div的内容为当前时间*/
    document.getElementById("myclock").innerHTML =
    "<h1>现在是:"+hh+":"+mm+":"+ss+"<h1>";
}

var myTime;
function startTime(){
    //使用setInterval()每间隔指定毫秒后调用disptime()
    myTime = setInterval("disptime()", 1000);
}
/*关闭定时器*/
function stopTime(){
    clearTimeout(myTime);
}
</script>
</head>
<body onload="disptime();">
<div id="myclock"></div>
<input type="button" value=" 开始"  onclick="startTime();" />&nbsp;
<input type="button" value=" 结束 " onclick="stopTime();" />
</body>
</html>

12、制作12小时制时钟

  • 使用Date对象以及定时器,实现步骤如下:
  • getFullYear()获得当前年份
  • getMonth() + 1 获得当前月份
  • getDate()获得当前日期
  • 根据getHours()获得的小时,使用if语句判断当前时间是否大于12
  • getDay()获取当前表示星期几的数字,然后使用switch设置当前星期几


示例代码:
<!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=gb2312" />
<title>制作12小时进制的时钟</title>
<script type="text/javascript">
function clock12h(){
   
    var today = new Date(); //获得当前时间
    //获得年、月、日,Date()函数中的月份是从0-11计算
    var year = today.getFullYear(); 
    var month = today.getMonth()+1;
    var date = today.getDate();
    var hour = today.getHours();  //获得小时、分钟、秒
    var minute = today.getMinutes();
    var second = today.getSeconds();

    var apm="AM"; //默认显示上午: AM
    if (hour>12)
{ //按12小时制显示
       hour=hour-12;
       apm="PM"  ;
    }
    var weekday = 0;
    switch(today.getDay()){
        case 0:
            weekday = "星期日";
            break;
        case 1:
            weekday = "星期一";
            break;
        case 2:
            weekday = "星期二";
            break;
        case 3:
            weekday = "星期三";
            break;
        case 4:
            weekday = "星期四";
            break;
        case 5:
            weekday = "星期五";
            break;
        case 6:
            weekday = "星期六";
            break;
    }
   
    /*设置div的内容为当前时间*/
    document.getElementById("myclock").innerHTML="<h2>你好,欢迎访问本商城!</h2><h2>"+year+"年     
           "+month+"月"+date+"日&nbsp;"+hour+":"+minute+":"+second+"&nbsp;"+apm+"&nbsp;"+weekday+"</h2>";
}

/*使用setInterval()每间隔指定毫秒后调用clock12h()*/
var myTime = setInterval("clock12h()",1000);

</script>
</head>
<body>
<div id="myclock"></div>
</body>
</html>

13、history对象

history对象提供最近浏览过的URL列表以及逐个返回访问过的页面的方法

history对象的方法:
    back()                 加载前一个URL
    forward()             加载下一个URL
    go(URL顺序号)      按顺序号加载URL,比如,go(-1)和back效果一样,
                              go(1)和forward效果一样

14、location对象


location对象提供当前页面的URL信息,还可刷新(重新加载)当前页面或指定加载
新的也没

location对象的属性:
    host            设置或返回主机名和当前URL的端口号
    hostname    设置或返回当前URL的主机名
    href            设置或返回完整的URL,通过该属性可指定当前窗口
                      加载新的页面

location对象的方法:
    reload()              刷新(重新加载)当前页面
    replace("URL")    用新的页面替换当前页面

15、location和history对象的使用

功能描述:

  • 主页面使用href实现跳转和刷新本页
  • 详情页面实现返回主页面功能


主页面,示例代码:
<!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=gb2312" />
<title>主页面</title>
<style type="text/css">
body{
    margin-top: 0px;
    margin-right: auto;
    margin-bottom: 0px;
    margin-left: auto;
    text-align:center;
}
</style>
</head>
<body>
<img src="images/flow.jpg" alt="鲜花" /><br />
<a href="javascript:location.href='flower.html' ">查看鲜花详情</a> 
<a href="javascript:location.reload() ">刷新本页</a>
</body>
</html>

详情页面,示例代码
<!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=gb2312" />
<title>鲜花详情页面</title>
<style type="text/css">
body{
    font-size:12px;
    line-height:20px;
    margin-top: 0px;
    margin-right: 10px;
    margin-bottom: 0px;
    margin-left: 10px;
}
p{font-size:14px;
  font-weight:bold;
}
</style>
</head>
<body>
<img src="images/flow.jpg" />
<p style="text-align:right;">
<a href="javascript:history.back() ">返回主页面</a>
</p>
<p>服务提示:</p>非节日期间,可指定时间段送达;并且允许指定送达收货人的最快时间为两小时;节日期间,只保证当日送达。<br />
配送范围:<br />
   鲜花配送范围:北京、上海、深圳、天津、广州、重庆等各大中城市。<br />
   蛋糕、果篮配送范围:全国大中城市。<br />
   绿植配送范围:仅限于直辖市,省会城市市区。<br />
   更多详细的配送区域与相应配送费率请点击这里!<br />
配送方式:<br />
   专业鲜花、蛋糕礼品速递机构,送货上门。 <br />
服务时间:<br />
   全年365天,节假日不休息,24小时接单; 每日送花时间:8:00-20:00。<br />
   其它时间送花酌情加收10-30服务费用。 <br />
替换原则:<br />由于地域或季节的限制,需要更换主花材时,我们将电话向订货人提出更换建议,假如在有效配送时间内得不到订货人的确认,我们将采用同等价值或相同寓意的花材代替。实际送花以图片为参考,以商品规格文字说明为主。鲜花为手工做品,实际花束可能会与图示有些出入,但我们保证鲜花的主花材品种、新鲜程度、数量、颜色与说明一致。<br />
</body>
</html>

16、总结:

  • window对象有哪些常用的方法及其含义?
  • Date对象有哪些方法?
  • setTimeout()方法与setInterval()方法的区别?
  • 事件onload和onclick的用法
  • location和history在什么情况下使用?

17、浏览器对象模型

window对象是根对象,其下属还有很多其他对象,如下图:





JavaScript 第一章 基本语法

JavaScript 第三章 DOM编程基础 使用document对象

 

你可能感兴趣的:(JavaScript,html,应用服务器,浏览器,XHTML)