Ajax前台与Mod_python后台应用示例
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之中。
该方法可以实现完美的浏览器兼容。
Ajax前台与Mod_python后台应用示例的更多相关文章
- ajax前台数据到后台
var username = $("#id").val(); var user={"userAccount":username,"userPasswo ...
- ajax前台传到后台乱码,显示问号的问题
response.setContentType("text/html;charset=gbk"); response.setHeader("Cache-Control&q ...
- 解决Ajax前台中文传到后台出现中文乱码
遇到的问题是: 前台利用Ajax, get方式向后台发送中文数据出现乱码. 解决办法是前台两次编码, 后台一次解码即可. 前台jsp文件 1 var text = "张三"; 3 ...
- JAVA WEB 前台实时监控后台程序运行
基本思路: 1. 操作状态在类中以静态变量方式(或公共类存储公共变量方式,SESSION方式.COOKIE方式)存在 2. 前台采用AJAX方式激发后台进行业务逻辑操作,并实时更新操作状态信息 3. ...
- aspx前台调用cs后台方法
随着对于mvc的习惯使用,aspx页面渐渐用的不怎么用了,主要是生命周期感觉上比较慢,要么就用html+handler一般处理程序来装下逼.虽然不用,但还是要给刚工作的人讲下,相信不少人都想过:既然前 ...
- ajax传递数组到后台
//实体类 public class Person { private int ID{get;set;} private string Name{get;set;} private int Age{g ...
- ASP.NET前台JS与后台CS函数如何互相调用
摘要: 在实际的Web开发中,我们可能会常常遇到后台调用前台JS代码或者前台JS调用后台代码的情况.今天就把比较实用的前后台相互调用的方法总结出来和大家分享. 在实际的Web开发中,我们可能会常常遇到 ...
- ASP.NET前台代码绑定后台变量方法总结
经常会碰到在前台代码中要使用(或绑定)后台代码中变量值的问题.一般有<%= str%>和<%# str %>两种方式,这里简单总结一下.如有错误或异议之处,敬请各位指教. 一方 ...
- 转:ASP.NET前台代码绑定后台变量方法总结
经常会碰到在前台代码中要使用(或绑定)后台代码中变量值的问题.一般有<%= str%>和<%# str %>两种方式,这里简单总结一下.如有错误或异议之处,敬请各位指教. 一方 ...
随机推荐
- LINUX下WIFI默认连接
#! /bin/sh ifconfig wlan0 upiwconfig wlan0 key 123456iwconfig wlan0 essid "rat-linux"iwcon ...
- 【Android 系统开发】Android JNI/NDK (三) 之 JNIEnv 解析
jni.h文件 : 了解 JNI 需要配合 jni.h 文件, jni.h 是 Google NDK 中的一个文件, 位置是 $/Android-ndk-r9d/platforms/android-1 ...
- Python复习笔记-字典和文件操作
抽时间回顾2年前自己做过的python工具,突然感觉不像自己写的,看来好久没用过python的字典和文件操作了,查询资料和网页,整理如下: 一.字典 键值对的集合(map) 字典是以大括号“{}”包围 ...
- 纸上谈兵:栈(stack)
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 栈(stack)是简单的数据结构,但在计算机中使用广泛.它是有序的元素集合.栈最显 ...
- 浅谈js的键值对key和value
> 昨晚无意中看到类似下面结构的一段代码的取值问题,引起我的兴趣,花了点时间写了个demo给大家分享一下... var obj = [ {"2011":{"name ...
- Android开发--布局
一:LinearLayout 1.线性布局,这个东西,从外框上可以理解为一个div,他首先是一个一个从上往下罗列在屏幕上.每一个LinearLayout里面又可分为垂直布局(android:orie ...
- Python函数中的参数(二)
当使用混合特定的参数匹配模型时,Python将会遵循以下有关顺序的法则: 1.在函数调用中,参数必须以这样的顺序出现:任何位置参数(Value).任何关键字参数(name = Value)和*sequ ...
- Yarn&Mapreduce参数的具体含义和配置参考
Yarn & Mapreduce 参数的具体含义和配置 http://zh.hortonworks.com/blog/how-to-plan-and-configure-yarn-in-hdp ...
- JavaScript Function(函数表达式)
创建函数 创建函数的方式有两种:1.函数声明,2.函数表达式 函数声明的语法为 functionName(); //不会报错,函数声明提升function functionName(arg0,arg1 ...
- java 字节数组转int
4字节数组转int类型 小端模式 /** * 数组转int类型 * * @param src * @return */ public static int bytesToInt(byte[] src) ...