JS实现Ajax,Josn数据的序列化和反序列化---例: 省市区联动(包含get,post)

时间:2022-10-02 23:07:16

服务器端相应JOSN数据   用到序列化和反序列化----命名空间using System.Web.Script.Serialization;

 public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
//获取请求的参数
string id = context.Request["id"].ToString();
//通过参数查询父级id是参数的数据
DataClasses1DataContext db = new DataClasses1DataContext();
List<ChinaStates> list = db.ChinaStates.Where(p => p.ParentAreaCode == id).ToList();
//将查询到的数据序列化,,用到using System.Web.Script.Serialization;
JavaScriptSerializer jss = new JavaScriptSerializer();
//调用jss.Serialize(list)方法,,得到josn类型的字符串,使用时要反序列化,得到josn数组
string josnData = jss.Serialize(list);
context.Response.Clear();
context.Response.Write(josnData);
context.Response.End();
}

通过以上方法得到的JOSN数据----崩溃类型0.0

[{"AreaCode":"","AreaName":"河北","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"山西","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"内蒙古","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"辽宁","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"吉林","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"黑龙江","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"上海","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"江苏","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"浙江","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"安徽","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"福建","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"江西","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"山东","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"河南","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"湖北","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"湖南","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"广东","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"广西","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"海南","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"重庆","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"四川","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"贵州","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"云南","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"*","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"陕西","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"甘肃","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"青海","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"宁夏","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"*","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"*","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"香港","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null},{"AreaCode":"","AreaName":"澳门","ParentAreaCode":"","Root":false,"Zone":,"NavigateURL":null}]

JosnViewer---神兵利器!

JS实现Ajax,Josn数据的序列化和反序列化---例: 省市区联动(包含get,post)

JS实现Ajax代码

window.onload = function () {
LoadProv();
LoadCity();
LoadTown(); };//onload
 function LoadProv() {
//确认事件
//1.创建xhr对象
var xhr = null;
if (XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else if (ActiveXObject) {
xhr = new ActiveXObject("Microsoft.XMLHttp");
}
//2.设置回调函数
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
//将响应的数据反序列化
var josnObj = eval('(' + xhr.responseText + ')');
for (var i = 0; i < josnObj.length; i++) {
var opt = document.createElement('option');
opt.value = josnObj[i].AreaCode;
opt.innerHTML = josnObj[i].AreaName;
document.getElementById('ddlProv').appendChild(opt);
}//for
document.getElementById('ddlProv').onchange();//内部调用自己的onchange事件,加载下一个下拉
}//if
}
//3.初始化xhr,三个参数,,提交方式,url,是否异步
xhr.open('get', 'Select.ashx?id=0001', true);
//4.发送请求
xhr.send(null);
}
 function LoadCity() {
//确认事件--改变事件
document.getElementById('ddlProv').onchange = function () {
//获取被选省份的id
var id = this.value;
//根据被选择的id加载市区
var xhr = null;
//1.创建xhr对象
if (XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else if (ActiveXObject) {
xhr = new ActiveXObject("Microsoft.Http");
}
//2.设置回调函数
xhr.onreadystatechange = function () {
//反序列化
var josnObj = eval(xhr.responseText);
document.getElementById('ddlCity').innerHTML = '';
if (xhr.readyState = 4 && xhr.status == 200) {
for (var i = 0; i < josnObj.length; i++) {
var opt = document.createElement('option');
opt.value = josnObj[i].AreaCode;
opt.text = josnObj[i].AreaName;
document.getElementById('ddlCity').appendChild(opt);
}
}
document.getElementById('ddlCity').onchange();
}
//3.初始化
xhr.open('post', 'Select.ashx', true);
xhr.setRequestHeader('content-type', 'application/x-www-form-urlencoded');
//4.发送
xhr.send('id=' + id);
};//onchange
}
function LoadTown() {
//确认事件
document.getElementById('ddlCity').onchange = function () {
var id = this.value;
var xhr = null;
//1.创建对象
if (XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else if (ActiveXObject) {
xhr = new ActiveXObject("Microsoft.Http");
}
//2.设置回掉函数
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
//反序列化响应,转化为josn格式
document.getElementById('ddlTown').innerHTML = '';
var josnObj = eval(xhr.responseText);
for (var i = 0; i < josnObj.length; i++) {
var opt = document.createElement('option');
opt.value = josnObj[i].AreaCode;
opt.text = josnObj[i].AreaName;
document.getElementById('ddlTown').appendChild(opt);
}
}
}
//3.初始化
xhr.open('post', 'SelectByPost.ashx', true);
//post 必备
xhr.setRequestHeader('content-type', 'application/x-www-form-urlencoded');
//4.发送
xhr.send('id=' + id);
};//onchange
<body>
<form id="form1" runat="server">
省:<asp:DropDownList ID="ddlProv" runat="server"></asp:DropDownList>
市:<asp:DropDownList ID="ddlCity" runat="server"></asp:DropDownList>
区/县:<asp:DropDownList ID="ddlTown" runat="server"></asp:DropDownList>
</form>
</body>

JS实现Ajax,Josn数据的序列化和反序列化---例: 省市区联动(包含get,post)的更多相关文章

  1. 对 JSON 数据进行序列化和反序列化

    如何:对 JSON 数据进行序列化和反序列化 2017/03/30 作者 JSON(JavaScript 对象符号)是一种高效的数据编码格式,可用于在客户端浏览器和支持 AJAX 的 Web 服务之间 ...

  2. Json数据的序列化与反序列化的三种经常用法介绍

    下面内容是本作者从官网中看对应的教程后所做的demo.其体现了作者对相关知识点的个人理解..作者才疏学浅,难免会有理解不到位的地方.. 还请各位读者批判性对待... 本文主要介绍在Json数据的序列化 ...

  3. js实现对json数据的序列化(兼容ie6以上浏览器)

    /** * 增加对JSON数据的序列化方法, * 主要用于IE6.7不支持JSON对象的浏览器 */ var xue = xue || {};xue.json = xue.json || {}; xu ...

  4. Vue&period;js&mdash&semi;&mdash&semi;基于&dollar;&period;ajax实现数据的跨域增删查改

    概述 之前我们学习了Vue.js的一些基础知识,以及如何开发一个组件,然而那些示例的数据都是local的.在实际的应用中,几乎90%的数据是来源于服务端的,前端和服务端之间的数据交互一般是通过ajax ...

  5. Vue&period;js——基于&dollar;&period;ajax实现数据的跨域增删查改

    转自:https://www.cnblogs.com/keepfool/p/5648674.html 概述 之前我们学习了Vue.js的一些基础知识,以及如何开发一个组件,然而那些示例的数据都是loc ...

  6. 详解电子表格中的json数据:序列化与反序列化

    从XML到JSON 当下应用开发常见的B/S架构之下,我们会遇到很多需要进行前后端数据传输的场景.而在这个传输的过程中,数据通过何种格式传输.方式是否迅速便捷.书写方式是否简单易学,都成为了程序员在开 ...

  7. c&num;中对json数据的序列化和反序列化(笔记)

    今天遇到在后台中要获取json格式数据里的某些值,网上查了些资料: string jsonstr = _vCustomerService.LoadCustomerbyNumTotalData(quer ...

  8. Python 中数据的序列化和反序列化(json处理)

    概念: JSON(JavaScript Object Notation):是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Programming ...

  9. C&num; 编写通用的JSON数据进行序列化和反序列化

    注意事项:使用JSON系列化和反系列化,必须要添加引用System.Runtime.Serialization. 1.通用类代码如下: /// <summary>    /// JSON序 ...

随机推荐

  1. 在 PHP 中结合 Ajax 技术进行图片上传

    前面几则日志中讲述了在 PHP 中上传文件,相信大家对 PHP 中如何进行文件上传已经初步掌握.本文来继续探讨在 PHP 中上传文件的技术,不同的是,本次上传将仅限于图片文件的上传,并且将采用 Aja ...

  2. jQuery学习-事件之绑定事件(一)

    我们都知道jQuery的事件其思想来源于Dean Edwards的addEvent,通过源码我们知道jQuery在为元素绑定事件时,每种类型的事件(click,blur)时只绑定了一次对应类型的事件处 ...

  3. java定义和实现接口

    1.定义接口     使用interface来定义一个接口.接口定义同类的定义类似,也是分为接口的声明和接口体.当中接口体由常量定义和方法定义两部分组成.定义接口的基本格式例如以下: [修饰符] in ...

  4. json和java对象相互转换

    json和java对象相互转换 springboot中json转换默认使用的是jackson包,通过spring-boot-starter-web依赖的 1 在属性上添加注解@JsonFormat(p ...

  5. day 7-22 进程&comma;线程&comma;协程

    一.什么是进程 进程是一个具有独立功能的程序关于某个数据集合的一次运行活动.它可以申请和拥有系统资源,是一个动态的概念,是一个活动的实体.它不只是程序的代码,还包括当前的活动,通过程序计数器的值和处理 ...

  6. python 操作 saltstack Api&lpar;二&rpar; 示例

    获取token #!/usr/bin/env python #-*-coding:utf--*- import urllib import urllib.parse import urllib.req ...

  7. BZOJ2911 &colon; &lbrack;Poi1997&rsqb;The Number of Symmetrical Choices

    新建源汇S,T,根据题意可以建出一个DAG 设f[x][y]为从x走到y的回文路径的方案数,则 边界条件: f[x][x]=1 对于一条边x->y,若a[x]==a[y],则f[x][y]=1 ...

  8. python3处理json文件中含有中文dumps的应用

    python3的编码问题一直比较简单 内存中字符串采用unicode 存储到文件中采用utf-8 以下为str,byte互相转换的过程: str = "abc学习" str Out ...

  9. ztree获取选中节点时不能进入可视区域出现BUG如何解决

    zTree 是一个依靠 jQuery 实现的多功能 “树插件”.优异的性能.灵活的配置.多种功能的组合是 zTree 最大优点. zTree 的特点编辑 ● zTree v3.0 将核心代码按照功能进 ...

  10. C 标准库 - string&period;h之strstr使用

    strstr Returns a pointer to the first occurrence of str2 in str1, or a null pointer if str2 is not p ...