Window 浏览器:

- location:地址
- history:历史
- Document:文档
- screen:窗口
- navigator:帮助

> 1.外部对象就是浏览器提供的API -- **BOM**
> 2.这些对象由w3c规定,由浏览器开发者设计并开发
> 3.这些对象分为2部分,其中BOM包含了DOM
> 4.我们可以通过js访问这些对象

# 外部对象

> BOM (Browser Object Model)
    浏览器对象模型,用来访问和操纵浏览器窗口,是JavaScript有能力与浏览器对话。
> DOM (Document Object Model)
    文档对象模型,用来操作文档。

##1.对话框
- alert(str)
    - 提示对话框,显示str字符串的内容
- confirm(str)
    - 确认对话框,显示str字符串的内容
    - 按"确定"按钮返回true,其他操作返回false

>案例
    
    //调用window对象的属性或方法,可以省略"window."
    //1.弹出框
        //1)弹出框
        function f1(){
            alert("你好,小俊子");
        }
        //2)确认框
        function f2(){
            var v = confirm("你吃了吗?");
            //点击确定返回true,否则返回false
            console.log(v);
        }
        //3)输入框
        function f3(){
            var p = prompt("你吃的什么?");
            //点击取消返回null
            console.log(p);
        }

## 2. 定时器
- 多用于网页动态时钟,制作倒计时,跑马灯效果
- 周期性时钟
    - 以一定的间隔执行代码,循环往复
    - setInterval(exp,time);
    - 返回已经启动的定时器对象
- 停止启动的定时器
    - clearInterval(tID) 
    - tID:启动的定时器对象
- 一次性时钟
    - 在一个设定的时间间隔之后来执行代码,而不是在函数被调用后执行
    - setTimeout(exp,time);
- 停止启动的定时器
    - clearTimeout(tID) 
    - tID:启动的定时器对象

> 案例

  1. 1)周期性定时器
  2. //每隔N毫秒执行一次函数,反复执行,直到达到停止条件位置。
  3. function f4(){
  4. var n = 5;
  5. //启动定时器,返回定时器的ID,用来停止定时器
  6. var id = setInterval(function(){
  7. console.log(n);
  8.  
  9. switch(n%4){
  10. case 0: btn1();break;
  11. case 3: btn2();break;
  12. case 2: btn3();break;
  13. case 1: btn4();break;
  14.  
  15. default: ;
  16. }
  17. n++;
  18. },100);
  19. //启动定时器就相当于启动了一个支线程,当前方法f4相当于主线程。
  20. //2个线程并发执行,不互相等待,
  21. //因此主线程在启动完支线程后立刻向下执行,而支线程却需要在1秒后才执行
  22. console.log("蹦");
  23. }
  24.  
  25. 2)一次性定时器
  26. //推迟N毫秒执行一次函数,执行完之后,自动停止,
  27. //也可以在未执行前手动停止
  28. var id;
  29. function f5(){
  30. //启动定时器,若想在未执行定时器前就将它停止,需要使用id
  31. id = setTimeout(function(){
  32. console.log("叮叮叮");
  33. f4();
  34. },3000);
  35. }
  36.  
  37. function f6(){
  38. //若定时器已经执行,则取消无效; 若定时器还未执行,则可以取消
  39. clearTimeout(id);
  40. console.log("已停止!");
  41. }

## 3. 常用属性
- screen 对象
    - 包含有关客户端显示屏幕的信息
    - 常用于获取屏幕的分辨率和色彩
    - 常用属性:
        - width height
        - availWidth availHeight

-  history对象
    -  包含用户访问过的URL
        -  length属性:浏览器历史列表中的URL数量
    - 方法:
        - back();
        - forwird();
- location对象
    - 包含有关当前URL的信息
        - 常用于获取和改变当前浏览的网址
    - href属性:当前窗口正在浏览的网址地址
    - 方法
        - reload():重新载入当前网址,相当于刷新    
- navigator 对象
    - 包含有关浏览器的信息
        - 常用于获取客户端浏览器和操作系统的信息

> 案例

  1. //Location对象
  2. function f1(){
  3. var b = confirm("你真的要离开我吗?");
  4. if(b){
  5. location.href = "http://www.tmooc.cn";
  6. }
  7.  
  8. }
  9. //刷新页面
  10. function f2(){
  11. location.reload();
  12. }
  13. //screen 对象: 获取屏幕宽高
  14. function f3(){
  15. console.log(screen.width);
  16. console.log(screen.height);
  17. console.log(screen.availWidth);
  18. console.log(screen.availHeight);
  19. }
  20. //history对象
  21. function f4(){
  22. history.forward();
  23. }
  24. //navigator对象
  25. function f5(){
  26. console.log(navigator.userAgent);
  27. }

## DOM
### DOM操作
- 查找节点
- 读取节点信息
- 修改节点信息
- 创建节点信息
- 删除节点

### 读取、修改
- 节点信息
    - nodeName:节点名称
    - nodeType:节点类型
- (1) 读取节点
    - 读取节点的名称,类型
            
            <p id="p1">1.<b>读写</b>节点</p>
            <p id="p2">2.<b>查询</b>节点</p>
            <p id="p3">3.<b>增删</b>节点</p>

var p1 = document.getElementById("p1");
            console.log(p1.nodeName);
            console.log(p1.nodeType);
    - 读写节点的内容
         - 双标签中间的文本叫内容,任何双标签都有内容
         - innerHTML:包括子标签信息
         - innerText:忽略子标签
                 
                console.log(p1.innerHTML);
                p1.innerHTML="1.<i>读写</i>节点";

console.log(p1.innerText);
    - 读写节点的值
        - 表单控件中的数据叫值,只有如下表单控件才有值:
        - input
        - select
        - textarea

Javascript外部对象的更多相关文章

  1. JavaScript的对象——灵活与危险

    转:http://www.cnblogs.com/tolg/p/4873000.html 没有哪种数据结构比JavaScript的对象更简单灵活了.作为一个弱动态类型语言,JavaScript对对象的 ...

  2. JavaScript原生对象及扩展

    来源于 https://segmentfault.com/a/1190000002634958 内置对象与原生对象 内置(Build-in)对象与原生(Naitve)对象的区别在于:前者总是在引擎初始 ...

  3. JavaScript DOM 对象

    JavaScript DOM 对象   什么叫DOM,DOM是文档对象模型(Document Object Model,是基于浏览器编程(在本教程中,可以说就是DHTML编程)的一套API接口,W3C ...

  4. 前端基础:JavaScript DOM对象

    JavaScript DOM对象 通过HTML DOM,可以访问JavaScript HTML文档的所有元素. 一.HTML DOM(文档对象模型) 当网页被加载时,浏览器会创建页面的文档对象模型(D ...

  5. javascript 全局对象--w3school

    JavaScript全局对象 1.  decodeURI()解析某个编码的URI. 2.decodeURInComponent()解析一个编码的URI组件. 3.encodeURI()把字符串编码为U ...

  6. JavaScript Json对象和Json对象字符串的关系 jsonObj<->JsonString

    JavaScript Json对象和Json对象字符串的关系 jsonObj<->JsonString 如下示例: 直接写的a1就是一个Json对象,a2 就是一个Json对象字符串; 通 ...

  7. 从零构建JavaScript的对象系统

    一.正统的类与继承 类是对象的定义,而对象是类的实例(Instance).类不可直接使用,要想使用就必须在内存上生成该类的副本,这个副本就是对象. 以Java为例: public class Grou ...

  8. 关于javascript自定义对象(来自网络)(最近几天不会的)

    javascript定义对象的几种简单方法 1.构造函数方式,全部属性及对象的方法都放在构造方法里面定义 优点:动态的传递参数 缺点:每创建一个对象就会创建相同的方法函数对象,占用大量内存 funct ...

  9. 据说每个大牛、小牛都应该有自己的库——JavaScript原生对象拓展

    在据说每个大牛.小牛都应该有自己的库——框架篇中我扬言要做个小牛,没想到一天没更新,小伙儿伴们就戏谑的问我,油哥是不是要太监了?其实事情是这个样子的,这不是太监的节奏,一是,关于写个自己的库的想法由来 ...

随机推荐

  1. jquery Ajax提交表单数据

    //表单中控件的name要和实体类字段属性一致 $.ajax({ cache: true, type: "POST", url:ajaxCallUrl, data:$('#your ...

  2. for_each(c++11)

    http://www.cplusplus.com/reference/algorithm/for_each/ template<class InputIterator, class Functi ...

  3. Mysql InnoDB 共享表空间和独立表空间

    前言:学习mysql的时候总是习惯性的和oracle数据库进行比较.在学习mysql InnoDB的存储结构的时候也免不了跟oracle进行比较.Oracle的数据存储有表空间.段.区.块.数据文件: ...

  4. Delphi编程时候诡异地出现ORA-00937错误,记录解决它的思路和方法

    首先需要说明,这个问题的出现需要几个前提:使用微软的Oracle驱动(使用Oracle自己的驱动不会出现这个问题).使用绑定变量法,使用Format等方式拼接SQL也不会出现这个问题,还有一些诡异的规 ...

  5. Ubuntu(Linux系统)虚拟机工具vmtools详细说明

    安装虚拟机工具vmtools大概步骤如下: 个人总结步骤: 第一步:点击虚拟机软件的vm工具栏选项,选择install vmware tools(安装VMware Tools) 第二步:桌面会出现一个 ...

  6. Ueditor之前后端源码的学习和简单的研究

    这是我的项目目录 这里写图片描述 1.从访问路径http://localhost:8081/Test/_examples/simpleDemo.html,我们主要是要看看,富文本框被加载出来之前,会调 ...

  7. 追踪记录每笔业务操作数据改变的利器——SQLCDC

    对于大部分企业应用来用,有一个基本的功能必不可少,那就是Audit Trail或者Audit Log,中文翻译为追踪检查.审核检查或者审核记录.我们采用Audit Trail记录每一笔业务操作的基本信 ...

  8. js数组操作大全

    原文(http://www.cnblogs.com/webhotel/archive/2010/12/21/1912732.html) 用 js有很久了,但都没有深究过js的数组形式.偶尔用用也就是简 ...

  9. TFS 分支导致nuget项目依赖丢失

    问题: 项目的代码 在tfs上分支后,签出项目.编译时发现无法编译,原有的nuget来的包的dll都丢失了(项目签入时,默认会忽略dll) 在网上找了下,发现一个简单的解决方法: 在"程序包 ...

  10. HDU5977 Garden of Eden(树的点分治)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5977 Description When God made the first man, he ...