Javascript 使用Ajax向PHP发送数据
我试图使用GET方法通过ajax发送一个字符串,但是每当该字符串包含一些标点字符时,当我在php中使用echo时,这些字符就不会出现 例如,如果我发送一个字符串“sub+12”,php将回显“sub 12” 如果我发送“&()*”,php将回显一个空字符串 为什么会发生这种情况?Javascript 使用Ajax向PHP发送数据,javascript,php,ajax,Javascript,Php,Ajax,我试图使用GET方法通过ajax发送一个字符串,但是每当该字符串包含一些标点字符时,当我在php中使用echo时,这些字符就不会出现 例如,如果我发送一个字符串“sub+12”,php将回显“sub 12” 如果我发送“&()*”,php将回显一个空字符串 为什么会发生这种情况? 是否有字符串不能包含的特殊字符?在发送请求之前使用。在发送请求之前使用。您可以使用encodeURIComponent()。这是您可以检查的演示代码 类似这样的encodeURIComponent(yourtext)
是否有字符串不能包含的特殊字符?在发送请求之前使用。在发送请求之前使用。您可以使用
encodeURIComponent()
。这是您可以检查的演示代码
类似这样的encodeURIComponent(yourtext)
首先是这个html代码。在文本字段中输入文本并检查此输出,这是onkeyup,因此输入文本并检查结果
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>PHP, jQuery search demo</title>
<link rel="stylesheet" type="text/css" href="my.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$("input").keyup(function () {
$('#results').html('');
var searchString = $("#search_box").val();
var data = 'search_text=' + encodeURIComponent(searchString);
if (searchString) {
$.ajax({
type: "GET",
url: 'edit.php',
data: data,
dataType: 'text',
async: false,
cache: false,
success: function (result) {
$('#results').html(result);
//window.location.reload();
}
});
}
});
});
</script>
</head>
<body>
<div id="container">
<div style="margin:20px auto; text-align: center;">
<form method="post" action="do_search.php">
<input type="text" name="search" id="search_box" class='search_box'/>
<input type="submit" value="Search" class="search_button"/><br/>
</form>
</div>
<div>
<div id="searchresults">Search results :</div>
<ul id="results" class="update">
</ul>
</div>
</div>
</body>
</html>
您可以
encodeURIComponent()
。这是您可以检查的演示代码
类似这样的encodeURIComponent(yourtext)
首先是这个html代码。在文本字段中输入文本并检查此输出,这是onkeyup,因此输入文本并检查结果
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>PHP, jQuery search demo</title>
<link rel="stylesheet" type="text/css" href="my.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$("input").keyup(function () {
$('#results').html('');
var searchString = $("#search_box").val();
var data = 'search_text=' + encodeURIComponent(searchString);
if (searchString) {
$.ajax({
type: "GET",
url: 'edit.php',
data: data,
dataType: 'text',
async: false,
cache: false,
success: function (result) {
$('#results').html(result);
//window.location.reload();
}
});
}
});
});
</script>
</head>
<body>
<div id="container">
<div style="margin:20px auto; text-align: center;">
<form method="post" action="do_search.php">
<input type="text" name="search" id="search_box" class='search_box'/>
<input type="submit" value="Search" class="search_button"/><br/>
</form>
</div>
<div>
<div id="searchresults">Search results :</div>
<ul id="results" class="update">
</ul>
</div>
</div>
</body>
</html>
请出示相关代码好吗?出示您尝试的代码好吗?出示您尝试的代码好吗?出示您尝试的代码非常感谢,编码器组件是我所需要的全部!非常感谢,我只需要一个组件!
&()*