2016-04-01 185 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