html5不支持jquery,jquery ie8不支持怎么办?

使用jQuery的时候,jQuery从2.0开始不兼容IE8,最低支持IE9,那么jquery ie8不支持怎么办?怎么解决?下面本篇文章就来给大家介绍一下jQuery兼容浏览器IE8方法。

b27d17e0e9ea731ddbaa1630f4c9b9d4.png

IE8不支持jQuery版本解决办法

可以使用原生JS或者低版本的Jquery1.x版本,通过判断IE浏览器的版本来加载对应版本的jQuery。

使用语句 可在IE8模式下进行一些兼容操作。代码如下:

这样在切换到IE8时,低版本的jQuery就会覆盖高版本的jQuery。如果在IE8下需要调整某些元素的样式的话,最好将JS代码放在页面底部(并注意是否有行内样式),不然为某些动态加载的内容设置的样式可能不会生效。

IE8不支持forEach解决办法

为不支持forEach的浏览器添加自定义forEach方法

代码如下:if (typeof Array.prototype.forEach != 'function') {

Array.prototype.forEach = function (callback) {

for (var i = 0; i < this.length; i++) {

callback.apply(this, [this[i], i, this]);

}

};

}

如果是引入的jQuery插件,可将该段代码放在插件内容的开头即可,这样在IE8下执行forEach方法就不会报错了。

IE8不支持map解决办法

添加自定义forEach方法if (!Array.prototype.map) {

Array.prototype.map = function(callback, thisArg) {

var T, A, k;

if (this == null) {

throw new TypeError(" this is null or not defined");

}

// 1. Let O be the result of calling ToObject passing the |this|

// value as the argument.

var O = Object(this);

// 2. Let lenValue be the result of calling the Get internal method

// of O with the argument "length".

// 3. Let len be ToUint32(lenValue).

var len = O.length >>> 0;

// 4. If IsCallable(callback) is false, throw a TypeError exception.

// See: http://es5.github.com/#x9.11

if (typeof callback !== "function") {

throw new TypeError(callback + " is not a function");

}

// 5. If thisArg was supplied, let T be thisArg; else let T be undefined.

if (thisArg) {

T = thisArg;

}

// 6. Let A be a new array created as if by the expression new Array(len)

// where Array is the standard built-in constructor with that name and len is

// the value of len.

A = new Array(len);

// 7. Let k be 0

k = 0;

// 8. Repeat, while k < len

while(k < len) {

var kValue, mappedValue;

// a. Let Pk be ToString(k).

// This is implicit for LHS operands of the in operator

// b. Let kPresent be the result of calling the HasProperty internal

// method of O with argument Pk.

// This step can be combined with c

// c. If kPresent is true, then

if (k in O) {

// i. Let kValue be the result of calling the Get internal method

// of O with argument Pk.

kValue = O[ k ];

// ii. Let mappedValue be the result of calling the Call internal method of callback

// with T as the this value and argument list containing kValue, k, and O.

mappedValue = callback.call(T, kValue, k, O);

// iii. Call the DefineOwnProperty internal method of A with arguments

// Pk, Property Descriptor {Value: mappedValue, : true, Enumerable: true, Configurable: true},

// and false.

// In browsers that support Object.defineProperty, use the following:

// Object.defineProperty(A, Pk, { value: mappedValue, writable: true,

// enumerable: true, configurable: true });

// For best browser support, use the following:

A[ k ] = mappedValue;

}

// d. Increase k by 1.

k++;

}

// 9. return A

return A;

};

}

更多jQuery相关技术文章,请访问 jQuery答疑 栏目进行学习!!

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值