浏览器兼容性检测

ipad下的safari执行window.open,会打开2个tab窗口。但是若在全屏模式。(将网页添加到屏幕中),window.open会无效。只能通过<a/>
如果要打开一个新标签窗口,只能通过<a>或者
var a = window.open("");
a.location = "www.sina.com";
或者用js append一段<a>标签,打开后再remove掉。

window.notification(目前只有在chrome下支持通知)
IE不支持window.innerWidth

在Opera和iE7或更高版本中,resizeTo和resizeBy,moveTo和moveBy是被禁用的。

ipad版的safari不支持双击事件,包括jquerydblclick
ipad下的touchevent,若要访问event对象,则必须通过addEventListener来获取,在jquery的bind或click是无法获取到e对象的。

cloneNode不会复制添加到DOM节点中的js属性,例如事件处理程序,只复制特性、子节点,其它都不会复制。
IE在cloneNode()方法中会复制事件处理程序,建议复制之前最好先移除事件处理程序。

所有浏览器都支持document.documentElement 和document.body。
document.doctype 获取<!DCOTYPE>的引用
IE的document.doctype 始终为null,若存在就将它注释掉。
FF:如果存在则将document.doctype作为第一个子节点
safari,chrome,opera:存在就解析,但不会作为文档的子节点。不会出现在document.childNodes中。

解析html外部的注释的差异:
IE,safari 3.1+,opera,chrome:只为第一条注释创建节点。不为第二条注释创建节点 。
FF safari3.1之前的版本:完全忽略注释

document.domain的限制:如果一开始是domain.com则不能在更改为p2p.domain.com

<div id="myDiv"></div>
document.getElementByID("mydiv");
除了IE,其他浏览器都返回null。IE8及其以下版本不区分ID的大小写。
在IE下,若表单元素如input的name属性和其它元素的id一致,则ie的getElementByID会返回表单元素。

你可能感兴趣的:(JavaScript,dom)