JavaScript--BOM对象

BOM(browser object model)浏览器对象模型

一、window对象

window是浏览器的一个实例,在浏览器中,window对象有双重角色,它既是通过JavaScript访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象。

1.window对象的方法
①alert("content")
语法:window.alert(”content”)
功能:显示带有一段消息和一个确认按钮的警告框

②confirm(“message")
语法:window.confirm(“message")
功能:显示一个带有指定消息和OK及取消按钮的对话框
返回值:如果用户点击确定按钮,则confirm()返回true
如果用户点击取消按钮,则confirm()返回false

③prompt(“text,defaultText")
语法:window.prompt(“text,defaultText")
参数说明:
text:要在对话框中显示的纯文本(而不是HTML格式的文本)
defaultText:默认的输入文本
返回值:如果用户单击提示框的取消按钮,则返回null
如果用户单击确认按钮,则返回输入字段当前显示的文本

注意:所有的全局变量和全局方法都被归在window上

<body>
    <div id="box">
        <span>iphone6s</span>
        <input type="button" value="删除" id="btn">
    </div>
    <script>
       var age=15;
       function sayAge(){
          alert('我'+window.age);
       }
       // 声明一个全局变量
       window.username="marry";   // var username="marry";
       // 声明一个全局方法
       window.sayName=function(){
          alert("我是"+this.username);
       }
       //sayAge();
       //window.sayName();

       // confirm()
       // 获取按钮,绑定事件
       var btn=document.getElementById("btn");
       btn.onclick=function(){
           // 弹出确认对话框
           var result=window.confirm("您确定要删除吗?删除之后该信息\n将不可恢复!");
           if(result){
              document.getElementById("box").style.display="none";
           }
       }
       // 弹出输入框
       //var message=prompt("请输入您的星座","天蝎座");
       //console.log(message);
    </script>
</body>
全局变量
全局函数

④open(pageURL,name,parameters)
语法:window.open(pageURL,name,parameters)
功能:打开一个新的浏览器窗口或查找一个已命名的窗口
参数说明:
pageURL:子窗口路径
name:子窗口句柄。(name声明了新窗口的名称,方便后期通过name对子窗口进行引用)
parameters :窗口参数(各参数用逗号分隔)

⑤close( )
语法:window.close( )
功能:关闭浏览器窗口

index1.html:

<head>
    <meta charset="UTF-8">
    <title>open</title>
</head>
<body>
    <input type="button" value="退 出" id="quit">
    <script>
       window.onload = function(){
          // 打开子窗口,显示newwindow.html
          window.open("newwindow.html","newwindow","width=400,height=200,left=0,top=0,toolbar=no,menubar=no,scrollbars=no,location=no,status=no");
          //name的作用:在引用子窗口的时候通过name引用
          var quit = document.getElementById("quit");
          // 点击关闭当前窗口
          quit.onclick = function(){
              window.close();
          }
       }
    </script>
</body>

newwindow.html:

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <h1>hello window.open</h1>
</body>
</html>
设置窗口属性

⑥定时器

JavaScript是单线程语言,单线程就是所执行的代码必须按照顺序。

超时调用:
语法:setTimeout(code,millisec)
功能:在指定的毫秒数后调用函数或计算表达式
参数说明:
1、code:要调用的函数或要执行的JavaScript代码串
2、millisec:在执行代码前需等待的毫秒数

说明:setTimeout()只执行code一次。如果要多次调用,请使用setInterval()或者让code自身再次调用setTimeout()

setTimeout方法返回一个ID值,通过它取消超时调用

清除超时调用:
语法:clearTimeout(id_of_settimeout)
功能:取消由setTimeout()方法设置的timeout
参数说明:
1、 id_of_settimeout :由setTimeout()返回的ID值,该值标识要取消的延迟执行代码块

<body>
    <script>
       //setTimeout("alert('hello')",4000);
       
       //匿名函数
       var timeout1=setTimeout(function(){
          alert("hello");
       },2000)

       //自定义函数
       var fnCall=function(){
          alert("world");
       }
       clearTimeout(timeout1);
        //推荐:
       //setTimeout(fnCall,5000);
    </script>
</body>

间歇调用:
语法:setInterval(code,millisec)
功能:每隔指定的时间执行一次代码
参数说明:
1、code:要调用的函数或要执行的代码串。
2、millisec:周期性执行或调用code之间的时间间隔,以毫秒计

<body>
    <script>
       /* var intervalId=setInterval(function(){
           console.log("您好");
        },1000)

        // 10秒之后停止打印
        setTimeout(function(){
            clearInterval(intervalId);
        },10000);*/
        
        var num=1,
            max=10,
            timer=null;
       
       // 每隔1秒针num递增一次,直到num的值等于max,清除定时器
      /* timer=setInterval(function(){
           console.log(num);
           num++;
           if(num>max){
              clearInterval(timer);
           }
       },1000)*/

       // 使用超时调用实现
       function inCreamentNum(){
           console.log(num);   // 1 2 3 10 
           num++;      
           if(num<=max){
              setTimeout(inCreamentNum,1000);
           }else{
              clearTimeout(timer);
           }
       }
       timer=setTimeout(inCreamentNum,1000);
    </script>
</body>

二、location对象

location对象提供了与当前窗口中加载的文档有关的信息,还提供了一些导航的功能,它既是window对象的属性,也是document对象的属性。

1.location对象的常用属性
①location.href
语法:location.href
功能:返回当前加载页面的完整URL
说明: location.href与window.location.href等价

②语法:location.hash
功能:返回URL中的hash(#号后 跟零或多个字符),如果不包含
则返回空字符串。

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
       .box1{height:400px;background:#ccc;}
       .box2{height:600px;background:#666;}
    </style>
</head>
<body>
    <div class="box1" id="top"></div>
    <div class="box2"></div>
    <input type="button" id="btn" value="返回顶部">
    <script>
       //console.log(location.href);
       //file:///E:/BaiduNetdiskDownload/JavaScript/js%E8%B5%84%E6%96%99%E5%92%8C%E6…E5%9F%BA%E7%A1%80%EF%BC%88%E6%BA%90%E4%BB%A3%E7%A0%81%EF%BC%89/index6.html
       //console.log(location.hash); 
       //在连接中加入锚点 打印锚点#top
       var btn=document.getElementById("btn");
       btn.onclick=function(){
          location.hash="#top";
       }
       console.log(location.pathname);
    </script>
</body>

③location.host
语法:location.host
功能:返回服务器名称和端口号(如果有)

④location.hostname
语法:location.hostname
功能:返回不带端口号的服务器名称。

⑤location.pathname
语法:location.pathname
功能:返回URL中的目录和(或)文件名。

⑥location.port
语法:location.port
功能:返回URL中指定的端口号,如果没有,返回空字符串。

⑦location.protocol
语法:location.protocol
功能:返回页面使用的协议。

⑧location.search
语法:location.search
功能:返回URL的查询字符串。这个字符串以问号开头。

xxxx?id=55&name=marry;
location.search;
"?id=55&name=marry;"

2.locating对象的位置操作
改变浏览器位置的方法:
location.href属性
location对象其他属性也可改变URL:
location.hash
location.search

①location.replace()
语法:location.replace(url)
功能:重新定向URL。
说明: 使用location.replace不会在历史记录中生成新纪录。

②location.reload()
语法:location.reload()
功能:重新加载当前显示的页面。
说明:
• location.reload()有可能从缓存中加载
• location.reload(true)从服务器重新加载

<body>
    <input type="button" value="刷新" id="reload">
    <script>
      /*  setTimeout(function(){
            //location.href='index6.html';
            // window.location='index6.html';
            location.replace("index6.html");
        },1000)*/
         document.getElementById("reload").onclick=function(){
             location.reload(true);
         }
    </script>
</body>

三、history对象

history对象保存了用户在浏览器中访问页面的历史记录

①history.back()
语法:history.back()
功能:回到历史记录的上一步
说明:相当于使用了history.go(-1)

②history.forward()
语法:location.forward()
功能:回到历史记录的下一步
说明:相当于使用了history.go(1)

③history.go(-n)
语法:history.go(-n)
功能:回到历史记录的前n步

④history.go(n)
语法:history.go(n)
功能:回到历史记录的后n步

<body>
    <p>这是index11.html</p>
    <p><input type="button" value="后退" id="btn"></p>
    <p><input type="button" value="前进" id="btn2"></p>
    <p><input type="button" value="前进两步" id="btn3"></p>
    <script>
        var btn=document.getElementById("btn");
        var btn2=document.getElementById("btn2");
        var btn3=document.getElementById("btn3");
        //点击btn按钮时回到历史记录的上一步
        btn.onclick=function(){
            //history.back();
            //history.go(-1);
            history.go(-2);//回到前两步
        }
        //点击btn2按钮来到历史记录的下一步
        btn2.onclick=function(){        
            //history.forward();
            history.go(1);
        }
        //点击btn3按钮来到历史记录的下一步
        btn3.onclick=function(){        
            history.go(2);
        }
    </script>
</body>

四、Screen对象

包含有关客户端显示屏幕的信息
①screen.availWidth
语法:screen.availWidth
功能:返回可用的屏幕宽度

②screen.availHeight
语法:screen.availHeight
功能:返回可用的屏幕高度

<body>
    <script>
        //获取屏幕的宽和高
        console.log("页面宽:"+screen.availWidth);
        console.log("页面高:"+screen.availHeight);
        //获取窗口的宽和高
        console.log("pageWidth:"+window.innerWidth);
        console.log("pageHeight:"+window.innerHeight);
    </script>
</body>

五、Navigator对象

UserAgent:用来识别浏览器名称、版本、引擎 以及操作系统等信息的内容。
可以判断浏览器的类型
判断设备的终端是移动还是PC

<head>
    <meta charset="UTF-8">
    <title>Navigator</title>
</head>
<body>
    <script>
       //console.log(navigator.userAgent);
       // 判断浏览器
       function getBrowser(){
           var explorer = navigator.userAgent,browser;
           //indexOf():返回某个指定的字符串值在字符串中首次出现的位置,如果没有出现过,返回-1
           if(explorer.indexOf("MSIE")>-1){
              browser = "IE";
           }else if(explorer.indexOf("Chrome")>-1){
              browser = "Chrome";
           }else if(explorer.indexOf("Opera")>-1){
              browser = "Opera";
           }else if(explorer.indexOf("Safari")>-1){
              browser = "Safari";
           }
           return browser;
       }
       var browser = getBrowser();
       console.log("您当前使用的浏览器是:"+browser);
       // 判断终端
       function isPc(){
          var userAgentInfo = navigator.userAgent,
              Agents = ["Andriod","iPhone","symbianOS","windows phone","iPad","iPod"],
              flag = true,i;
              console.log(userAgentInfo);
           for(i=0;i<Agents.length;i++){
              if(userAgentInfo.indexOf(Agents[i])>-1){
                 flag = false;
                 break;
              }
           }
           return flag;
       }
       var isPcs = isPc();
       console.log(isPcs);
    </script>
</body>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351