博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
读javascript高级程序设计09-BOM
阅读量:6238 次
发布时间:2019-06-22

本文共 2620 字,大约阅读时间需要 8 分钟。

一、window

1.在全局作用域中定义的变量和函数会被归在window对象。

var a=1,b=2;function add(a,b){return a+b;}console.log(window.a);//1console.log(window.add(a,b));//3

有点区别在于,全局变量不能用delete删除,而直接在window对象定义的属性可以用delete删除。

2.计算窗口位置

var leftpos=typeof window.screenLeft=="number"?window.screenLeft:window.screenX;var toppos=typeof window.screenTop=="number"?window.screenTop:window.screenY;

3.间接性调用

①setInterval方法:

var i=1,max=10;  function f(){    if(i==max){    clearInterval(test);      console.log('Done');    }    else{      console.log(i);      i++;    }  }var test=setInterval(f,1000);

②用setTimeout方法实现:

var i=1,max=10;  function f(){    if(i==max){      console.log('Done');    }    else{      console.log(i);      setTimeout(f,1000);      i++;    }  }var test=setTimeout(f,1000);

使用超时调用模拟间歇调用是一种最佳实践。

4.系统对话框

prompt:

var result=prompt("your name?");if(result!=null){alert('hello,'+result);}

二、location对象

1.location对象属性:

window.location和document.location指向同一个对象。

每次修改location的属性(hash除外),都会以新URL重新加载页面。

location对象几个常用的属性实例:

//url为:http://www.cnblogs.com/janes/p/3829648.html//hash:用于锚点定位location.hash="#author_profile_info";//定位到头像//hostname:不带端口号的服务器名称location.hostname;//"www.cnblogs.com"//href:当前页面的完整urllocation.href;//"http://www.cnblogs.com/janes/p/3829648.html#author_profile_info"//pathname:url中的路径名或者文件名location.pathname;//"/janes/p/3829648.html"//search:url中的查询字符串,以问号开头location.search;//""

2. 获取查询字符串参数:

function getQueryArgs(){  var qs=location.search.length>0?location.search.substring(1):"";  var result={};  var items=qs.length?qs.split('&'):[];  var item=null,name=null,value=null;  for(var i=0;i
0){ result[name]=value; } } return result;}var r=getQueryArgs();

3.修改url:

location.href="http://www.baidu.com";//打开新URL之后可以通过浏览器后退回到前一页面location.replace("http://www.baidu.com");//打开新URL之后在某些浏览器下不能通过后退回到前一页面

重新加载页面:

location.reload():可能从缓存加载location.reload(true):重新从服务器加载

三、navigator对象

1.常用属性

navigator.cookieEnabled:浏览器cookie是否可用navigator.userAgent:浏览器的用户代理字符串;

2.检测插件:检测浏览器中是否安装了某个插件。

非IE浏览器:使用plugins数组,判断插件名称在name属性中是否存在。

function hasPlugin(name){name=name.toLowerCase();  for(var i=0;i
-1){ return true; } } return false;}//调用hasPlugin('Flash');

IE浏览器:使用ActiveObject对象,并尝试创建插件的一个实例。

function hasIePlugin(name) {  try {    new ActiveXObject(name);    return true;  } catch(ex) {    return false;  }}
//调用hasIePlugin('ShockWaveFlash.ShockWaveFlash');

由于两种检测方式差异较大,所以一般针对每个插件写单独的检测方法:

function hasFlash() {  var result = hasPlugin('flash');  if (!result) {    result = hasIePlugin('ShockWaveFlash.ShockWaveFlash');  }  return result;}
http://www.cnblogs.com/janes/p/3885183.html
你可能感兴趣的文章
聊一聊前端系列篇
查看>>
C#,ASP.NET jquery uploadify上传控件中文乱码解决办法
查看>>
POJ 1651 Multiplication Puzzle
查看>>
struts2 spring 优缺点
查看>>
ps学习入门篇
查看>>
MyEclipse 配置多个Tomcat运行
查看>>
[MVC_Json序列化]MVC之Json序列化循环引用
查看>>
选购智能机必须知道的知识
查看>>
Dynamic CRM 2013学习笔记(四)单据编号及插件批量注册工具
查看>>
个人博客2
查看>>
(css笔记)清理浮动的各种方法
查看>>
RedHat yum源配置
查看>>
Node.js:cookie和session在Express中应用
查看>>
Google code Jam 大中华区测试题
查看>>
Hadoop生态圈-hive编写自定义函数
查看>>
java中接口与多重继承的关系
查看>>
jsp分页
查看>>
为什么输入shutdown -h -t会报错:command not fount
查看>>
Spark 集群环境搭建
查看>>
4.css浏览器原理与兼容等
查看>>