Jquery+Json+Handler文件结合应用实例
1、页面script代码-【model数据、字符串】
<script type="text/javascript" charset="utf-8" src="Js/jquery-1.6.2.min.js"></script>
<script type="text/javascript">
//提交验证
function ChekFrom()
{
var msg = "";
//取值
var UserName = $("#txtUserName").val();
//验证
if (UserName == "") {
msg += "用户名为空!/r/n";
} else {
$.ajax({
type: "POST",
url: "/Controller/UserHandler.ashx",
data: { Action: "IsUserName", UserName: UserName },
cache: false, //设置时候从浏览器中读取 缓存 true 表示 是
datatype: "json",
async: false,
success: function (result) {
if (result.code == 1) {
msg += "该用户名已存在!/r/n";
}
}
});
}
if (msg == "") {
return true;
} else {
alert(msg);
return false;
}
}
//总计金额 可以写成js方法
function BuyTotal() {
var Total = $.ajax({
type: "POST",
dataType: text,//xml html script json
url: "/Controller/UserHandler.ashx",
data: { Action: "BuyTotal" },
async: false
}).responseText;
return Total;
}
</script>
2、返回Model的handler代码
<%@ WebHandler Language="C#" Class="UserHandler" %>
using System;
using System.Web;
using ECS.Utility;
using System.Collections.Generic;
//使用session的时候必须继承IRequiresSessionState接口:, System.Web.SessionState.IRequiresSessionState
public class UserHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
//全局默认返回信息
string Json = JsonUtil.Serialize(new { code = 0, msg = "" });
//取值
string Action = context.Request.Form["Action"] == null ? "" : context.Request.Form["Action"].ToString().Trim();
string UserName = context.Request.Form["UserName"] == null ? "" : context.Request.Form["UserName"].ToString().Trim();
//判断
if (!string.IsNullOrEmpty(Action))
{
//验证用户
if (Action.Equals("IsUserName"))
{
//验证
if (IsExistUser(UserName))
{
Json = JsonUtil.Serialize(new { code = 1, msg = "用户名已存在!" });
}
else
{
Json = JsonUtil.Serialize(new { code = 0, msg = "用户名可以注册!" });
}
}
//计算金额
if (Action.Equals("BuyTotal"))
{
//Json格式
//Json = JsonUtil.Serialize(new { code = 1, msg = "成功", Total = 100 });
//
Json = "100";
}
else
{ //Json格式
//Json = JsonUtil.Serialize(new { code = 0, msg = "失败", Total = 0 });
Json = "0";
}
}
//最终返回信息
context.Response.Write(Json);
}
/// <summary>
/// 判断UserName是否存在
/// </summary>
/// <param name="userName">用户名</param>
/// <returns>返回true or false</returns>
public bool IsExistUser(string userName)
{
List<LSY.Model.A_User> UserList = new LSY.BLL.A_User().GetList(null, "UserName='" + userName.Trim() + "'and Type=0", null);
if (UserList.Count > 0)
{
return true;
}
else
{
return false;
}
}
public bool IsReusable
{
get
{
return false;
}
}
}
3、页面script代码-【DataTable、List】
//查询城市
function getCity(CityVal) {
var DDL_Province = $("#DDL_Province");
var DDL_City = $("#DDL_City");
DDL_City.empty();
DDL_City.append("<option value=\"0\">市/区</option>");
$.ajax(
{
type: "post",
url: "/UserCart/Controller/CityAreas.ashx",
data: { "type": "city", "provinceID": DDL_Province.val() },
dataType: "json",
async: false,
success: function (msg) {
for (var i = 0; i < msg.length; i++) {
if (CityVal == msg[i].CityName) {
if (msg[i].IsCOD == 1) {
DDL_City.append("<option value=" + msg[i].CityID + " selected=\"selected\">" + msg[i].CityName + "*</option>");
} else {
DDL_City.append("<option value=" + msg[i].CityID + " selected=\"selected\">" + msg[i].CityName + "</option>");
}
} else {
if (msg[i].IsCOD == 1) {
DDL_City.append("<option value=" + msg[i].CityID + " >" + msg[i].CityName + "*</option>");
} else {
DDL_City.append("<option value=" + msg[i].CityID + " >" + msg[i].CityName + "</option>");
}
}
}
getArea('');
GetAddreesSpan();
}
})
};
4、返回数据集Handler代码
<%@ WebHandler Language="C#" Class="CityAreas" %>
using System;
using System.Web;
using System.Collections.Generic;
public class CityAreas : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Request["type"] == "city")
{
context.Response.Write(select2(context.Request["provinceID"]));
}
else if (context.Request["type"] == "district")
{
context.Response.Write(select3(context.Request["cityID"]));
}
}
public string select2(string id)
{
string str = string.Empty;
if (!string.IsNullOrEmpty(id))
{
List<ECS.Model.A_CityAreas> list = new ECS.BLL.A_CityAreas().GetList(null, "deep=2 and ParentID=" + id, null);
if (list != null && list.Count > 0)
{
System.Text.StringBuilder sb = new System.Text.StringBuilder();
sb.Append("[");
foreach (ECS.Model.A_CityAreas item in list)
{
sb.Append("{");
sb.Append("\"CityID\":\"" + item.id + "\",\"CityName\":\"" + item.AreaName + "\",\"IsCOD\":\"" + item.IsCOD + "\"");
sb.Append("},");
}
sb.Remove(sb.Length - 1, 1);
sb.Append("]");
str = sb.ToString();
}
}
return str;
}
public string select3(string id)
{
string str = string.Empty;
if (!string.IsNullOrEmpty(id))
{
List<ECS.Model.A_CityAreas> list = new ECS.BLL.A_CityAreas().GetList(null, "deep=3 and ParentID=" + id, null);
if (list != null && list.Count > 0)
{
System.Text.StringBuilder sb = new System.Text.StringBuilder();
sb.Append("[");
foreach (ECS.Model.A_CityAreas item in list)
{
sb.Append("{");
sb.Append("\"DistrictID\":\"" + item.id + "\",\"DistrictName\":\"" + item.AreaName + "\",\"IsCOD\":\"" + item.IsCOD + "\"");
sb.Append("},");
}
sb.Remove(sb.Length - 1, 1);
sb.Append("]");
str = sb.ToString();
}
}
return str;
}
public bool IsReusable
{
get
{
return false;
}
}
}
Jquery+Json+Handler文件结合应用实例的更多相关文章
- Jquery Uploadify多文件上传实例
jQuery Uploadify开发使用的语言是java. 详细的相关文档,可以参考官网的doc:http://www.uploadify.com/documentation/ 官网的讲解还是很详细的 ...
- jQuery插件AjaxFileUpload文件上传实现Javascript多文件上传功能
Ajax file upload plugin是一个功能强大的文件上传jQuery插件,可自定义链接.或其它元素庖代传统的file表单上传结果,可实现Ajax动态提示文件上传 过程,同时支撑多文 ...
- JQuery 获取json数据$.getJSON方法的实例代码
这篇文章介绍了JQuery 获取json数据$.getJSON方法的实例代码,有需要的朋友可以参考一下 前台: function SelectProject() { var a = new Array ...
- Struts2+JQuery+Json登陆实例
Struts2+JQuery+Json登陆实例 博客分类: Struts2 在搭建之前.. 首先,需要准备struts2.0框架的5个核心包, 以及jsonplugin-0.32.jar 以及js ...
- jquery ajax返回json数据进行前后台交互实例
jquery ajax返回json数据进行前后台交互实例 利用jquery中的ajax提交数据然后由网站后台来根据我们提交的数据返回json格式的数据,下面我来演示一个实例. 先我们看演示代码 代码如 ...
- python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码
python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码 python的json.dumps方法默认会输出成这种格式"\u535a\u ...
- jquery下json数组的操作用法实例
jquery下json数组的操作用法实例: jquery中操作JSON数组的情况中遍历方法用的比较多,但用添加移除这些好像就不是太多了. 试过json[i].remove(),json.remove( ...
- jQuery FileUpload等插件的使用实例
1.jQuery FileUpload 需要的js: jquery.js jquery.fileupload.js jquery.iframe-transport.js jquery.xdr-tran ...
- JS jQuery json日期格式问题的办法
原生JS:Date对象详细参考 Date对象:基于1970年1月1日(世界标准时间)起的毫秒数 本文参考MDN做的详细整理,方便大家参考MDN 构造函数: new Date(); 依据系统设置的当前时 ...
随机推荐
- Python基础篇(六)
retun空值,后面的语句将不再被执行 >>> def test(): ... print("just a test!") ... return .. ...
- C语言深度剖析-笔记
关键字: C语言关键字32个: 关键字 意 义 auto 声明自动变 ...
- D 区间求和 [数学 树状数组]
D 区间求和 题意:求 \[ \sum_{k=1}^n \sum_{l=1}^{n-k+1} \sum_{r=l+k-1}^n 区间前k大值和 \] 比赛时因为被B卡了没有深入想这道题 结果B没做出来 ...
- zabbix-agent 启动不起来
遇到一个问题 zabbix-agent 一直启动不起来 查看Zabbix Agent日志文件才究其原因. tail /var/log/zabbix/zabbix_agentd.logzabbix_a ...
- 插入排序Insertion Sort
插入排序:将一个数据插入到一个已经排好序的有序数据序列中,从而得到一个新的.个数+1的有序数列:插入排序适用于少量数据排序,时间复杂度为O(n^2). 实现思路:1.对于一个无序数组,选取第一个元素, ...
- Vue.js响应式原理
写在前面 因为对Vue.js很感兴趣,而且平时工作的技术栈也是Vue.js,这几个月花了些时间研究学习了一下Vue.js源码,并做了总结与输出. 文章的原地址:answershuto/learnV ...
- nf共享
实验环境是两台Centos6.8 客户端是192.168.3.218 服务端是192.168.3.219 首先配置服务端 1 安装包 用yum安装需要的服务包(两边都安装) yum install n ...
- NDK 开发中,各种指令集的坑,arm64
最近在NDK开发中遇到了一个奇怪的问题,希望记录下,可以帮到大家: 我编译了一些 .so 动态库,只编译了armeabi-v7a.armeabi 指令集,其它指令集编译不了 ...
- 【Unity3D技术文档翻译】第1.4篇 AssetBundle 依赖关系
上一章:[Unity3D技术文档翻译]第1.3篇 创建 AssetBundles 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced Develo ...
- 03 JVM的垃圾回收机制
1.前言 理解JVM的垃圾回收机制(简称GC)有什么好处呢?作为一名软件开发者,满足自己的好奇心将是一个很好的理由,不过更重要的是,理解GC工作机制可以帮助你写出更好的Java程序. 在学习GC前,你 ...