前端代码 ie9及以下ie版本 兼容问题,不完全记录

本文主要记录了在IE9及以下版本中遇到的几个兼容性问题及其解决方案,包括classList的不兼容、postMessage的限制以及placeholder属性的缺失,并提供了相应的补丁代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为选择转载还需要确认被转载人已同意,有点麻烦,所以选了原创,但是附上了原文地址

1. classList 在ie9中的不兼容

引入以下代码,即可

if (!("classList" in document.documentElement)) {
    Object.defineProperty(HTMLElement.prototype, 'classList', {
        get: function() {
            var self = this;
            function update(fn) {
                return function(value) {
                    var classes = self.className.split(/\s+/g),
                        index = classes.indexOf(value);
 
                    fn(classes, index, value);
                    self.className = classes.join(" ");
                }
            }
 
            return {
                add: update(function(classes, index, value) {
                    if (!~index) classes.push(value);
                }),
 
                remove: update(function(classes, index) {
                    if (~index) classes.splice(index, 1);
                }),
 
                toggle: update(function(classes, index, value) {
                    if (~index)
                        classes.splice(index, 1);
                    else
                        classes.push(value);
                }),
 
                contains: function(value) {
                    return !!~self.className.split(/\s+/g).indexOf(value);
                },
 
                item: function(i) {
                    return self.className.split(/\s+/g)[i] || null;
                }
            };
        }
    });
}

https://blog.youkuaiyun.com/weixin_44860135/article/details/90404135   原文地址

2. postMessage 在ie9的不兼容问题

传参只支持字符串,ie10及以上支持对象和字符串。所以统一改为字符串

 

3. placeholder 在ie9的不兼容问题

 /*

     IE9placeholder支持

     */

    if(!placeholderSupport()){   // 判断浏览器是否支持 placeholder

        $('[placeholder]').focus(function() {

            var input = $(this);

            if (input.val() == input.attr('placeholder')) {

                input.val('');

                input.removeClass('placeholder');

            }

        }).blur(function() {

            var input = $(this);

            if (input.val() == '' || input.val() == input.attr('placeholder')) {

                input.addClass('placeholder');

                input.val(input.attr('placeholder'));

            }

        }).blur();

    };

 

    function placeholderSupport() {

        return 'placeholder' in document.createElement('input');

    }

 

https://www.cnblogs.com/quitpoison/p/8794254.html    原文地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值