为了账号安全,请及时绑定邮箱和手机立即绑定

js链式调用的疑惑

js链式调用的疑惑

皈依舞 2019-02-28 22:14:24
今天封装了关于jq的siblings的函数,想再封装一个关于removeClass的函数并实现链式调用,类似于document.getElementById().siblings().removeClass()这样的链式调用方式。尝试了多次均不成功,可能是思路不对,请多指点怎样实现用js封装jq的api并实现链式调用,不胜感激。提供思路也可!Element.prototype.siblings=function siblings(){            var siblingsElement=[];            var parentAllElement=[];            if(! this.parentNode){                return siblingsElement;            };            parentAllElement=this.parentNode.getElementsByTagName(this.tagName)            for(var i=0,len=parentAllElement.length;i<len;i++){                if(parentAllElement[i]!=this)                siblingsElement.push(parentAllElement[i]);            }            return siblingsElement;        }var hasClass=function(element,oClass){    return element.className.match(new RegExp('(^|\\s)' + oClass + '(\\s|$)'));    }var removeClass=function(element,oClass){    var cls=new RegExp('(^|\\s)' + oClass + '(\\s|$)');    if(hasClass(element,oClass)){        element.className=element.className.replace(cls,'')}}
查看完整描述

2 回答

?
烙印99

TA贡献1829条经验 获得超13个赞

想要链式调用 return 必须是有后续调用方法的对象
你siblings方法最后return的是一个内部的数组 他的原型上没有对应的方法 所以不成功

查看完整回答
反对 回复 2019-03-01
?
一只名叫tom的猫

TA贡献1906条经验 获得超3个赞

Element.prototype.removeClass=function(oClass){

    var cls=new RegExp('(^|\\s)' + oClass + '(\\s|$)');

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

        if(hasClass(this[i],oClass)){

        element.className=this[i].className.replace(cls,'')}

    }

}


查看完整回答
反对 回复 2019-03-01
  • 2 回答
  • 0 关注
  • 544 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号