dongshi6529 2016-03-23 10:17
浏览 65
已采纳

带有空结果的AJAX请求 - 清除我们的HTML输入字段

I have a select menu that, when a user makes a selection, it fires off an AJAX request to a PHP script to query a database and return a value that matches the selection and inserts this into an associated input field.

This is all working well, however I now need to cater for the possibility that an empty result might be returned (up until now a matching result was always returned). If that is the case it needs to delete the value from the associated input field/clear this input field.

Here's what a successful AJAX request returns (JSON data):

[{"senderMobile":"0412 345 678"}]

and here's what an empty result returns:

[{"senderMobile":""}]

Here's the AJAX code that calls the PHP script and updates the input field:

$(document).ready(function() {
  $("#smsFromName").change(function() {
    var smsFromName = $("#smsFromName").val();
    console.log(smsFromName);
    $.post('getSMSSender.php', {
      senderName: smsFromName
    }, function(data) {
      data = JSON.parse(data);
      if (data.error) {
        alert("error");
        $("#smsFrom").html('');
        return; // stop executing this function any further
      } else {
        console.log(data[0].smsFrom);
        $("#smsFrom").val(data[0].senderMobile);
      }

    }).fail(function(xhr) {
      $("#smsFrom").html('');
    });
  });
});

I gather I need to update this section to include an option that if there is no data to simply clear out the #smsFrom input field:

} else { 
console.log( data[0].smsFrom );
$("#smsFrom").val(data[0].senderMobile);

but I'm stumped at this point.

</div>
  • 写回答

2条回答 默认 最新

  • dongniuxia8650 2016-03-23 10:22
    关注

    You just need to check if senderMobile has a value. Try this:

    if (data.error) {
        alert("error");
        $("#smsFrom").html('');
        return; // stop executing this function any further
    } else if (data[0] && data[0].senderMobile) {
        console.log(data[0].smsFrom);
        $("#smsFrom").val(data[0].senderMobile);
    } else {
        $("#smsFrom").val(""); // or .html(""); I didn't get what kind of element is this...
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 易语言把MYSQL数据库中的数据添加至组合框
  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况