我试图从我的select
框option
s中插入数据到我的数据库表中。我的数据库表字段是id_country
和country_name
。发送JavaScript数组到PHP
数据库字段id_country
从select
option
值填充和country_name
是从相应的文本option
。 的代码是这样的..
<select id="id_country" name="id_country">
<option value="17" >USA</option>
<option value="16" >Canada</option>
<option value="7" >France</option>
</select>
<script>
$(document).ready(function(){
var data=new Array();
$('#id_country').find('option').each(function() {
var id=$(this).val();
data[id]=$(this).text();
});
$('#btn_insert').click(function(){
$.ajax({
type: "POST",
url: "ajax.php",
data: data,
success: function(response){
alert(response);
}
});
});
});
</script>
服务器端脚本:
<?php
//echo $_POST['data'];
$arr=$_POST['data'];
foreach($arr as $key => $value){
$sql="INSERT INTO Country($key,$value)";
$query=mysql_query($sql);
if(mysql_num_rows($query)>0){
echo "success";
}
}
?>
我不能让$_post['data']
值。我如何在PHP脚本中获得Javascript数组?
不要使用mysql_ *函数。它们都被弃用,除了名称,旧的,不安全的,并且意味着与已经过时多年的mysql的版本接口。考虑切换到mysqli或PDO – GordonM
发送json而不是数组 –
var_dump($ _ POST); –