javaScript的学习笔记....浏览器兼容性汇总

事件响应函数,中的event对象

视频链接:https://b23.tv/BV1YW411T7GX/p112
event.clientX和event.client
在这里插入图片描述
解决事件兼容;
event = event || window.event;

————————————-
视频:https://b23.tv/BV1YW411T7GX/p116
大部分浏览器的兼容addEventListener与只有IE8以下支持的attachEvent的使用;

在这里插入图片描述
在这里插入图片描述

———————————-
事件的捕获与冒泡;
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

IE8及以下浏览器没有捕获阶段;

——————————————

拖拽

视频:https://b23.tv/BV1YW411T7GX/p118;
当鼠标进行拖拽的时候,浏览器也有默认的拖拽功能,解决方案:
在这里插入图片描述
针对IE8;
视频:https://b23.tv/BV1YW411T7GX/p120
在这里插入图片描述

但鼠标松开的时候,取消对事件的捕获;
box1.releaseCapture();

setCapture只有IE支持;
—————————————-
取消浏览器的默认行为;
event.preventDefault();

———————

navigator

视频来源:https://b23.tv/BV1YW411T7GX/p124
判断浏览器
在这里插入图片描述

在这里插入图片描述
关于IE11
在这里插入图片描述
如果通过UserAgent不能判断,还可以通过一些浏览器中特有的对象,来判断浏览器的信息;比如:ActiveXObject
在这里插入图片描述
IE11:上面的方法不能识别IE11,因为window.ActiveXObject结果也为false;
解决方案:
alert(“AciveXObject” in window);
结果:IE浏览器都显示为true,其他浏览器显示为false;

在这里插入图片描述
综合上面的写法:

在这里插入图片描述

———————————

json

json转为js对象:JSON.parse();
js对象转为JSON:JSON.stringify();

浏览器兼容性问题:
JSON这个对象在IE7及以下的版本,不支持;
解决方案:
eval();
这个函数可以用来执行一段字符串形式的JS代码,并将执行结果返回;

在这里插入图片描述
具有安全隐患
在这里插入图片描述
最总使用的是如下:
在这里插入图片描述
引入的文件为自建创建的JSON对象;

———————————

childNodes属性;

childNodes属性会获取包括文本节点在的所有节点;
根据DOM标签间的空白也会变为文本节点;
注意:在IE8:及以下的浏览器中,不会讲空白节点当成子节点;

children属性获取子元素,所有浏览器都兼容;

—————————

getElementsByClassName();

根据元素的class属性查询一组元素节点对象;但是IE8及以下浏览器不支持;
虽然IE8中没有getElementsByClassName,但是可以使用,
document.querySelector();
可以根据一个CSS选择器来查询一个元素节点对象;元素有多个的时候只会返回第一个;
**doucment.querySelectAll();**同上,不同的是返回数组;

——————————

Js修改样式,

语法:元素.style.样式名 = 样式值;
backgroud-color需要修改为backgroudColor;
js修改的为内联样式;

获取样式
语法:元素.style.样式名
该方法只能获取内联样式;即嵌套在标签元素的样式;例

获取当前显示的样式;
语法:元素.currentStyle.样式名;
只有IE浏览器支持!!!!

在其他浏览器中可以用;
var box = document.getElementById(‘id’);
var obj = getComputedStyle(box,null);
获取宽度;
console.log(obj.width);
需要两个参数,第一个,要获取样式的元素,第二个,可以传递一个伪元素,一般都传null;该方法会返回一个对象,对象中封装了一个当前元素的对应的样式;例如:obj.width

上面不支持IE8以下!!!

通过currentStyle和getComputedStyle方法读取到的样式都是只读的,不能修改,修改只能用style属性;

兼容所有在这里插入图片描述浏览器的方法!!

————————————————

try,catch语句

如果提供 finally 子句,则 catch 子句就成了可选的(catch 或 finally 有一个即可)。IE7及 更早版本中有一个 bug:除非有 catch 子句,否则 finally 中的代码永远不会执行。如果你仍然要考 虑 IE的早期版本,那就只好提供一个 catch 子句,哪怕里面什么都不写。IE8修复了这个 bug;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值