ajax回调函数中使用$(this)取不到对象的解决方法,ajax回调函数


下面这段jquery代码,是可以达到预期效果的。
复制代码 代码如下:

$(".derek").each(function(){
$(this).click(function(){
var params = $(this).parent().serialize();
var obj=$(this).parent().siblings("div#caskContent");
var form=$(this).parent();
$.ajax({
url:"editCaskContent",
type:"post",
data:params,
dataType:"json",
success:function(e){
obj.empty();
obj.html("<font color=\"#00AA00\">追问:</font>");
obj.append(e.caskContent);
form.toggle();
alert("修改成功!");
},
error:function(e){
alert(e);
}
});
});
});

其中,大家可以看到,在发出ajax请求之前,我提前定义了两个变量,obj和form,分别用来存储两个jquery对象。如果在ajax的回调函数内使用$(this)的话,实践证明,是取不到任何对象的。具体原因,希望大神留言指教。。

ajax异步调用,回调函数的问题,this未定义

updateEvent()中this代表的是方法本身,this.myState代表updateEvent()中的myState参数,但是在这个方法里你并未定义。
<input type="text" onclick="a(this.value)" />中的this代表的是文本框本身,所以value属性是默认的,不需要写上去。
纯属个人看法。。
 

ajax回调函数取不到返回的值

问题应该不在这段代码中,估计是后台代码的问题,你可以直接运行后台代码看看输出是什么。
 

评论关闭