jQuery Ajax返回undefined

时间:2010-08-15 01:02:39

标签: javascript jquery ajax

$('.updateDescriptionProduct').click( function() {
  if ( updateProductDescription(productID, description) == 'true') {
    alert('success!');
  } else {
    alert('did not update');        
  }
});

function updateProductDescription(productID, description) {
  $.ajax({
    url: '/index.php/updateProductDescription',
    global: false,
    type: 'POST',
    data: ({productID: productID, description: description}),
    dataType: 'html',
    async:false,
    success: function(msg){
      alert(msg); 

      return msg;
    }
  });
}

该函数本身为true,但我的click事件以undefined的形式返回。

1 个答案:

答案 0 :(得分:10)

return适用于回调。尝试在初始函数中设置变量并在回调中设置值,然后返回它?

function updateProductDescription(productID, description) {
    var ret = false;
    $.ajax({
          url: '/index.php/updateProductDescription',
          global: false,
          type: 'POST',
          data: ({productID: productID, description: description}),
          dataType: 'html',
          async:false,
          success: function(msg){
            ret = msg;
          }
    });
    return ret;
}

我从未做过async电话,但似乎这应该有效。如果没有,请告诉我。