2016-04-01 133 views
1

我想将一个值传递给ajax函数。这在表单中很简单并且按预期工作(在下面的示例中将id更改为gal_id1),但是我的定位器传递的值出现未定义的错误。将值通过锚点传递给ajax。

<html> 
<head> 
<script> 
function ajax_post(){ 
    // Create our XMLHttpRequest object 
    var hr = new XMLHttpRequest(); 
    // Create some variables we need to send to our PHP file 
    var url = "ajax_json_gallerySQL.php"; 
    var gid = document.getElementById("gal_id").value; 
    var vars = "gal_id="+gid; 
    hr.open("POST", url, true); 
    // Set content type header information for sending url encoded variables in the request 
    hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); 
    // Access the onreadystatechange event for the XMLHttpRequest object 
    hr.onreadystatechange = function() { 
     if(hr.readyState == 4 && hr.status == 200) { 
      var return_data = hr.responseText; 
      document.getElementById("status").innerHTML = return_data; 
     } 
    } 
    // Send the data to PHP now... and wait for response to update the status div 
    hr.send(vars); // Actually execute the request 
    document.getElementById("status").innerHTML = "processing..."; 
} 
</script> 
</head> 

<body> 
<h2>Test Pictures. </h2> 

THis is working 
<input id="gal_id1" name="gal_id1" type="text"> <br><br> 
<input name="myBtn" type="submit" value="Submit Data" onclick="ajax_post();" > <br><br> 
<div id="status"></div> 
<?php 

$myValue='13'; 
This is not working 
echo "<td> <a id='gal_id' name='gal_id' href='#' onClick='ajax_post();' value='13' ><img src='images/Parents/Brook/Brook1.jpg' alt='Image' width='270' height='203'></a><br><br>"; 

?>   


</body> 
</html> 

回答

1

锚不必在输入的方式相同的价值观,所以.value将无法​​正常工作。你可以做的是使用document.getElementById("gal_id").getAttribute('value')

说了这么多,你可能应该使用数据属性,例如,

<a data-value="13" id="gal_id">

然后

document.getElementById("gal_id").dataset.value

More information on data attributes

+0

这很棒! – user1956040