$.ajax()

 举例:

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.0/jquery.min.js"></script>
<script>
$(document).ready(function(){
    $("button").click(function(){
        $.ajax({url: "demo_test.txt", success: function(result){
            $("#div1").html(result);
        }});
    });
});
</script>
</head>
<body>

<div id="div1"><h2>Let jQuery AJAX Change This Text</h2></div>

<button>Get External Content</button>

</body>
</html>
View Code

举例和使用

ajax()方法展现一个AJAX(异步的HTTP)请求。


语法

$.ajax({name:value, name:value, ... })

参数是一个或者多个name/value键值对,用于ajax请求。

可能的键值对如下:

NameValue/Description
async

布尔值,是否异步亦或同步请求,默认异步true(异步)

如果需要同步,设置成fasle,但是注意会将浏览器锁住

注意跨域的JSONP请求不支持同步请求的选项

beforeSend(xhr) 在请求之前运行的函数
cache

布尔值,浏览器是否会缓存被请求的页面,默认true,对于script和jsonp类型会默认为fasle

如果设置成false,将会强迫被请求的页面不被浏览器缓存。注意:只有cache为fasle只会直接作用于HEAD和GET请求中。
它的工作原理是在GET请求参数后面添加"_={timestamp}"。
complete(xhr,status)

当请求完成之后执行的函数(在success和error函数之后)

contentType 当发送数据给服务器时候使用的内容类型。默认是: "application/x-www-form-urlencoded"
context 所有ajax相关的返回函数中的this所指定的内容。
data 将传递给服务器的数据内容
dataFilter(data,type)

处理XMLHttpRequest的原生返回内容的函数

dataType

希望服务器返回的数据类型

error(xhr,status,error)

当请求失败的时候运行的函数

global

布尔值,是否触发全局AJAX处理事件,默认是true

ifModified

布尔值,只有从上一次请求开始返回值改变才能视为请求成功

默认false

jsonp

在jsonp请求中重写回调函数的字符串

jsonpCallback

在jsonp请求中指定回调函数的函数名

password

在一个HTTP接入认证的请求中指定密码内容

processData

布尔值,是否发送的请求数据需要转换成一个查询字符串

默认是true

scriptCharset

指定请求的字符类型

success(result,status,xhr)

当请求成功是运行的函数

timeout

请求超时的时间(以毫秒为单位)

traditional 布尔值,使用传统的参数序列化方式?
type 请求的类型(GET还是POST)
url

发送请求的URL,默认是当前页面

username

在一个HTTP接入认证的请求中指定用户名

xhr

用于创建XMLHttpRequest对象的方法

accepts 

默认:由DataType决定

一个键对值,分别是一个已经给予的dataType和它的MIME类型,这将会在请求头部Accept字段显示。

这个头部信息高速服务器ajax将会接受什么类型的response。

converters

默认:{"* text": window.String, "text html": true, "text json": jQuery.parseJSON, "text xml": jQuery.parseXML}

在jQuery1.5之前是dataFilter 

$.ajax({
  accepts: {
  //和下面的dataType相互对应 mycustomtype:
'application/x-some-custom-type' }, // 介绍怎样解析序列化的`mycustomtype`类型数据 converters: { 'text mycustomtype': function(result) { // Do Stuff return newresult; } }, // 希望从服务器端得到`mycustomtype` dataType: 'mycustomtype' });

 

将返回的数值'[{"x:"1", "y":"2"}, {"x:"3", "y":"4"}]'中的x和y的值都转化成数字形式:

$.ajaxSetup({
    converters: {
        "json jsoncoords": function(data) { //返回的数据类型是json,并且和下面的dataType进行绑定
            if (valid(data)) {
                $.each(data, function(i,o){
                    if (o.x) {
                        data[i].x = parseFloat(o.x);
                    }
                    if (o.y) {
                        data[i].y = parseFloat(o.y);
                    }
                });
                return data;
            } else {
                throw exceptionObject;
            }
        }
    }
});

$.ajax({
    url: "/foo/",
    dataType: "jsoncoords" //和上面的converters中的json jsoncoords中的jsoncoords对应
}).success(function(data){
    // data should now have x and y as float numbers
});

 

.ajaxSetup() 设置了全局的ajax的默认选项

 

posted @ 2016-04-25 21:26  RachelChen  阅读(599)  评论(0编辑  收藏  举报