这里有几点。 我们用asp.net开发数据库应用时。时常要建立一些实体如 ![]()
public class UserEntity ...{ public string UserName ...{ get...{ return "";} } public string UserEmail ...{ get...{ return "" ;} } } |
下面要讲的是如何使用脚本来模拟这种实体
首先 要讲解概念 要返还类似这种实体脚本可以这么写
UserEntity=function() ...{ return ...{"UserName":"shenyi","UserEmail":"shenyi@csdn.net"} } |
这样我们在 脚本中只要写
var scriptEntity=new UserEntity(); scriptEntity.UserName; scriptEntity.UserEmail; |
就可以引用到,好 脚本实体构建好了。接下来我们要从服务器取数据如下
新建一个aspx页面 假如叫 getData.aspx 在代码里写
![]()
public void Page_load() ...{ int userid=int.parse(Request.QueryString["uid"].ToString()); string sql="select * from Users where userid="+userid.ToString(); using(DataTable dt=SqlHelper.ExecuteDataSet(sql).Tables[0]) //SqlHelper 不要告诉我 不知道是什么 ...{ // 这里构建一个 字符 令 一个 脚本变量 等于 {"UserName":dt.rows[0]["username].......} //如 Response.Write("userReturnValue={.......//这里自己拼接}"); Response.End(); } } |
以下是如何把脚本和这个 aspx页面建立联系 如下直接是代码
var UserReturnValue="" //这个很重要一定要定义 因为在服务端要对其赋值 ComJS=function() ...{ this.GetEntitying=function(uid,callback) ...{ var scriptObj=document.createElement("script"); scriptObj.type="text/javascript"; scriptObj.src="getData.aspx?uid="+uid document.getElementsByTagName("head")[0].appendChild(scriptObj); scriptObj.onreadystatechange=function() ...{ if(scriptObj.readyState=="loaded") ...{ callback.EndGetEntity(UserReturnValue); } } } } |
这里使用 callback回调 是最重要的一步 当脚本加载完毕后才会对UserReturnValue 进行赋值 因此我们不能直接获得这个实体.
上面脚本写完后 我们在页面要开始获得这个实体
var cjs=new ComJS(); //初始化我们的脚本对象 function BeginGetEntity() ...{ this.EndGetEntity=function(entityDataList) ...{ //entityDataList 这个就是最终的实体对象 你可以直接 用 entityDataList.UserName 或者 entityDataList.表里字段名 //来获取这个实体的对象 // 注意 业务操作 要在这个 函数内执行。因为这是一个回调。也就是当服务端把数据取到了 这边才开始执行 严格来说就是异步获取数据。类似Ajax 但是不使用 xmlhttp对象 } } var bge=new BeginGetEntity(); cjs.GetEntity("3",bgelist); //这里的3代表我要取用户id等于3的 数据 |
整个用脚本构建实体的方法写好 希望对大家尤其是初学者 会有点用。其实在脚本中要实现ajax不光只有xmlhttp可以实现 很普通的脚本也能实现
更多内容请看PCdog.com--Ajax技术 Ajax框架与实例专题
