隔了一段时间,现在开始看第8章。

第8章:BOM

  BOM提供了很多对象,用于访问浏览器的功能。BOM的核心对象是window,它表示浏览器的一个实例

  window对象是通过javascript访问浏览器窗口的一个接口,又是ECMAScript中的Global对象。

  所有在全局作用域声明的变量、函数都是window对象的属性和方法。

  1. 窗口关系,框架

    每个框架都有window对象,并在frames集合中

    每个window对象都有name属性,其中包含框架名称

    top对象始终指向最高(最外)层框架,也就是浏览器窗口

    parent对象始终指向当前框架的直接上层框架

    self对象始终指向window对象

  2. 窗口位置、视口大小

var leftPos = (typeof window.screenLeft == "number") ?   window.screenLeft : window.screenX;
var topPos = (typeof window.screenTop == "number") ? window.screenTop : window.screenY; var pageWidth = document.compatMode == "CSS1Compat" ? document.documentElement.clientWidth : document.body.clientWidth;
var pageHeight = document.compatMode == "CSS1Compat" ? document.documentElement.clientHeight : document.body.clientHeight;

  3. 打开新窗口  

function openNewWindow(){
var win = window.open('http://www.a.com/', 'aWindow', 'width=300,height=300,left=10,top=10');
win.resizeTo(500,500);
win.moveTo(100,100);
//win.close();
//win.opener = null;
}

  4. 间隔调用 超时调用

//1秒后执行 只执行一次
var timeoutId = setTimeout(function() {
alert("Hello world!");
}, 1000);
//clearTimeout(timeoutId); //每间隔1秒执行一次,直到取消
var timer = setInterval(function() {
alert("Hello world!");
}, 1000);
//clearInterval(timer); //兼容 requestAnimationFrame 用法和setTimeout类似
if (!window.requestAnimationFrame) {
window.requestAnimationFrame = (window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.msRequestAnimationFrame ||
window.oRequestAnimationFrame ||
function (callback) {
return window.setTimeout(callback, 17);
});
}
if (!window.cancelRequestAnimationFrame) {
window.cancelRequestAnimationFrame = (window.cancelAnimationFrame ||
window.webkitCancelRequestAnimationFrame ||
window.mozCancelRequestAnimationFrame ||
window.msCancelRequestAnimationFrame ||
window.oCancelRequestAnimationFrame ||
window.clearTimeout);
}

  5. 系统对话框

//alert
alert('Hello world!');
//confirm
if(confirm('are you ok?')){
//yes
}else{
//no
}
//prompt
var result = prompt("What is your name? ", "");
if(result !== null) {
alert("Welcome, " + result);
}

  6. location对象

// http://www.a.com:1234/test.html?k1=v1&k2=v2#part2

location.hash	//URL的锚部分 ( #part2 )
location.hash='#hash' //不会重新加载
location.host //URL的主机名称和端口号 location.href //完整URL location.pathname //URL的路径部分 ( /test.html )
location.port //URL的端口部分 ( 1234 )
location.protocol //URL的协议 ( http ) location.search //URL的查询部分 ( ?k1=v1&k2=v2 ) location.assign //加载一个新的文档
window.location.assign("http://www.a.com")
window.location='http://www.a.com/';
location.href='http://www.a.com/';
location.reload //重新加载当前文档
location.reload() //重新加载 可能重缓存加载
location.reload(true) //重服务器重新加载
location.replace //用一个新文档取代当前文档
location.replace('www.a.com') //不会留下历史记录 不能点击后退返回上一个页面 //转到新URL
location.assign('www.a.com')
window.location='www.a.com';
location.href='www.a.com';

  7. navigator对象 

navigator.appName //名称
navigator.appVersion //版本
navigator.appCodeName //代码名称
navigator.platform //系统平台
navigator.cookieEnabled //是否启用cookies
navigator.userAgent //浏览器用户代理头的值(只读的字符串) if(/Android|Windows Phone|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)){
location.href="http://www.a.com/";
}else if(/iPad/i.test(navigator.userAgent)){
location.href="http://www.b.com/"
}else{
location.href="http://www.c.com/"
}

  8. history对象

back() //加载历史列表中的前一个URL(如果存在)等价于点击后退按钮或调用 history.go(-1)
forward() //加载历史列表中的下一个URL 等价于点击前进按钮或调用 history.go(1)
go() //加载历史列表中的某个具体的页面 //后退一页
history.back()
history.go(-1)
//前进一页
history.forward()
history.go(1)

第9章:客户端检测

   检测web客户端的方式很多,不到万不得已不要使用客户端检测,有更通用的方法就使用更通用的方法。

   最常用的客户端检测形式是能力检测(特性检测),判断浏览器是否支持某种特性。

//基本检测格式
if(object.property){
//use object.property
} //ie判断
var isIE = !!("ActiveXObject" in window);
var isIE6 = !document.addEventListener && !window.XMLHttpRequest;
var isIE7 = isIE && !!window.XMLHttpRequest && !document.documentMode;
var isIE8 = isIE && !document.addEventListener && !!document.documentMode; if( isIE6 ) alert('你使用的是ie6浏览器')
if( isIE7 ) alert('你使用的是ie7浏览器')
if( isIE8 ) alert('你使用的是ie8浏览器')

   在可能的情况下,尽可能使用 typeof 来检测。

   用户代理检测包含大量与浏览器有关的信息。 

var ua = navigator.userAgent;
if(/Android|Windows Phone|webOS|iPhone|iPod|BlackBerry/i.test(ua)){
location.href="http://www.a.com/";
}else if(/iPad/i.test(ua)){
location.href="http://www.b.com/"
}else{
location.href="http://www.c.com/"
}

  第8章主要介绍了浏览器的window对象,window对象下的各种方法、navigator对象history对象。第9章介绍怎样检查客户端,在平常为了兼容一般都要做这样的检测。根据浏览器是否支持某个特性来检测,根据浏览器的navigator.userAgent(用户代理信息)检测。

  

  

读书时间《JavaScript高级程序设计》四:BOM,客户端检测的更多相关文章

  1. 读书笔记 - javascript 高级程序设计 - 第一章 简介

      第一章 简介   诞生时间 1995 最初用途 客服端验证 第一版标准 注意是标准 1997年 Ecma-262  一个完整的js实现由三部分组成 ECMAScript DOM 文档对象模型 BO ...

  2. 读书笔记-JavaScript高级程序设计(1)

    1.组合继承 (JavaScript 中最常用的继承模式 ) (position: page168) (书中定义了两个变量名 SuperType   SubType  乍一看 感觉不太能区分,我将改为 ...

  3. 读书笔记 - javascript 高级程序设计 - 第二章 在Html中使用JavaScript

    1 <script>的6个属性 async  立即下载当前script标签的外部脚本 但不能影响别的 charset 没用了 defer  文档显示之后再执行脚本,只对外部脚本有效 lan ...

  4. JavaScript高级程序设计(四): 关键字With的使用

    一.关键字with 1.含义    with 语句可以方便地用来引用某个特定对象中已有的属性,但是不能用来给对象添加属性.要给对象创建新的属性,必须明确地引用该对象.   简单的说,with为一个或一 ...

  5. javascript 高级程序设计 四

    新的一天开始,让我们伴随者轻快的心情,开始今天的笔记 1.操作符: (1): *./.-在ECMAScript中操作的时候,如果遇到有一个操作值不是数值型(Number),那么就会在后台调用numbe ...

  6. 读书时间《JavaScript高级程序设计》一:基础篇

    第一次看了<JavaScript高级程序设计>第二版,那时见到手上的书,第一感觉真是好厚的一本书啊.现在再次回顾一下,看的是<JavaScript高级程序设计>第三版,并记录一 ...

  7. 《JavaScript高级程序设计》读书笔记--前言

    起因 web编程过程使用javascript时感觉很吃力,效率很低.根本原因在于对javascript整个知识体系不熟,看来需要找些书脑补一下,同时欢迎众网友监督. 大神推荐书籍 看了博客大神们推荐的 ...

  8. JavaScript高级程序设计学习(四)之引用类型

    在javascript中也是有引用类型的,java同样如此. javascript常见也比较常用的引用类型就熟Object和Array. 一个对象和一个数组,这个在前后端分离开发中也用的最多.比如aj ...

  9. 读书笔记(05) - 事件 - JavaScript高级程序设计

    HTML依托于JavaScript来实现用户与WEB网页之间的动态交互,接收用户操作并做出相应的反馈,而事件在此间则充当桥梁的重要角色. 日常开发中,经常会为某个元素绑定一个事件,编写相应的业务逻辑, ...

  10. 《Javascript高级程序设计》阅读记录(二):第四章

    这个系列之前文字地址:http://www.cnblogs.com/qixinbo/p/6984374.html 这个系列,我会把阅读<Javascript高级程序设计>之后,感觉讲的比较 ...

随机推荐

  1. 2014-5-22 java.lang.OutOfMemoryError: Java heap space的一次诊断

    收到消息某系统一个节点因为内存溢出而宕机.系统的中间件是weblogic.数据库的oracle. 1. 先用IBM  HeapAnalyzer分析内存溢出时的dump文件,找到占用内存最多的请求,然后 ...

  2. MyEclipse导入主题文件epf后xml及jsp等页面中点击标签之后显示灰白

    MyEclipse导入主题文件epf后xml及jsp等页面中点击标签之后显示灰白,症状例如以下: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvVVAxOT ...

  3. Burp Suite抓包、截包和改包

    Burp Suite..呵呵.. 听说Burp Suite是能够监測.截取.改动我们訪问web应用的数据包,这么牛X? 条件:本地网络使用代理.由Burp Suite来代理.也就是说,每一个流出外网的 ...

  4. HDU 3217 Health(状压DP)

    Problem Description Unfortunately YY gets ill, but he does not want to go to hospital. His girlfrien ...

  5. MBR格式无法识别2T以上的硬盘的问题

    早上有人打电话说四块2T的sata 硬盘做了raid 5之后安装window server 2012的时候,无法创建分区,安装完系统后无法给剩余的硬盘创建分区,刚开始的时候我还以为是别人分区的数量问题 ...

  6. C++基础学习教程(八)

    转载请注明出处:http://blog.csdn.net/suool/article/details/38300117 引入 在进行下一步的学习之前,我们须要厘清几个概念. RAII 首先介绍一个编程 ...

  7. 修ecshop品牌筛选以LOGO图片形式显示

    如何实现商品列表页属性筛选区品牌筛选以LOGO形式展示,最模板总结ecshop/'>ecshop教程入下: 1.修改 category.php 文件,将(大概215行) $sql = " ...

  8. HUNNU11351:Pythagoras's Revenge

    http://acm.hunnu.edu.cn/online/?action=problem&type=show&id=11351&courseid=0 Problem des ...

  9. u-boot: Error: Can&#39;t overwrite &quot;ethaddr&quot;

    When try to execute following command, It reports error as following: --->8--- U-Boot> setenv ...

  10. PHP 类属性 类静态变量的访问

    php的类属性其实有两种,一种是类常量,一种是类静态变量.两种容易引起混淆. 如同静态类方法和类实例方法一样,静态类属性和实例属性不能重定义(同名),但静态属性可以和类常量同名. <?php c ...