首页 技术 正文
技术 2022年11月10日
0 收藏 868 点赞 5,114 浏览 4651 个字

Ajax的好处就是可以实现无刷新动态更新。后台配合Mod_python程序,使后台处理变得非常高效简洁。【index.html】

<HTML>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Ajax测试页面</title><script language="JavaScript">function checkForm(){
var messageDiv = document.getElementById("msgDiv");
var product = document.getElementById("product");
var pvalue = product.options[product.selectedIndex].value;
var svalue = document.getElementById("sn").value;if(svalue == ""){
messageDiv.style.color = "Red";
messageDiv.innerHTML = "请输入序列号!";
return false;
}
//alert(svalue);
//var par = "pv=" + pvalue + "&sv=" + svalue
var par = "sv=" + svalue if (pvalue == 0){
sendRequest("mypython/pro1", par);
return true;
}else{
messageDiv.innerHTML = "抱歉,该产品信息尚未入库!";
return false;
}
}function sendRequest(url, par){
//注意,这里定义的是一个局部变量,即每调用一次都创建一个新的XMLHttpRequest对象,即发送一个新的请求
var xmlHttp = false;
if(window.XMLHttpRequest){ //for mozilla
xmlHttp = new XMLHttpRequest();
}else if(window.ActiveXObject){//for IE
try{
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
}catch(e){
try{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){ }
}
}
xmlHttp.open("POST",url,true);
xmlHttp.onreadystatechange = function(){
if(xmlHttp.readyState == 4) {
if(xmlHttp.status == 200) {
//alert("123456");
var mdiv = document.getElementById("msgDiv");
mdiv.style.color = "Red";
mdiv.innerHTML = xmlHttp.responseText;
}else
alert("Error!" + "\nStatus code is: " + xmlHttp.status + "\nStatus text is: " + xmlHttp.statusText);
}
}
xmlHttp.setRequestHeader("Content-length", par.length);
xmlHttp.setRequestHeader("Content-Type","text/xml");
    //xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded;charset=utf-8");
xmlHttp.send(par); // 名=值&名=值&名=值...
}</script></head>
<Body style="background-color:#e0f4df">
<br/>
<br/>
<br/>
<br/>
<br/>
<div align="center"><!--为什么不能用Form表单,因为表单必需有返回,会导致当前页面闪烁或是跳转 -->
<!--form name="myform" id="myform" action="" method="POST" onsubmit="return checkForm()"-->
<table border="1px" cellspacing="0px" cellpadding="0px">
<tr><td>请选择产品的型号:</td><td>
<select id="product">
<option value ="0">3D打印机</option>
<option value ="1">3D扫描仪</option>
</select>
</td></tr>
<tr><td>请输入产品序列号:</td><td>
<input id="sn" type="text" size="14" value="" />
</td></tr>
<tr><td colspan="2" align="center">
<button onClick="return checkForm()">点击查询</button>
</table>
<!--/form -->
</div>
<br/>
<div align="center" id="msgDiv"></div>
</Body>
</HTML>

然后就是后台的mod_python程序:【mypython.py】

#!/usr/bin/python
# -*-coding:UTF-8-*-from mod_python import apache, util
from MySQLdb import *def pro1(req, sv):
svalue = sv
req.write(svalue)

只要保证前台Ajax所Post的参数名称 与 mod_python 指定的参数名称一致(如“sv”),就可以获取前台传递过来的参数了。

该方法可以在Firefox上完美的工作,但在其它浏览器则返回501:method not implemented 错误信息。

搜索了很久发现是由于Ajax请求发送的标准数据类型:

xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded;charset=utf-8")

导致的。好像是mod_python/util.py 无法正确解析,应该是mod_python的一个bug.

最终没有找到好的解决方法,最后只能选择一个替代方案:Form + iFrame 的方式来实现无刷新提交。【index.html】

<HTML>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>iFrame测试页面</title><script language="JavaScript">function checkForm(){
var messageDiv = document.getElementById("msgDiv");
var product = document.getElementById("product");
var pvalue = product.options[product.selectedIndex].value;
var svalue = document.getElementById("sn").value;if(svalue == ""){
messageDiv.style.color = "Red";
messageDiv.innerHTML = "请输入序列号!";
return false;
}
if (pvalue == 0){ //R2
return true;
}else{
messageDiv.innerHTML = "抱歉,该产品信息尚未入库!";
return false;
}
}function callback(msg){
var mdiv = document.getElementById("msgDiv");
mdiv.innerHTML = msg;
}</script></head>
<Body style="background-color:#e0f4df">
<br/>
<br/>
<br/>
<br/>
<br/>
<div align="center"><!--为什么不能用Form表单,因为表单必需有返回,会导致当前页面闪烁或是跳转 -->
<form name="myform" id="myform" action="mypython/pro1" method="POST" target="i_frame" onsubmit="return checkForm()">
<table border="1px" cellspacing="0px" cellpadding="0px">
<tr><td>请选择产品的型号:</td><td>
<select name="pv" id="product">
<option value ="0">3D打印机</option>
<option value ="1">3D扫描仪</option>
</select>
</td></tr>
<tr><td>请输入产品序列号:</td><td>
<input name="sv" id="sn" type="text" size="14" value="" />
</td></tr>
<tr><td colspan="2" align="center">
<input type="submit" value="点击查询"></td></tr>
</table>
</form>
</div>
<br/>
<div align="center" id="msgDiv"></div>
<iframe name="i_frame" width="1px" height="1px" style="display:none" ></iframe>
</Body>
</HTML>

注意,必需定义一个iframe,但width与height不能设置为0px 。然后form里面的target属性必需指定成iframe的name值(如“sv”)。Form里面需要提交到后台的节点需设置name属性。

后台mod_python程序:【mypython.py】

#!/usr/bin/python
# -*-coding:UTF-8-*-from mod_python import apache, util
from MySQLdb import *def pro1(req, sv):
svalue = str(sv)
return "<html><body onload=\"javacript: parent.callback('" + svalue + "')\"></body></html>"

必需使用return返回数据前台才能收到。

可以看到返回的是一段简单的HTML代码,该代码会返回到前台的iFrame里面。且一加载就会运行一句javascript代码。该javascript代码会调用前台父页面的callback()函数把返回的信息输出到指定的DIV之中。

该方法可以实现完美的浏览器兼容。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,117
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,590
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,435
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,206
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,842
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,927