当我提交表单时,我收到 Uncaught RangeError:超出最大调用堆栈大小
2017-08-31
2917
我尝试使用 Ajax 请求将表单发布到我的
testexe.php
,但是,每当我在 Ajax 请求中添加数据类型网关时,我都会收到 Uncaught RangeError:超出最大调用堆栈大小错误消息。我这里做错了什么吗?我能够成功获取
button 值
,但不确定为什么
gateway
给我带来了问题。
<!DOCTYPE html>
<html>
<head>
<style>
.box1 {
width: 450px;
border: 2px solid black;
margin: 0;
display: flex;
}
.col {
display: inline-block;
border-right: 2px solid black;
padding: 5px;
width: 200px;
}
.col:last-child {
border-right: none;
}
input[type=text], select {
width: 20%;
padding: 12px 20px;
margin: 8px 0;
display: inline-block;
border: 1px solid #ccc;
border-radius: 4px;
box-sizing: border-box;
background-color: #ffffff;
}
</style>
</head>
<body>
<div id="gatewayInput">
<form method="post">
<input type="text" id="gateway" name="gateway" placeholder="Gateway Name"><br><br>
<?php
include("search.php");
?>
</div>
<div class="box1">
<label class="col">Up/Down</label>
<span class="col">
<input type="radio" name="option" id="r1" value="1" />
<label for="r1">Up</label>
<input type="radio" name="option" id="r2" value="2" />
<label for="r2">Down</label>
</span>
<span class="col">
<input type="submit" class="button" name="submit"/>
</span>
</form>
</div>
<script src ="../../../jqueryDir/jquery-3.2.1.min.js"></script>
<script src ="../../../jqueryDir/jquery-ui.min.js"></script>
<script type="text/javascript">
//auto seatch function
$(function() {
$( "#gateway" ).autocomplete({
source: 'search.php'
});
});
//button click function
$(".button").click(function(event){
if ((document.getElementsByName("gateway")[0].value == '')) {
alert('Gateway Required!');
return false;
}
else if (document.querySelectorAll('input[type="radio"]:checked').length < 1) {
alert('Please Choose Value!');
return false;
}
else {
//alert('Sucess!');
event.preventDefault();
$.ajax({
url:"testexe.php",
type: "POST",
data: {
gateway: gateway, //when I add this it give me the error
option: $('input[type=radio]:checked').val()
},
dataType: "text",
success:function(result){
$('#div1').html(result)
}
});
return true;
}
});
</script>
<div id="div1"></div>
</body>
</html>
testexe.php
<?php
//when the submit button is clicked
if ($_SERVER['REQUEST_METHOD'] == 'POST'){
echo "yay I got the POST!";
if(isset($_POST['gateway']){
$gateway = $_POST['gateway'];
echo $gateway;
}
}
(removed code for simplicity)
?>
search.php
<?php
//database configuration
$dbHost = 'localhost';
$dbUsername = 'user';
$dbPassword = '';
$dbName = 'database';
//connect with the database
$db = new mysqli($dbHost,$dbUsername,$dbPassword,$dbName);
if(isset($_GET['term'])){
//get search term
$searchTerm = $_GET['term'];
//get matched data from skills table
$query = $db->query("SELECT * FROM table WHERE tablename LIKE '%".$searchTerm."%' ORDER BY tablename ASC");
while ($row = $query->fetch_assoc()) {
$data[] = $row['tablename'];
}
//return json data
echo json_encode($data);
mysqli_close($db);
}
?>
错误消息:
Uncaught RangeError: Maximum call stack size exceeded
at Function.type (jquery-3.2.1.min.js:2)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
at Ab (jquery-3.2.1.min.js:4)
2个回答
这里有一个解决方案
$.ajax({
url:"testexe.php",
type: "POST",
data: {
gateway: $("#gateway").val(),
option: $('input[type=radio]:checked').val()
},
dataType: "text",
success: function(result){
$('#div1').html(result)
}
});
错误是
gateway: gateway
。
我假设您想从
input textbox
传递
gateway
值。
更改代码
gateway: $("#gateway").val(),
希望这会对您有所帮助。
Shiladitya
2017-08-31
gateway: $("#gateway").val(),
您必须使用此方法获取网关的值,就像您对选项所做的那样
gateway: gateway, //when I add this it give me the error
option: $('input[type=radio]:checked').val()
Bhupender Singh
2021-05-19