我是AJAX新手,在将变量传递回 HTML 脚本时遇到了一些问题。
我使用XAMPP网络服务器、JavaScript和jQuery作为 HTML 脚本和Perl cgi脚本作为后端。
我需要获取一个输入字符串,将其传递给 CGI 脚本,在那里它将在 Perl 函数中使用。Perl cgi 脚本生成的字符串变量需要传回 HTML 前端,并用于$(document).ready(function(){})
.
到目前为止,我能够将用户定义的输入传递给 cgi 脚本并将结果显示为简单的 HTML 文本。但是如何将 cgi 输出用作进一步 JavaScript/jQuery 函数的变量?
任何帮助将不胜感激。
这是我的 HTML 和 JavaScript 代码:
<!doctype html>
<html>
<head>
<title>AJAX example</title>
<script type="text/javascript" src="_lib/jquery.js"></script>
<script type="text/javascript" src="jquery.jstree.js"></script>
<script type="text/javascript">
$(document).ready(function() {
/*
I need to use the string variable "#searchtext" in this example function:
$("#filter").click(function () {
$("#testtree").jstree("search",$("#searchtext").val());
});
*/
});
</script>
<script language="Javascript">
function xmlhttpPost(strURL) {
var xmlHttpReq = false;
var self = this;
// Mozilla/Safari
if (window.XMLHttpRequest) {
self.xmlHttpReq = new XMLHttpRequest();
}
// IE
else if (window.ActiveXObject) {
self.xmlHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
}
self.xmlHttpReq.open('POST', strURL, true);
self.xmlHttpReq.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
self.xmlHttpReq.onreadystatechange = function() {
if (self.xmlHttpReq.readyState == 4) {
updatepage(self.xmlHttpReq.responseText);
}
}
self.xmlHttpReq.send(getquerystring());
}
function getquerystring() {
var form = document.forms['f1'];
var word = form.word.value;
qstr = 'w=' + escape(word);
return qstr;
}
function updatepage(str){
document.getElementById("result").innerHTML = str;
}
</script>
</head>
<body>
<form name="f1">
<p>word: <input name="word" type="text">
<input value="Go" type="button" onclick='JavaScript:xmlhttpPost("/cgi-bin/ajax_test.cgi")'></p>
<div id="result"></div>
</form>
</body>
</html>
这是我的 Perl 脚本 ajax_test.cgi:
#!/usr/bin/perl -w
use strict;
use warnings;
use CGI;
my $query = new CGI;
my $word = $query->param('w');
print $query->header;
print "<p>You are searching for: <b>$word</b>.</p>";
更新:
我尝试使用collapsar建议的第一个解决方案,但我仍然不确定将 js 变量放在哪里,因为我需要能够在以下位置调用它们$(document).ready(function(){})
:
<script language="Javascript">
function xmlhttpPost(strURL) {
//...//
}
function getquerystring() {
//..//
}
function updatepage(str){
//...//
}
var resp_html = self.xmlHttpReq.responseText;
var resp_dom = jQuery.parseHTML(resp_html );
var mydata1 = $('#<custom-id-1>', resp_dom).text();
// the alert doesn't work
$("#alertbutton").click(function () {
alert( "You entered: " + mydata1);
});