java ashx_.net Ajax与后台一般处理程序(ashx) 交互

本文将为您描述.net Ajax与后台一般处理程序(ashx) 交互,教程操作步骤:

本文主要实现无动态刷新查询后台数据功能,主要用到ajax+ashx+sqlserver进行交互.

首先需要引用Jquery:

html脚本:

前台通过一个事件来调用ashx:

$(function () {

$("#tb_corpName").blur(function () {    //鼠标失去焦点事件

var corpName = $("#tb_corpName").val();

$.ajax({

type: "post", //提交方式

url: "/ashx/FZGpyShowData.ashx", //一般处理程序的路径

data: { corpName: corpName }, //向后台传入的值

dataType: "json", //返回值格式

success: function (data) { //返回成功后将要做的事,这里是返回一个表

$("#tb_CreditCode").val(data[0].CreditCode);

$("#tb_corpCode").val(data[0].CorpCode);

$("#tb_linkTel").val(data[0].LinkPhone);

$("#corpProvince option[text='" + data[0].StateName + "']").attr("selected", true);

showCity();

$("#corpCity option[text='" + data[0].AdminAreaName + "']").attr("selected", true);

$("#tb_address").val(data[0].Address);

$("#tb_linkMan").val(data[0].LinkMan);

$("#tb_Mobile").val(data[0].LinkMobile);

}

});

})

})

后台来接收前台传过来的值,对其进行操作:

public void ProcessRequest(HttpContext context)

{

context.Response.ContentType = "text/plain";

string corpName = context.Request["corpName"].Trim().ToString();      //接收前台传过来的参数

if (corpName != "")

{

string sql = @"select top 1 CorpName,CreditCode,CorpCode,LinkPhone,StateName,AdminAreaName,LinkMan,LinkMobile,Address from tbProductOrder as a

inner join tbStateDic as b on a.StateNum = b.StateNum

inner join tbAdminAreaClass on a.CityNum = AdminAreaClassID

where CorpName =@CorpName order by CorpName";

SqlParameter[] par = new SqlParameter[1];

par[0] = new SqlParameter("@CorpName", corpName);

DataSet ds = DBHerpler.Load(sql, par);

string json = SerializerHelper.ToJsonString(ds.Tables[0]);    //返回json类型的数据

context.Response.Write(json);

context.Response.End();

}

}

SerializerHelper类的定义:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Text;

using System.IO;

using System.Xml.Serialization;

using Newtonsoft.Json;

///

/// SerializerHelper 的摘要说明

///

public static class SerializerHelper

{

///

/// 反序列化XML文件

///

public static T LoadFromXmlFile(string filepath) where T : class

{

using (FileStream stream = new FileStream(filepath, FileMode.Open, FileAccess.Read))

{

XmlSerializer serializer = new XmlSerializer(typeof(T));

return (T)serializer.Deserialize(stream);

}

}

///

/// 反序列化XML字符串

///

public static T LoadFromXmlString(string xml) where T : class

{

XmlSerializer serializer = new XmlSerializer(typeof(T));

byte[] bytes = Encoding.UTF8.GetBytes(xml);

using (MemoryStream stream = new MemoryStream(bytes))

{

return (T)serializer.Deserialize(stream);

}

}

///

/// 序列化XML对象

///

public static string SaveToXmlString(T entity) where T : class

{

using (MemoryStream stream = new MemoryStream())

{

XmlSerializer serializer = new XmlSerializer(typeof(T));

serializer.Serialize(stream, entity);

return Encoding.UTF8.GetString(stream.ToArray());

}

}

///

/// 序列化Json对象

///

public static string ToJsonString(object obj)

{

return ToJsonString(obj);

}

///

/// 序列化Json对象

///

public static string ToJsonString(T obj) where T : class

{

string text = JsonConvert.SerializeObject(obj);

return text;

}

///

/// 反序列化Json字符串

///

public static T ToJsonObject(string text) where T : class

{

T obj = (T)JsonConvert.DeserializeObject(text, typeof(T));

return obj;

}

}

如果向后台传入多个参数在data里面用逗号分割可写多个参数:

data: { corpName: corpName , corpName2: corpName2}.net Ajax与后台一般处理程序(ashx) 交互就为您介绍到这里,感谢您关注懒咪学编程c.lanmit.com.

本文地址:https://c.lanmit.com/bianchengkaifa/net/18253.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值