jQuery那坑爹的text()

简介:

有一段代码:

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

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

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

 
  1. jTd.text($express || ""

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

 
  1. var jTd = $("td:first");  
  2. jTd.addClass("readonly").text(jTd.find(":input").val()); 
坑爹的text(),还有类似的html(),下次得小心着用啦!


本文转自边城__ 51CTO博客,原文链接:http://blog.51cto.com/jamesfancy/843013,如需转载请自行联系原作者
相关文章
|
JavaScript 前端开发
前端基础 -JQuery之val,text,html
前端基础 -JQuery之val,text,html
79 1
|
6月前
|
JavaScript 前端开发
jquery怎么给循环出来的列表(类似于text框)取值和赋值
jquery怎么给循环出来的列表(类似于text框)取值和赋值
39 0
jquery怎么给循环出来的列表(类似于text框)取值和赋值
|
JavaScript
Jquery操作文本内容(三个方法:html()、text()、var())
Jquery操作文本内容(三个方法:html()、text()、var())
|
JavaScript Java
Java Web——jQuery中的过滤器与第一组函数(val、text、attr)
Java Web——jQuery中的过滤器与第一组函数(val、text、attr)
Java Web——jQuery中的过滤器与第一组函数(val、text、attr)
|
JavaScript
jQuery中的.html() .text() .val() .attr()获取元素内容、值、属性
本文目录 1. 元素 2. 内容、值、属性 3. html() text() val() attr()用法
196 0
jQuery中的.html() .text() .val() .attr()获取元素内容、值、属性
|
JavaScript 索引
jQuery操作select下拉框的text值和value值的方法
1、jquery获取当前选中select的text值 $("#select1").find("option:selected").text(); 2、jquery获取当前选中select的value值 $("#select1").
1156 0