请参阅以下代码。
$dArr = '<script>document.write(volunteerDist);</script>';
$ dArr获取volunteerDist的值。 echo $ dArr打印值4.1,9.4,2.3,4.7,9.1,14.7,3.2,7.1,4.1,0.5
我想将其拆分为数组中的元素,因此我使用了:
$dArr = preg_split("/,/", $dArr);
但是$ dArr是一个只有一个元素的数组,这是所有的值..这意味着没有发生preg_split。我也试过
$temp=explode(",", $dArr);
但仍然无效。
我试图粘贴该值(即上面的数字)和preg_split直接
$temp=explode(",", '4.1,9.4,2.3,4.7,9.1,14.7,3.2,7.1,4.1,0.5');
它成功了。怎么了?请注意,当我回显$ dArr时,会打印数字。
答案 0 :(得分:5)
您在这里混合服务器端和客户端代码和逻辑。
你看到&#34;正确&#34;输出是因为document.write
方法将输出写入浏览器。
您无法直接与服务器端代码中的客户端变量进行交互。
您必须使用AJAX将客户端值发送到服务器,或者在客户端解析它:
<script type="text/javascript">
var dArr = volunteerDist.split(",");
for (var i = 0; i < dArr.length; i++)
document.write(dArr[i] + "<br />");
</script>
编辑:虽然我不是PHP开发人员,但阅读其他一些帖子给了我足够的示例代码。
要将客户端volunteerDist
变量的值发送到PHP并保存到数据库,首先在代码中包含jQuery:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
现在在定义和创建变量后的某处:
<script type="text/javascript">
$.ajax({
type: "POST",
url: "yourpagehere.php",
data: "volunteerDist=" + volunteerDist,
dataType: "html"
});
</script>
并阅读此数据并添加到数据库:
<?php
$volunteerDist = $_POST['volunteerDist'];
if(isset($volunteerDist)) {
$dArr = preg_split("/,/", $volunteerDist);
foreach($dArr as $volunteer) {
$sql = "INSERT INTO TableName (fieldname) VALUES ('".$volunteer."')";
mysql_query($sql) or die(mysql_error());
}
}
?>
当然,您需要将页面名称,表格名称和字段名称更改为实际值。