jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解


Posted in Javascript onNovember 19, 2014

当我们用javascript写ajax程序写得很“开心”的时候,突然有人告诉你有一种东西叫jquery,它会告诉你不直接和HttpRequest是多么的快乐,同时你再也不需要再烦恼纠结的ajax乱码问题,更幸福的是你的js代码将大大地简化,看完本文,你会发现,ajax,简单的来讲就是一句话的事情。

1、$.get

$.get()方法使用GET方式来进行异步请求,它的语法结构为:

$.get( url [, data] [, callback] )

解释一下这个函数的各个参数:

url:string类型,ajax请求的地址。

data:可选参数,object类型,发送至服务器的key/value数据会作为QueryString附加到请求URL中。

callback:可选参数,function类型,当ajax返回成功时自动调用该函数。

最后写一个$.get()的实例供大家参考:

$.get(

    "submit.aspx",{

        id:     '123',

        name:   '青藤园',

    },function(data,state){

        //这里显示从服务器返回的数据

        alert(data);

        //这里显示返回的状态

        alert(state);

    }

)

2、$.post()

$.post()方法使用POST方式来进行异步请求,它的语法结构为:

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

这个方法和$.get()用法差不多,唯独多了一个type参数,那么这里就只介绍type参数吧,其他的参考上面$.get()的。

type:type为请求的数据类型,可以是html,xml,json等类型,如果我们设置这个参数为:json,那么返回的格式则是json格式的,如果没有设置,就和$.get()返回的格式一样,都是字符串的。

最后写一个$.post()的实例供大家参考:

$.post(

    "submit.aspx",{

        id:     '123',

        name:   '青藤园',

    },function(data,state){

        //这里显示从服务器返回的数据

        alert(data);

        //这里显示返回的状态

        alert(state);

    },

    "json"

)

3、$.getJSON()

$.getJSON()是专门为ajax获取json数据而设置的,并且支持跨域调用,其语法的格式为:

getJSON(url,[data],[callback])

url:string类型, 发送请求地址  data :可选参数, 待发送 Key/value 参数 ,同get,post类型的data callback :可选参数,载入成功时回调函数,同get,post类型的callback

JSON是一种理想的数据传输格式,它能够很好的融合与JavaScript或其他宿主语言,并且可以被JS直接使用。使用JSON相比传统的通过 GET、POST直接发送“裸体”数据,在结构上更为合理,也更为安全。至于jQuery的getJSON()函数,只是设置了JSON参数的 ajax()函数的一个简化版本。这个函数也是可以跨域使用的,相比get()、post()有一定优势。另外这个函数可以通过把请求url写 成"myurl?callback=X"这种格式,让程序执行回调函数X。

4、$.ajax()

$.ajax()是jquery中通用的一个ajax封装,其语法的格式为:

$.ajax(options)

其中options是一个object类型,它指明了本次ajax调用的具体参数,这里我把最常用的几个参数附上

$.ajax({

        url: 'submit.aspx',

        datatype: "json",

        type: 'post',

        success: function (e) {   //成功后回调

            alert(e); 

        },

        error: function(e){    //失败后回调

            alert(e);

        },

        beforeSend: function(){  /发送请求前调用,可以放一些"正在加载"之类额话

            alert("正在加载");

        }

})

以上就是jquery实现ajax调用的几种方法,ajax调用还是挺复杂的,希望本文能对大家有所帮助,如有什么疑问,也可以联系我,大家共同进步。

Javascript 相关文章推荐
[原创]用javascript实现检测指定目录是否存在的方法
Jan 12 Javascript
仅IE支持clearAttributes/mergeAttributes方法使用介绍
May 04 Javascript
浅谈JavaScript Math和Number对象
Jan 26 Javascript
CSS或者JS实现鼠标悬停显示另一元素
Jan 22 Javascript
Vue.js每天必学之过滤器与自定义过滤器
Sep 07 Javascript
vue.js表格组件开发的实例详解
Oct 12 Javascript
jquery日历插件e-calendar升级版
Nov 10 Javascript
Bootstrap CSS组件之按钮组(btn-group)
Dec 17 Javascript
canvas实现爱心和彩虹雨效果
Mar 09 Javascript
JS+CSS实现网页加载中的动画效果
Oct 27 Javascript
JS编写兼容IE6,7,8浏览器无缝自动轮播
Oct 12 Javascript
浅谈JS和jQuery的区别
Mar 27 jQuery
实现图片预加载的三大方法及优缺点分析
Nov 19 #Javascript
jQuery Ajax()方法使用指南
Nov 19 #Javascript
javascript匿名函数实例分析
Nov 18 #Javascript
Linux下使用jq友好的打印JSON技巧分享
Nov 18 #Javascript
删除Javascript Object中间的key
Nov 18 #Javascript
如何在MVC应用程序中使用Jquery
Nov 17 #Javascript
Jquery实现仿腾讯微博发表广播
Nov 17 #Javascript
You might like
复杂检索数据并分页显示的处理方法
2006/10/09 PHP
基于curl数据采集之正则处理函数get_matches的使用
2013/04/28 PHP
PHP把空格、换行符、中文逗号等替换成英文逗号的正则表达式
2014/05/04 PHP
浅谈php函数serialize()与unserialize()的使用方法
2014/08/19 PHP
Joomla框架实现字符串截取的方法示例
2017/07/18 PHP
PHP实现打包zip并下载功能
2018/06/12 PHP
phpinfo的知识点总结
2019/10/10 PHP
可输入的下拉框
2006/06/19 Javascript
写了一个layout,拖动条连贯,内容区可为iframe
2007/08/19 Javascript
JS支持带x身份证号码验证函数
2008/08/10 Javascript
javascript 限制输入和粘贴(IE,firefox测试通过)
2008/11/14 Javascript
jquery 操作DOM案例代码分享
2012/04/05 Javascript
js屏蔽鼠标键盘(右键/Ctrl+N/Shift+F10/F11/F5刷新/退格键)
2013/01/24 Javascript
根据表格中的某一列进行排序的javascript代码
2013/11/29 Javascript
一个仿糯米弹框效果demo
2014/07/22 Javascript
jquery实现二级导航下拉菜单效果
2015/12/18 Javascript
JS实现随机颜色的3种方法与颜色格式的转化
2017/01/05 Javascript
jQuery居中元素scrollleft计算方法示例
2017/01/16 Javascript
大白话讲解JavaScript的Promise
2017/04/06 Javascript
详解开源的JavaScript插件化框架MinimaJS
2017/10/26 Javascript
jQuery实现判断上传图片类型和大小的方法示例
2018/04/11 jQuery
VsCode与Node.js知识点详解
2019/09/05 Javascript
python实现迭代法求方程组的根过程解析
2019/11/25 Javascript
vue中监听路由参数的变化及方法
2019/12/06 Javascript
[56:42]完美世界DOTA2联赛循环赛 Matador vs Forest 第二场 11.06
2020/11/06 DOTA
利用打码兔和超人打码自封装的打码类分享
2014/03/16 Python
python模拟鼠标拖动操作的方法
2015/03/11 Python
Django中使用第三方登录的示例代码
2018/08/20 Python
opencv3/C++实现视频读取、视频写入
2019/12/11 Python
python爬虫开发之PyQuery模块详细使用方法与实例全解
2020/03/09 Python
Tensorflow卷积实现原理+手写python代码实现卷积教程
2020/05/22 Python
python如何调用字典的key
2020/05/25 Python
2016年班主任培训心得体会
2016/01/07 职场文书
推荐六本经典文学奖书籍:此生必读
2019/08/22 职场文书
python使用pymysql模块操作MySQL
2021/06/16 Python
详解apache编译安装httpd-2.4.54及三种风格的init程序特点和区别
2022/07/15 Servers