BOM部分整理 (章节 8、9)

概览:

一、介绍BOM

在web中,JS的核心对象就是BOM。

1.1 在浏览器中,window对象 == global

所以,你在全局环境下定义的变量,函数都会自动成为window的属性和方法。

  1. var a = 1;
  2. console.log(window.a); //
  3. function fn(){
  4. console.log("window");
  5. }
  6. console.log(window.fn()); //window

tips:通过var声明的变量,无法被delete操作符删除。因为它默认了configurable =false。

直接写且不声明的变量,以及通过window.xx定义的变量都可以通过delete删除。

  1. var a = 1;
  2. console.log(delete a);//false
  3. window.b = 2;
  4. console.log(delete b);//true
  5. c = 3;
  6. console.log(delete c);//true

二、frame和window的关系

每一个frame窗口都有一个window对象,并且他们保存在JS定制的frames数组里,可以通过frames[0]来获取。

每个window对象都有自己的名称,属性为name。

这部分的内容了解就好,只是定义了一些iframe和window之间互相访问的关系。

因为现在开发很少使用iframe了,就是说不时髦了。

三、窗口相关的方法

整理如上,值得注意的几点:

1. 浏览器和屏幕是两个概念,很多同学调用screen方法发现一直都是0,因为你们全屏了!

2.innerWidth/Height同类的方法还有outerWidth/Height,因为实现的效果基本相同,所以用的基本都是inner系列。

3. 本节的重点是定时器部分的内容,建议多加练习。

4. alert这类方法,基本只是在测试时候用了,正常页面谁会搞这个东西给用户看。

三、location对象

对于搜索框的对象操作,是BOM部分非常重要的内容,概览如下:

它既是window的属性,又是document对象的属性。

虽然可以获取到参数,但是拿过来的字符串其实相当不方便,需要自己编写函数进行优化。

  1. function query(){
  2. //去掉问号
  3. var qs = (location.search.length>0?location.search.substring(1):'');
  4.  
  5. // 用一个空对象来接收键值对
  6. var ar
  7. // 看有没有参数,有就按照&来分割,没有的话就返回空数组
  8. var items = qs.length?qs.split("&"):[];//[a=1,b=2]
  9. console.log("items = " + items);
  10. var item = null,
  11. name = null,
  12. i = 0 ,
  13. len = items.length,
  14. value = null;
  15. for(i=0;i<len;i++) {
  16. //再对每一个项按照等号分割
  17. item = items[i].split("=");//[[a,1],[b,2]]
  18. // name = decodeURIComponent(item[0]);
  19. name = item[0];
  20. value = item[1];
  21. // value = decodeURIComponent(item[1]);
  22. if(name.length) {
  23. args[name] = value;
  24. }
  25. }
  26. return args;
  27. }

四、navigator对象

还没有完全的兼容,但是部分功能依旧强大,概览:

4.1 操作浏览器历史记录的方法

在浏览器中就是左上角的前进后退,JS实现了用代码来管理它们。

history对象,它有一些方法,常用的如下:

  1. history.go(-1);//返回上一页
  2. history.go(1);//前进一页
  3. history.go(2);//前进两页
  4. // 也可以不传参数,简写成
  5. history.back();//后退
  6. history.forward();//前进

如果你不希望用户跳转网页后返回上一页,调用:

  1. window.location.replace("地址");
  2. //这样跳转不能通过浏览器的返回键返回到上一级

最后一个方法,location.reload()

不传参数就在缓存中刷新一遍网页
传true就强制要从服务器重新获取网页

五、第八章小结
这章很多方法都过时了,还有很多兼容ie的方法
重要的几点就是:

location对象和history对象

定时器

第九章

第九章真的没啥好看的,有点浪费时间。

浏览器检测就是为了处理兼容性问题。

我只想说 GTMD IE

以上;

BOM部分笔记整理的更多相关文章

  1. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  2. 从0开始学Swift笔记整理(五)

    这是跟在上一篇博文后续内容: --Core Foundation框架 Core Foundation框架是苹果公司提供一套概念来源于Foundation框架,编程接口面向C语言风格的API.虽然在Sw ...

  3. Deep Learning(深度学习)学习笔记整理系列之(五)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  4. 学习ReactNative笔记整理一___JavaScript基础

    学习ReactNative笔记整理一___JavaScript基础 ★★★笔记时间- 2017-1-9 ★★★ 前言: 现在跨平台是一个趋势,这样可以减少开发和维护的成本.第一次看是看的ReactNa ...

  5. Deep Learning(深度学习)学习笔记整理系列之(八)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  6. Deep Learning(深度学习)学习笔记整理系列之(七)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  7. Deep Learning(深度学习)学习笔记整理系列之(六)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  8. Deep Learning(深度学习)学习笔记整理系列之(四)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  9. Deep Learning(深度学习)学习笔记整理系列之(三)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

随机推荐

  1. 【Android Developers Training】 40. 序言:通过NFC共享文件

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  2. vue.js+UEditor集成 [前后端分离项目]

    首先,谈下这篇文章中的前后端所涉及到的技术框架内容. 虽然是后端的管理项目,但整体项目,是采用前后端分离的方式完成,这样做的目的也是产品化的需求: 前端,vue+vuex+vue router+web ...

  3. Android精品源码与技术博文

    Android精品源码android遵循Material Design风格天气源码基于exoplay 自定义播放器 支持直播 1 ExoUserPlayer 基本播放器...几种动画效果Animati ...

  4. VB6之截图

    今天先把主要逻辑写出来,如果有时间就实现一个真正的截图工具. Private Declare Function BitBlt Lib "gdi32" (ByVal hDestDC ...

  5. spring +springmvc+mybatis组合applicationContext.xml文件配置

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  6. python编程快速上手之第3章实践项目参考答案

    1 #!/usr/bin/env python 2 # coding:utf-8 3 # write by mfyang 4 # collatz.py 5 # 从用户读入一个值,并判断这个值是不是一个 ...

  7. Maven-FAQ

    1.Failure to transfer org.apache.maven.plugins:maven-resources-plugin:pom:2.5...: Q: 第一次使用maven+ecli ...

  8. (转)mq经验总结-转

    场景:学习mq相关的知识,发现这是一篇总结性很强的文章,转过来学习学习! 1 mq经验总结 首先了解什么是mq?mq的作用是什么? mq是通讯中间件.他的作用是省去开发人员开发通讯工具的时间,节省开发 ...

  9. (转)linux中项目部署和日志查看

    1 查找进程 ps -ef | grep java   查看所有关于java的进程 root     17540     1  0  2009 ?        01:42:27 /usr/java/ ...

  10. iOS开发实战-卫P嗯上网项目

    写在前面 最近闲来无事,又跟小伙伴搞起.一.键.上.网.的项目,于是这个项目就来了. 很高兴App 已经过审 有兴趣的可以玩玩牛牛数据