jQuery ajax - post() 方法
- 实例
- 请求 test.php 网页,忽略返回值:
- $.post("test.php");
- TIY 实例
- 通过 AJAX POST 请求改变 div 元素的文本:
- $("input").keyup(function(){
- txt=$("input").val();
- $.post("demo_ajax_gethint.asp",{suggest:txt},function(result){
- $("span").html(result);
- });
- });
- 亲自试一试
- 定义和用法
- post() 方法通过 HTTP POST 请求从服务器载入数据。
- 语法
- jQuery.post(url,data,success(data, textStatus, jqXHR),dataType)
- 参数 描述
- url 必需。规定把请求发送到哪个 URL。
- data 可选。映射或字符串值。规定连同请求发送到服务器的数据。
- success(data, textStatus, jqXHR) 可选。请求成功时执行的回调函数。
- dataType
- 可选。规定预期的服务器响应的数据类型。
- 默认执行智能判断(xml、json、script 或 html)。
- 详细说明
- 该函数是简写的 Ajax 函数,等价于:
- $.ajax({
- type: 'POST',
- url: url,
- data: data,
- success: success,
- dataType: dataType
- });
- 根据响应的不同的 MIME 类型,传递给 success 回调函数的返回数据也有所不同,这些数据可以是 XML 根元素、文本字符串、JavaScript 文件或者 JSON 对象。也可向 success 回调函数传递响应的文本状态。
- 对于 jQuery 1.5,也可以向 success 回调函数传递 jqXHR 对象(jQuery 1.4 中传递的是 XMLHttpRequest 对象)。
- 大部分实现会规定一个 success 函数:
- $.post("ajax/test.html", function(data) {
- $(".result").html(data);
- });
- 本例读取被请求的 HTML 片段,并插入页面中。
- 通过 POST 读取的页面不被缓存,因此 jQuery.ajaxSetup() 中的 cache 和 ifModified 选项不会影响这些请求。
- 注释:由于浏览器安全方面的限制,大多数 "Ajax" 请求遵守同源策略;请求无法从不同的域、子域或协议成功地取回数据。
- 注释:如果由 jQuery.post() 发起的请求返回错误代码,那么不会有任何提示,除非脚本已调用了全局的 .ajaxError() 方法。或者对于 jQuery 1.5,jQuery.post() 返回的 jqXHR 对象的 .error() 方法也可以用于错误处理。
- jqXHR 对象
- 对于 jQuery 1.5,所有 jQuery 的 AJAX 方法返回的是 XMLHTTPRequest 对象的超集。由 $.post() 返回的 jQuery XHR 对象或 "jqXHR,"实现了约定的接口,赋予其所有的属性、方法,以及约定的行为。出于对由 $.ajax() 使用的回调函数名称便利性和一致性的考虑,它提供了 .error(), .success() 以及 .complete() 方法。这些方法使用请求终止时调用的函数参数,该函数接受与对应命名的 $.ajax() 回调函数相同的参数。
- jQuery 1.5 中的约定接口同样允许 jQuery 的 Ajax 方法,包括 $.post(),来链接同一请求的多个 .success()、.complete() 以及 .error() 回调函数,甚至会在请求也许已经完成后分配这些回调函数。
- // 请求生成后立即分配处理程序,请记住该请求针对 jqxhr 对象
- var jqxhr = $.post("example.php", function() {
- alert("success");
- })
- .success(function() { alert("second success"); })
- .error(function() { alert("error"); })
- .complete(function() { alert("complete"); });
- // 在这里执行其他任务
- // 为上面的请求设置另一个完成函数
- jqxhr.complete(function(){ alert("second complete"); });
- 更多实例
- 例子 1
- 请求 test.php 页面,并一起发送一些额外的数据(同时仍然忽略返回值):
- $.post("test.php", { name: "John", time: "2pm" } );
- 例子 2
- 向服务器传递数据数组(同时仍然忽略返回值):
- $.post("test.php", { 'choices[]': ["Jon", "Susan"] });
- 例子 3
- 使用 ajax 请求发送表单数据:
- $.post("test.php", $("#testform").serialize());
- 例子 4
- 输出来自请求页面 test.php 的结果(HTML 或 XML,取决于所返回的内容):
- $.post("test.php", function(data){
- alert("Data Loaded: " + data);
- });
- 例子 5
- 向页面 test.php 发送数据,并输出结果(HTML 或 XML,取决于所返回的内容):
- $.post("test.php", { name: "John", time: "2pm" },
- function(data){
- alert("Data Loaded: " + data);
- });
- 例子 6
- 获得 test.php 页面的内容,并存储为 XMLHttpResponse 对象,并通过 process() 这个 JavaScript 函数进行处理:
- $.post("test.php", { name: "John", time: "2pm" },
- function(data){
- process(data);
- }, "xml");
- 例子 7
- 获得 test.php 页面返回的 json 格式的内容:
- $.post("test.php", { "func": "getNameAndTime" },
- function(data){
- alert(data.name); // John
- console.log(data.time); // 2pm
- }, "json");
jQuery ajax - post() 方法的更多相关文章
- 2016 系统设计第一期 (档案一)jQuery ajax serialize()方法form提交数据
jQuery ajax serialize()方法form提交数据,有个很奇怪的问题,好像不能取到隐藏控件的值. //点击提交按钮保存数据 $('#btn_submitUser').click(fun ...
- jQuery – AJAX load() 方法
jQuery load() 方法 jQuery load() 方法是简单但强大的 AJAX 方法. load() 方法从服务器加载数据,并把返回的数据放入被选元素中. 语法: $(selector). ...
- jquery ajax abort()方法
如果用户频繁点击ajax请求,除最后一个外都是无效的,趁早结束节省资源.也可能出现更严重的问题,最后一个发送的请求,响应未必是最后一个,有可能造成混乱.用jquery的abort方法,可以中途中止aj ...
- jQuery ajax - ajaxSetup() 方法
实例 为所有 AJAX 请求设置默认 URL 和 success 函数: $("button").click(function(){ $.ajaxSetup({url:" ...
- jquery ajax complete 方法
jquery ajax var ajaxTimeoutTest = $.ajax({ url:'', //请求的URL timeout : 1000, //超时时间设置,单位毫秒 type : 'g ...
- jQuery ajax - serialize() 方法-输出序列化表单值
定义和用法 serialize() 方法通过序列化表单值,创建 URL 编码文本字符串. 您可以选择一个或多个表单元素(比如 input 及/或 文本框),或者 form 元素本身. 序列化的值可在生 ...
- jQuery AJAX load() 方法
jQuery load() 方法 jQuery load() 方法是简单但强大的 AJAX 方法. load() 方法从服务器加载数据,并把返回的数据放入被选元素中. 语法: $(selector). ...
- jQuery ajax - get() 方法
AJAX = Asynchronous javaScript and XML. AJAX 是一种创建快速动态网页的技术. AJAX 通过在后台与服务器交换少量数据的方式,允许网页进行异步更新.这意味 ...
- jQuery ajax - getScript() 方法
通过 AJAX 请求来获得并运行一个 JavaScript 文件: HTML 代码: <button id="go">Run</button> <di ...
随机推荐
- java堆转储与内存分析
jmap -dump:format=b,file=dumpfile.hprof pid 将进程的堆转储到dumpfile.hprof文件里 jmap -heap pid 查看堆内存占用情 ...
- 类 __init__的注意事项
class Dog(): class类 后面的ClassName类名第一个字母一定要大写. def __init__(self,name,age): 注意init前后是英文格式下,前后都是两道 ...
- __stdcall,__cdecl,__fastcall,_stdcall,_cdecl,_fastcall 区别简介[转]
今天写线程函数时,发现msdn中对ThreadProc的定义有要求: DWORD WINAPI ThreadProc(LPVOID lpParameter); 不解为什么要用WINAPI宏定义,查 ...
- vue实现curd功能
一.实现效果 二.实现 (一)实现增加用户功能 Vuserlist组件中 <template> <div class="panel panel-default"& ...
- 通过js渲染高层级DOM实现网页加水印
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 清除浏览器默认样式——css reset & normalize.css
css reset 自己挨个清除很麻烦 可以使用网上一些css库——css reset 把模板复制到css文件最上方,其他的样式我们自己编写来覆盖它们 但是这个也有一些弊端,会把一些本来需要的样式给清 ...
- Python 让输入的密码不在屏幕上显示
使用getpass模块 #!/usr/bin/env python import getpass username = raw_input("username:") passwor ...
- 48 git使用
0 引言 git/github是当前最好的代码版本管理和协同工作工具.最近我终于用上了这一先进工具,撒花撒花! # 先把大神廖雪峰的链接献上https://www.liaoxuefeng.com/wi ...
- GDI+在Delphi程序的应用 Photoshop色相饱和度明度功能
本文用GDI+实现Photoshop色相/饱和度/明度功能,参照我的其它有关GDI+在 Delphi程序的应用的文章,代码也可供TBitmap使用. 有些人不喜欢,或者不太懂Delphi的BASM代码 ...
- NX二次开发-UFUN重命名图纸页UF_DRAW_rename_drawing
#include <uf.h> #include <uf_draw.h> #include <uf_drf.h> #include <uf_obj.h> ...