继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

jQuery那坑爹的text()

android也疯狂
关注TA
已关注
手记 279
粉丝 39
获赞 245

有一段代码:

var jTd = $("td:first");  jTd.text(jTd.find(":input").val()).addClass("readonly");

结果居然报告:对象不支持“addClass”属性或方法
难道 text(param) 返回的不是jQuery对象?!

仔细想了下,想明白了,一般情况下是返回的jQuery对象,但有一种情况除外……
假设:jTd.find(":input").val() 得到的值是undefined呢?这时候text(undefined)和text()是一样的效果,返回的都是innerText。所以,要排除text()的参数undefined的情况,可以这样

jTd.text($express || "")

不过也有缺陷,比如$express是0或者false的时候,这里jTd就不能显示出来了。如果觉得要去判断$express太麻烦,那就只有一个办法:把text()放在最后调用,或者单独调用!比如:

var jTd = $("td:first");  jTd.addClass("readonly").text(jTd.find(":input").val());

坑爹的text(),还有类似的html(),下次得小心着用啦!

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP