再次编辑于20160115

一、window对象

双重角色

  • JS访问浏览器窗口的接口
  • ECAMAscript规定的Global对象

1.全局作用域

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

delete的差别

  • 直接在window对象上定义的属性可以delete,返回true
  • 全局变量不能通过delete操作符删除([configurable] = false),返回false
  • IE<9在使用delete删除window属性时会抛出错误

访问未声明变量的差别

访问未声明的变量会抛出错误,但通过查询window对象可知某个未声明的变量是否存在

oldValue;         // 抛出错误
window.oldValue; // 返回undefined

2.窗口关系和框架(frames)

3.窗口位置

  • IE、Opera、Safari、Chrome:::

    screenLeft、screenTop

  • Firefox、Safari、Chorme:::

    screenX、screenY

跨浏览器取得窗口相对于屏幕左边和上边的位置

var leftPos = (typeof window.screenLeft == "number") ?
window.screenLeft : window.screenX;
var topPos = (typeof window.screenTop == "number") ?
window.screenTop : window.screenY;

1

  • IE、Opera:不含浏览器工具栏,即

    如果 window 对象是最外层对象,而且浏览器窗口紧贴屏幕最上端,则topPos=工具栏高度
  • Firefox、Safari、Chorme:与上相反,含工具栏

2

  • IE、Opera:返回当前frame相对屏幕的坐标
  • Firefox、Safari、Chorme:始终返回页面中每个框架的 top.screenX 和

    top.screenY 值

3

  • 然并卵,以上方法无法实现跨浏览器获取窗口精准坐标值...

移动窗口

moveTo(x, y);  //参数:新位置的x、y坐标
moveBy(x, y); //参数:x、y方向上移动的像素
  • 这两个方法可能会被浏览器禁用,在 Opera 和 IE 7(及更高版本)中默认就

    是禁用的。
  • 不适用于框架,只能对最外层的 window 对象使用。

4.窗口大小(兼容何解?)

跨浏览器取得页面视口的大小

var pageWidth = window.innerWidth,
pageHeight = window.innerHeight;
if (typeof pageWidth != "number"){
if (document.compatMode == "CSS1Compat"){ // 判断当前浏览器采用的渲染方式
pageWidth = document.documentElement.clientWidth;
pageHeight = document.documentElement.clientHeight;
} else {
pageWidth = document.body.clientWidth;
pageHeight = document.body.clientHeight;
}
}

改变窗口大小

resizeTo();
resizeBy();
  • 这两个方法可能会被浏览器禁用,在 Opera 和 IE 7(及更高版本)中默认就

    是禁用的。
  • 不适用于框架,只能对最外层的 window 对象使用。

5.导航和打开窗口

window.open();
// 参数:URL、窗口目标、窗口特性、是否取代历史记录的布尔值
// 返回指向新窗口的引用,可对其调整大小或移动位置
window.close();
// 关闭用window.open()打开的窗口
top.close();
// 关闭弹出窗口自身 wroxWin.close();
alert(wroxWin.closed); // true
// 弹出窗口关闭之后,窗口的引用仍然还在,只可用于检测其 closed 属性

新窗口的opener属性

  • 指向打开它(调用window.open())的原始窗口对象
  • 设为null表示新窗口不需要与原始窗口通信,一旦切断联系,就无法恢复

弹窗屏蔽程序

var blocked = false;
try {
var wroxWin = window.open("http://www.wrox.com", "_blank");
if (wroxWin == null){
blocked = true;
}
} catch (ex){
blocked = true;
}
if (blocked){
alert("The popup was blocked!");
}
  • 浏览器如有内置屏蔽程序阻止弹出窗口,则window.open()返回null
  • 浏览器扩展或其他程序阻止弹出窗口,则window.open()抛出错误

6.超时调用和间歇调用、系统对话框

二、location对象

保存当前文档信息、能将URL解析为独立的片段

window.location == document.location;  // true

1.查询字符串参数

function getQueryStringArgs(){
//取得查询字符串并去掉开头的问号
var qs = (location.search.length > 0 ? location.search.substring(1) : ""),
//保存数据的对象
args = {},
//取得每一项
items = qs.length ? qs.split("&") : [],
item = null,
name = null,
value = null,
//在 for 循环中使用
i = 0,
len = items.length;
//逐个将每一项添加到 args 对象中
for (i=0; i < len; i++){
item = items[i].split("=");
name = decodeURIComponent(item[0]);
value = decodeURIComponent(item[1]);
if (name.length) {
args[name] = value;
}
}
return args;
}

2.位置操作

  • 设置location.href(修改location的其他属性也可以改变当前页面,生成历史记录,除hash外页面都会以新URL重新加载)
  • location.replace("newHref") 位置改变,但不会生成历史记录,并不可后退
  • location.reload() 若页面未改变,则从浏览器缓存中重载,要强制从服务器重载则使用location.reload(true)。由于网络延迟或系统资源因素,reload()之后的代码可能不会执行,因此最好将reload()放在代码最后一行

三、 navigator对象

可用于检测浏览器类型

检测插件

  • 非IE浏览器-plugins数组(refresh()方法)
  • IE浏览器-ActiveXObject类型,COM对象标识符

两种检测插件的方法差别太大,典型做法为针对每个插件分别创建检测函数

//检测插件(在 IE 中无效)
function hasPlugin(name){
name = name.toLowerCase();
for (var i=0; i < navigator.plugins.length; i++){
if (navigator. plugins [i].name.toLowerCase().indexOf(name) > -1){
return true;
}
}
return false;
}
//检测 IE 中的插件
function hasIEPlugin(name){
try {
new ActiveXObject(name);
return true;
} catch (ex){
return false;
}
}
//检测所有浏览器中的 Flash
function hasFlash(){
var result = hasPlugin("Flash");
if (!result){
result = hasIEPlugin("ShockwaveFlash.ShockwaveFlash");
}
return result;
}
//检测所有浏览器中的 QuickTime
function hasQuickTime(){
var result = hasPlugin("QuickTime");
if (!result){
result = hasIEPlugin("QuickTime.QuickTime");
}
return result;
}

注册处理程序

(不理解)

四、screen对象

五、history对象

开发人员无法得知用户浏览过的URL,但可以在不知道历史URL的情况下实现前进后退

go();  //参数:整数值、字符串,传递字符串会跳转到历史中包含该字符串的最近的位置
back();
forward();

length属性

BOM(JavaScript高程笔记)的更多相关文章

  1. JAVASCRIPT高程笔记-------第八章 浏览器BOM对象

    8.1 window对象--表示一个浏览器的实例 在全局作用域中声明的任何变量.函数都会变成window对象的属性和方法,与之直接定义window对象的属性的区别是   window.xxx 可以通过 ...

  2. JAVASCRIPT高程笔记-------第五章 引用类型

    一.Object类型 1.1创建方式 ①new关键字 : var person = new Oject(); ②给定直接量: var person = { name : "zhangsan& ...

  3. DOM(JavaScript高程笔记)

    一.节点层次 1.Node类型 if (someNode.nodeType == 1){ // 适用于所有浏览器 alert("Node is an element."); } N ...

  4. 函数表达式(JavaScript高程笔记)

    函数声明 特点:函数声明提升(执行代码之前解析器会先读取函数声明,并使其在执行任何代码之前可用,意味着可以把函数声明放在调用语句之后) function functionName(arg0,arg1) ...

  5. javaScript高程笔记--最佳实践

    1.可维护性 <1>什么是可维护的代码 (1)可理解性 (2)直观性 (3)可适应性 (4)可扩展性 (5)可调试性 <2>代码约定 (1)可读性---适当的进行注释[函数和方 ...

  6. javascript高程笔记:逻辑与和逻辑或

    逻辑与和或 逻辑与 当 && 前后两个操作数都是布尔值,无可厚非,同时为true才为true.与其他强类型语言不同的是,javascript逻辑与前后的操作数可以应用于任何类型. 而且 ...

  7. JAVASCRIPT高程笔记-------JSON与AJAX

    json对象——语法 简单值:与JS相同语法,可以是字符串,数值,布尔值,null:但不支持undefined 对象: 复杂数据类型,表示一组有序的键值对,键值对的值可以是简单数据,也可以是复杂数据 ...

  8. JAVASCRIPT高程笔记-------第十章 DOM对象

    10.1.1 node类型 --除IE外 所有浏览器都可以访问到这个类型 :JS中所有的节点类型都继承自Node类型 nodeName 与nodeValue  如果是一个元素 那么nodeName中保 ...

  9. javascript高程笔记-------第四章 变量、作用域和内存问题

    首先JavaScript中的变量分为基本类型和引用类型. 基本类型就是保存在栈内存中的简单数据段,而引用类型指的是那些保存在堆内存中的对象. 1.参数传递 javascript中所有参数的传递都是值传 ...

随机推荐

  1. cad2019卸载/安装失败/如何彻底卸载清除干净cad2019注册表和文件的方法

    cad2019提示安装未完成,某些产品无法安装该怎样解决呢?一些朋友在win7或者win10系统下安装cad2019失败提示cad2019安装未完成,某些产品无法安装,也有时候想重新安装cad2019 ...

  2. JSX 和 template 随想

    就目前而言,我用到的前端页面开发框架主要有两种:以JSX为主的react和以template为主的vue. 虽然这两种方式各有千秋,但我其实更偏爱template多一些.为什么? 相较于灵活的JSX, ...

  3. CSS之浏览器默认样式问题

    今天自己写css样式时,其中用到了<ul>标签,设置了一系列效果后运行,发现位置与设置有出入.chrome上打开检查项,发现<ul>标签的styles底部多了以下一段: ul, ...

  4. Java调用HTTPS接口的证书配置

    首先需要获取到证书文件. 然后,将证书导入到本地: keytool -import -noprompt -trustcacerts -alias <AliasName> -file < ...

  5. 安装rlwrap方便sqlplus使用

    rlwrap包 这是一个为方便使用SQL*PLUS的技巧,为了能像在DOS命令窗口中那样运行SQL*Plus,使用向上.向下键来跳回之前已经执行过的SQL语句. 需要在Linux上安装rlwrap包, ...

  6. [Leetcode]134.加油站

    这一题是贪心不是模拟 是贪心不是模拟 是贪心不是模拟! 如果用模拟的做法会比较慢,也失去了做这一题的趣味了. 模拟的方法很简单,就是每一个加油站都做起点模拟一遍,试一下能不能完成一圈,能完成一圈就保存 ...

  7. 剑指offer三从头到尾打印链表

    一.题目: 输入一个链表,从尾到头打印链表每个节点的值. 二.解题方法: 方法一:采用递归的方式实现 方法二:借助堆栈的“后进先出”实现 import java.util.ArrayList; imp ...

  8. 图片训练:使用卷积神经网络(CNN)识别手写数字

    这篇文章中,我们将使用CNN构建一个Tensorflow.js模型来分辨手写的数字.首先,我们通过使之“查看”数以千计的数字图片以及他们对应的标识来训练分辨器.然后我们再通过此模型从未“见到”过的测试 ...

  9. Android内存管理篇 - 从updateOomAdjLocked看lowmemorykiller之外的Android进程回收机制

    提起android的进程回收机制,大家所熟知的是Android的lowmemroykiller的机制.当系统可用内存低于某个阀值时,即会杀死这个阀值对应的Adj值的所有应用.但是本篇文章并为是要介绍L ...

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

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