ASP网页设计XMLHTTP无革新增加数据
想法是和程序员的想法不一样的.至于为什么.大家去想一想.跟心理学有关的xml|数据|革新|无革新使用XMLHTTP无革新增加数据之Get篇.前两篇次要写了从猎取数据.接上去,我们讲讲怎样增加数据.
我们传统的提交数据的办法都是用<Form>来完成的.
<Form>标志中的Method属性断定了表单位素的数据在发送到服务器时,
怎样对HTTP哀求信息举行打包.
Method属性可使用的办法
Method属性发送表单位素的体例读取数据的Request汇合
Get标识在URL的最初QueryString
Post在HTTP哀求的主体内(HTTP哀求的自在地区)Form
这篇文章用XMLHTTP来完成Form的Method=Get.
ClientGet.htm
<scriptlanguage="JavaScript">
functionAddDataGet(sUserId,sUserName)
{
/*
*---------------AddDataGet(sUserId,sUserName)-----------------
*AddDataGet(sUserId,sUserName)
*功效:经由过程XMLHTTP增加数据.相称于Form的Method=Get.
*参数:sUserId,字符串,发送前提.
*参数:sUserName,字符串,发送前提.
*实例:AddDataGet(document.all.userid.value,document.all.username.value);
*author:wanghr100(灰豆宝宝.net)
*update:2004-5-3014:46
*---------------AddDataGet(sUserId,sUserName)-----------------
*/
varoBao=newActiveXObject("Microsoft.XMLHTTP");
//特别字符:+,%,&,=,?等的传输办理举措.用escape编码.
//Update:2004-6-112:22
//escape(sUserId),escape(sUserName);
oBao.open("POST","Server.asp?userid="+escape(sUserId)+"&username="+escape(sUserName),false);
oBao.send();
//清空输出框数据.
document.all.userid.value="";
document.all.username.value="";
//服务器端处置前往的是经由escape编码的字符串.
alert(unescape(oBao.responseText))
}
</script>
<inputtype="button"value="AddDataGet"><br>
userid:<inputtype="text"name="userid"><br>
username:<inputtype="text"name="username">
Server.asp服务器端处置.
<%@Language="JavaScript"%>
<%
functionOpenDB(sdbname)
{
/*
*---------------OpenDB(sdbname)-----------------
*OpenDB(sdbname)
*功效:翻开数据库sdbname,前往conn工具.
*参数:sdbname,字符串,数据库称号.
*实例:varconn=OpenDB("database.mdb");
*author:wanghr100(灰豆宝宝.net)
*update:2004-5-128:18
*---------------OpenDB(sdbname)-----------------
*/
varconnstr="Provider=Microsoft.Jet.OLEDB.4.0;DataSource="+Server.MapPath(sdbname);
varconn=Server.CreateObject("ADODB.Connection");
conn.Open(connstr);
returnconn;
}
varsResult="";
varoConn=OpenDB("data.mdb");
//相称于Form的Method=Get.
//相称于Form的Method=Get.
//特别字符:+,%,&,=,?等的传输办理举措.客户端传输过去是经由escape编码的.
//以是服用器端应当先用unescape解码.
//Update:2004-6-112:22
//unescape(Request.QueryString("userid")).....
varuserid=unescape(Request.QueryString("userid"));
varusername=unescape(Request.QueryString("username"));
sResult="userid:"+userid+"
username:"+username+"
增加乐成."
varsql="Insertintousers(userid,username)Values("+userid+","+username+")";
oConn.Execute(sql);
Response.Write(escape(sResult));
%>
数据库计划
data.mdb
表users.
字段
id主动编号
userid文本
username文本
表:users数据:
iduseridusername
1wanghr100灰豆宝宝.net
使用XMLHTTP无革新增加数据我们讲讲怎样增加数据.
我们传统的提交数据的办法都是用<Form>来完成的.
<Form>标志中的Method属性断定了表单位素的数据在发送到服务器时,
怎样对HTTP哀求信息举行打包.
Method属性可使用的办法
Method属性发送表单位素的体例读取数据的Request汇合
Get标识在URL的最初QueryString
Post在HTTP哀求的主体内(HTTP哀求的自在地区)Form
本文以Post办法为例,get办法更复杂
----------------------------------------------------------------------------------------------------------------------------
这篇文章用XMLHTTP来完成Form的Method=Post.
ClientPost.htm
<scriptlanguage="JavaScript">
functionAddDataPost(sUserId,sUserName)
{
/*
*---------------AddDataPost(sUserId,sUserName)-----------------
*AddDataPost(sUserId,sUserName)
*功效:经由过程XMLHTTP增加数据.相称于Form的Method=Post.
*参数:sUserId,字符串,发送前提.
*参数:sUserName,字符串,发送前提.
*实例:AddDataPost(document.all.userid.value,document.all.username.value);
*author:wanghr100(灰豆宝宝.net)
*update:2004-5-3014:46
*---------------AddDataPost(sUserId,sUserName)-----------------
*/
varoBao=newActiveXObject("Microsoft.XMLHTTP");
//特别字符:+,%,&,=,?等的传输办理举措.
//Update:2004-6-112:22
//escape(sUserId),escape(sUserName);
sUserId=escape(sUserId);
sUserName=escape(sUserName);
varuserInfo="userid="+sUserId+"&username="+sUserName;
oBao.open("POST","Server.asp",false);
oBao.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
oBao.send(userInfo);
//清空输出框数据.
document.all.userid.value="";
document.all.username.value="";
//服务器端处置前往的是经由escape编码的字符串.
alert(unescape(oBao.responseText))
}
</script>
<inputtype="button"value="AddDataPost"><br>
userid:<inputtype="text"name="userid"><br>
username:<inputtype="text"name="username">
Server.asp服务器端处置.
<%@Language="JavaScript"%>
<%
functionOpenDB(sdbname)
{
/*
*---------------OpenDB(sdbname)-----------------
*OpenDB(sdbname)
*功效:翻开数据库sdbname,前往conn工具.
*参数:sdbname,字符串,数据库称号.
*实例:varconn=OpenDB("database.mdb");
*author:wanghr100(灰豆宝宝.net)
*update:2004-5-128:18
*---------------OpenDB(sdbname)-----------------
*/
varconnstr="Provider=Microsoft.Jet.OLEDB.4.0;DataSource="+Server.MapPath(sdbname);
varconn=Server.CreateObject("ADODB.Connection");
conn.Open(connstr);
returnconn;
}
varsResult="";
varoConn=OpenDB("data.mdb");
//相称于Form的Method=Post.
//相称于Form的Method=Post.
//特别字符:+,%,&,=,?等的传输办理举措.客户端传输过去是经由escape编码的.
//以是服用器端应当先unescape解码.
//Update:2004-6-112:22
//unescape(Request.Form("userid")).....
varuserid=unescape(Request.Form("userid"));
varusername=unescape(Request.Form("username"));
sResult="userid:"+userid+"
username:"+username+"
增加乐成."
varsql="Insertintousers(userid,username)Values("+userid+","+username+")";
oConn.Execute(sql);
Response.Write(escape(sResult));
%>
数据库计划
data.mdb
表users.
字段
id主动编号
userid文本
username文本
表:users数据:
iduseridusername
1wanghr100灰豆宝宝.net
由于ASP还是一种Script语言所没除了大量使用组件外,没有办法提高其工作效率。它必须面对即时编绎的时间考验,同时我们还不知其背后的组件会是一个什么样的状况; 多看多学多思。多看一些关于ASP的书籍,一方面可以扩展知识面一方面可以鉴借别人是如何掌握、运用ASP的;多学善于关注别人,向同学老师多多学习,不论知识的大小;多思则是要将学到的知识灵活运用。 下载一个源代码,然后再下载一个VBScript帮助,在源代码中遇到不认识的函数或是其他什么程序,都可以查帮助进行解决,这样学习效率很高。 如何更好的使自己的东西看上去很不错等等。其实这些都不是问题的实质,我们可以在实践中不断提升自己,不断充实自己。 交流是必要的,不管是生活还是学习我们都要试着去交流,通过交流我们可以学到很多我们自己本身所没有的知识,可以分享别人的经验甚至经历。 封装性使得代码逻辑清晰,易于管理,并且应用到ASP.Net上就可以使业务逻辑和Html页面分离,这样无论页面原型如何改变,业务逻辑代码都不必做任何改动;继承性和多态性使得代码的可重用性大大提高。 我们必须明确一个大方向,不要只是停留在因为学而去学,我们应有方向应有目标. 作为IE上广为流传的动态网页开发技术,ASP以它简单易学博得了广大WEB程序爱好这的青睐,而且它对运行环境和开发品台的不挑剔,以及有大量有效的参考手册,极大的推广了它的发展。 接下来就不能纸上谈兵了,最好的方法其实是实践。实践,只能算是让你掌握语言特性用的。而提倡做实际的Project也不是太好,因为你还没有熟练的能力去综合各种技术,这样只能使你自己越来越迷糊。
页:
[1]