这是我的html代码:
<form name="sumForm" action="">
<input type="text" id="num1" name="num1" />
<input type="text" id="num2" name="num2" />
<input type="submit" id="sum" value="sum"/>
</form>
这是我的jquery代码:
$("#sum").click(function() {
var num1 = $("#num1").val();
var num2 = $("#num2").val();
var dataString = "num1="+ num1 + "&num2=" + num2;
$.ajax({
type: "POST",
url: "apotelesma.php",
data: dataString,
success: function() {
alert(dataString)
return false;
}
});
return false;
});
这是apotelesma.php脚本:
<?php
$num1 = isset($_POST['num1']);
$num2 = isset($_POST['num2']);
$apotelesma = 0;
$apotelesma = $num1 + $num2;
echo $apotelesma;
?>
我不知道如何得到结果。我不知道包含php脚本来显示结果是否正确。
isset
检查是否设置了值并返回布尔值,因此$num1
和$num2
将为true或false。所以你没有把实际值加起来。
问题是将$num1
和$num2
设置为布尔值。。
试试这个
$num1 = isset($_POST['num1']) ? $_POST['num1'] : 0;
$num2 = isset($_POST['num2']) ? $_POST['num2'] : 0;
isset()
返回true
或false
,并且很难用true
或false
进行任何添加(讽刺)。
您需要将其更改为类似以下内容:
$num1 = isset($_POST['num1']) ? $_POST['num1'] : 0;
$num2 = isset($_POST['num2']) ? $_POST['num2'] : 0;
return $num1 + $num2;
我的问题:有什么理由在ajax上进行添加吗?为什么不在没有ajax请求的javascript中呢?
其他人在你的php文件中指出了一个错误,但在你的javascript中也有一个错误:
$.ajax({
type: "POST",
url: "apotelesma.php",
data: dataString,
success: function() {
alert(dataString)
return false;
}
应该是:
$.ajax({
type: "POST",
url: "apotelesma.php",
data: dataString,
success: function(data) {
alert(data)
return false;
}
success: function(data){}
中的data
就是您在php文件中回显的内容。
您没有发送变量。更改AJAX以在data
区域中包括变量num1
和num2
:
$("#sum").click(function() {
var num1 = $("#num1").val();
var num2 = $("#num2").val();
$.ajax({
type: "POST",
url: "apotelesma.php",
data: {
num1: num1,
num2: num2
},
success: function(data) {
alert(data);
return false;
}
});
return false;
});
把你的PHP改成这样:
$num1 = isset($_POST['num1']) ? $_POST['num1'] : 0;
$num2 = isset($_POST['num2']) ? $_POST['num2'] : 0;
echo $num1 + $num2;
'isset'返回一个布尔值,表示是否设置了变量。
您需要:
<?php
if (!isset($_POST['num1']) || !isset($_POST['num2']))
exit;
$num1 = $_POST['num1'];
$num2 = $_POST['num2'];
$apotelesma = 0;
$apotelesma = $num1 + $num2;
echo $apotelesma;
?>
那么你的成功回调应该包括
$('#result').html(dataString);
当您进行ajax调用时,您的页面不会像普通表单那样刷新,因此您不希望使用include。