关于jQuery trim 方法兼容性问题

关于jQuery trim 方法兼容性问题,需要注意的地方:

 

当ie版本 <=8,使用:$("#input").val().trim(); //对象不支持“trim”属性或方法

正确的方法:$.trim($("#input").val()); // 各种兼容啊

jQuery trim 源码:

...

var trim = "".trim;

...

// Use native String.trim function wherever possible
    trim: trim && !trim.call("\uFEFF\xA0") ?
        function( text ) {
            return text == null ?
                "" :
                trim.call( text );
        } :

        // Otherwise use our own trimming functionality
        function( text ) {
            return text == null ?
                "" :
                ( text + "" ).replace( rtrim, "" );
        }

标准浏览器(es5)是支持字符串的 trim 方法的,所以最终原因是ie8以下浏览器不支持字符串 trim 造成的,你说是jquery的坑呢还是?

或者可以稍微改动一下:

var trim = "".trim || String.prototype.trim = function(){
    return this == null ? "" : (text + "").replace(rtrim, ""); // 沿用了jquery内部的东西   
}

 

转载于:https://www.cnblogs.com/jackliu6/p/3643202.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值