Jquery的.post说解(一)

准备工作

·Customer类

 
public class Customer
{
    public int Unid { get; set; }
    public string CustomerName { get; set; }
    public string Memo { get; set; }
    public string Other { get; set; }
}  

jQuery.post( url, [data], [callback], [type] )

·url:加载页的地址

·data(optional):k/v对或序列化的字符串(.serialize()),参数

·callbakc(optional):数据成功加载后的执行函数

·type(optional):请求返回的数据格式,串型

(一)ashx文件

(1)请求单实体数据

·Ashx文件,这里不对返回的数据做显式的序列化。

Customer customer = new Customer 
  { Unid = 1, CustomerName = "宋江", Memo = "天魁星", Other = "黑三郎" }; context.Response.Write(customer);

·ajax post

 
function GetCustomer_Ashx() {
    $.post(
    "webdata/post_1.ashx",
    function(data) {
        var sx = $.JsonToObject(data);
        var tt = "";
        $.each(sx, function(k, v) {
            tt += k + ":" + v + "<br/>";
        })
        $("#divmessage").html(tt);
    },
    "json"
);}  

(2)请求实体集合

·ashx文件

 
Customer customer = new Customer 
    { Unid = 1, CustomerName = "宋江", Memo = "天魁星", Other = "黑三郎" }; Customer customer2 = new Customer 
    { Unid = 2, CustomerName = "吴用", Memo = "天机星", Other = "智多星" };
      List<Customer> _list = new List<Customer>();
    _list.Add(customer);
    _list.Add(customer2);
    string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(_list);     context.Response.Write(strJson);
 

·ajax post

 
function GetCustomer_AshxList() {
    $.post(
    "webdata/post_1.ashx",
    function(data) {
        var jsonObjects = $.jsonToObject(data);
        var tt = "";
        $.each(jsonObjects, function(k, v) {
            $.each(v, function(kk, vv) {
                tt += kk + ":" + vv + "<br/>";
            });
        });         $("#divmessage").html(tt);
    },
    "json"
    );
}
 

(3)带参数的请求

·ashx文件

在前者基础上添加了对请求参数的获取语句,并添加了linq查询

int iCustomerId = Convert.ToInt32(context.Request["iUnid"]);
        var cus = from q in _list
                  where q.Unid == iCustomerId
                  select q; string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(cus);

·ajax post

 
function GetCustomer_AshxWithPara() {
    $.post(
    "webdata/post_1.ashx",
    { iUnid: 1 },
    function(data) {
        var tt = "";
        $.each(data, function(k, v) {
            $.each(v, function(kk, vv) {
                tt += kk + ":" + vv + "<br/>";
            });
        });
        $("#divmessage").html(tt);
    },
    "json"
);}
 

注意,这里返回的直接是json对象[object,object],可以直接解析。

这种参数传递的方法是以k/v对格式传递,post还有一种方式,那就是.serialize()之后的字串。

(二)Web Service

(1)Hello

·ws

[WebMethod]
public string HelloWorld()
{
    return "Hello World";
}

·ajax post

 
function WebService_Hello() {
    $.post(
    "post_1.asmx/HelloWorld",
    function(data) {
        alert(data.text);
        $("#divmessage").html(data);
    },
    "json"
);}
 

这个web方法返回一个单独的字串。这是一个纯正的字串,对于客户端来说,这是一个object对象,但也可以理解为一个[object,object]对象,而它完整的数据格式可以理解为:{text: "Hello World"}

所以这里对它进行访问,可以如下:

·data.text 这种方式对应于Object.Property

·data["text"] 这种方式对应于Object["key"]

(2)json串

·ws

 
[WebMethod]
public string HelloWorld_Json()
{
    string strJson=
      @"{Unid:1,CustomerName:""宋江"",Memo:""天魁星"",Other:""黑三郎""}";
    return strJson;
}
 

·ajax post

 
function WebService_HelloJsonString() {
    $.post(
    "post_1.asmx/HelloWorld_Json",
    function(data) {
        var jsonString = data.text;
        var jsonObject = $.jsonToObject(jsonString);
        var tt = "";
        $.each(jsonObject, function(k, v) {
            tt += k + ":" + v + "<br/>";
        })         $("#divmessage").html(tt);
    },
    "json"
);}
 

虽然服务方法返回的是string类型的数据:

{Unid:1,CustomerName:"宋江",Memo:"天魁星",Other:"黑三郎"}

但客户端得到的数据却是object类型,可以理解为[object,object],也就是

{text:’{Unid:1,CustomerName:"宋江",Memo:"天魁星",Other:"黑三郎"}’}

客户端请求到的数据取到json字串,然后转换为json对象,后进行解析。

所以,在请求web服务方法时,如果方法返回字串类型,先要通过data.text得到做为唯一k/v对的v值,也就是json字串,然后再进行下一步操作。

(3)通过串行化返回json字串的web方法

·ws

 
[WebMethod]
public string GetCustomer_Json()
{
    Customer customer = new Customer
      { Unid = 1, CustomerName = "宋江", Memo = "天魁星", Other = "黑三郎" };     string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(customer);
    return strJson;
}
 

·ajax post

 
function WebService_CustomerJsonString() {
    $.post(
    "post_1.asmx/GetCustomer_Json",
    function(data) {
        var jsonString = data.text;
        var jsonObject = $.jsonToObject(jsonString);
        var tt = "";
        $.each(jsonObject, function(k, v) {
            tt += k + ":" + v + "<br/>";
        })
        $("#divmessage").html(tt);
    },
    "json"
);}
 

这个方法与(2)相同道理。

(4)客户集

·ws

 
[WebMethod]
public string GetCustomerList_Json()
{
    Customer customer = new Customer 
       { Unid = 1, CustomerName = "宋江", Memo = "天魁星", Other = "黑三郎" };     Customer customer2 = new Customer 
       { Unid = 2, CustomerName = "吴用", Memo = "天机星", Other = "智多星" };          List<Customer> _list = new List<Customer>();
        _list.Add(customer);
        _list.Add(customer2);          string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(_list);
        return strJson;
}
 

·ajax post

 
function WebService_CustomerListJsonString() {
    $.post(
    "post_1.asmx/GetCustomerList_Json",
    function(data) {
        var jsonString = data.text;
        var jsonObject = $.jsonToObject(jsonString);
        var tt = "";
        $.each(jsonObject, function(k, v) {
            $.each(v, function(kk, vv) {
                tt += kk + ":" + vv + "<br/>";
            });
        });
        $("#divmessage").html(tt);
    },
    "json"
);}
 

其实得到了json字串,也就能正常解析出来。主要是理解返回的数据对象的格式。

(5)带参数的ws

·ws

 
[WebMethod]
public string GetCustomerList_JsonPara(int iUnid)
{
    Customer customer = new Customer 
       { Unid = 1, CustomerName = "宋江", Memo = "天魁星", Other = "黑三郎" };     Customer customer2 = new Customer 
       { Unid = 2, CustomerName = "吴用", Memo = "天机星", Other = "智多星" };          List<Customer> _list = new List<Customer>();
        _list.Add(customer);
        _list.Add(customer2);          var cus = from q in _list
                  where q.Unid == iUnid
                  select q;          string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(cus);
        return strJson;
}
 

·ajax post

 
function WebService_CustomerListJsonStringWithPara() {
    $.post("post_1.asmx/GetCustomerList_JsonPara",
    {iUnid:2},
    function(data) {
        var jsonString = data.text;
        var jsonObject = $.jsonToObject(jsonString);
        var tt = "";
        $.each(jsonObject, function(k, v) {
        $.each(v, function(kk, vv) {
        tt += kk + ":" + vv + "<br/>";
        });
        });
        $("#divmessage").html(tt);        
    }
 );}
 

带参数的post时,post函数的type部分不能以json格式请求返回。可以省略。

Jquery的.post说解的更多相关文章

  1. jquery的css详解(二)

    jq的工具方法style用于设置样式,jq的实例方法css在设置样式时就是调用的它,接下来分析一下源码. jQuery.extend({ ............................ st ...

  2. jQuery.attr() 函数详解

    一,jQuery.attr()  函数详解: http://www.365mini.com/page/jquery-attr.htm 二,jQuery函数attr()和prop()的区别: http: ...

  3. jQuery 事件用法详解

    jQuery 事件用法详解 目录 简介 实现原理 事件操作 绑定事件 解除事件 触发事件 事件委托 事件操作进阶 阻止默认事件 阻止事件传播 阻止事件向后执行 命名空间 自定义事件 事件队列 jque ...

  4. jQuery事件绑定、解绑、命名空间

    jQuery事件绑定.解绑.命名空间 <%@ page language="java" import="java.util.*" pageEncoding ...

  5. jQuery.ready() 函数详解

    jQuery.ready() 函数详解 ready()函数用于在当前文档结构载入完毕后立即执行指定的函数. 该函数的作用相当于window.onload事件. 你可以多次调用该函数,从而绑定多个函数, ...

  6. jquery inArray()函数详解

    jquery inarray()函数详解 jquery.inarray(value,array)确定第一个参数在数组中的位置(如果没有找到则返回 -1 ). determine the index o ...

  7. jQuery extend方法详解

    先说个概念的东西: jQuery为开发插件提拱了两个方法,分别是: $.fn.extend(item):为每一个实例添加一个实例方法item.($("#btn1") 会生成一个 j ...

  8. jQuery的观察者模式详解 转载

    jQuery的观察者模式详解 投稿:hebedich 本文主要是介绍了jQuery中on方法及trigger方法,以及围绕这个方法来体验的观察者模式,是篇非常不错的文章,对我们理解观察者模式很有帮助. ...

  9. 【转载】jQuery.extend 函数详解

    转载自:http://www.cnblogs.com/RascallySnake/archive/2010/05/07/1729563.html jQuery.extend 函数详解 JQuery的e ...

随机推荐

  1. 从零开始学ios开发(五):IOS控件(2),Slider

    下面继续学习ios的其他控件,这次会使用到的控件有Slider,当然还有一些之前已经使用过的控件Label. 这次我们不新建一个project了,当然如果你愿意重新创建一个新的项目也完全可以,我们还是 ...

  2. 关于IOS中的delegate必须知道的事情

    当你开始写iOS程式不久,应该开始面对到很多的delegate, 不管是用别人的library或是自己写library,可能都逃不了delegate. 为了怕有些人不知道什么是delegate,在这边 ...

  3. Careercup - Facebook面试题 - 6299074475065344

    2014-05-01 01:00 题目链接 原题: Given a matrix with 's. What is the maximum area of the rectangle. In . Ho ...

  4. Django 学习笔记之七 实现分页

    接着上篇,在上篇的基础上实现网页数据分页显示 1.打开views.py,编辑如下 #coding:utf-8from django.shortcuts import render,get_object ...

  5. 常用的Eclilpse插件列表以及安装方式总结

    Eclipse常用插件的安装方式总结: 1.Maven Integration for Eclipse WTP     作用:用来方便开发和使用maven项目.     安装方式:Eclipse Ma ...

  6. 阿里云CentOS6.3 安装MongoDB教程

    安装说明 系统环境:Centos-6.3安装软件:mongodb-linux-x86_64-2.2.2.tgz下载地址:http://www.mongodb.org/downloads安装机器:192 ...

  7. specular map normal map gloss map

    http://www.marmoset.co/toolbag/learn/materials http://digitalerr0r.wordpress.com/2009/03/26/xna-shad ...

  8. 为什么乱码:<meta http-equiv="content-type">前的非ANSI字符

    为什么乱码:<meta http-equiv="content-type">前的非ANSI字符 浏览器检测网页字符集的默认顺序 浏览器的网页字符集检测顺序通常是: ch ...

  9. ssh 内在溢出

    相信有一定java开发经验的人或多或少都会遇到OutOfMemoryError的问题,这个问题曾困扰了我很长时间,随着解决各类问题经验的积累以及对问题根源的探索,终于有了一个比较深入的认识. 在解决j ...

  10. Asp.net MVC 自定义路由在IIS7以上,提示Page Not Found 解决方法

    受限确保自定义路由在开发服务器上Ok! 然后在web.config的<webserver>节点下增加如下配置就好了.   1: <system.webServer> 2: &l ...