我有一个功能强大的 AJAX 帖子,效果很好。我的客户请求了一个额外的文本输入字段,但在我的一生中,我无法得到它。脚本很长,所以我会给你相关的部分,希望它是一个语法问题。

我的输入的 HTML:

<input type="text" name="why" id="why" maxlength="70">

Javascript 调用
$(document).on("click", ".take-claim-link", function(){
var id= $(this).attr('data-id');
var point= $(this).attr('data-point');
var val= $(this).attr('data-val');
var type = $(this).attr('data-type');
var why = $("#why").val();

var follow = document.getElementById("follow-" + id + "-"+ type);
var followuser='0';
if (follow.checked) {
    var followuser = "1";
}


var takeurl = '/api/responseClaim.json';
var newPrice ='';

var newData = $.ajax({
    type: "POST",
    url: takeurl,
    dataType: "json",
    data: { point: point, claimId: id, type: val,why: why,follow: followuser }
    })
(etc).

对于“为什么”,它不返回任何内容。

有趣的是:如果我将变量更改为 var why = 'sample why'; 它会通过。同样,如果我将输入更改为 <input type="text" name="why" id="why" maxlength="70" value="some value">,它会读取它。所以我认为问题在于我定义它的方式。

但是什么?我也试过 var why = $("input#why").val();document.getElementById("why").value;

最佳答案

在您的 HTML 代码中可能有另一个具有相同 id="why" 的元素。所以尝试搜索它。或者将上述输入的 id 更改为其他内容。

(可选)您可以尝试使用以下方法获取该输入值:

var why = $('input[name="why"]').val();

希望能帮助到你。

关于jquery - 将文本输入值发布到 ajax,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/17632895/

10-11 14:48