jQuery在header中设置请求信息的⽅法
jquery是js的类库,js本⾝不能操作header,因为js是在浏览器加载页⾯过程中才开始执⾏的header需要服务器端执⾏操作
如果是ajax,是可以设置header
$.ajax({
jquery框架定义url: "",
data: {},
type: "GET",
beforeSend: function(xhr){xhr.setRequestHeader('X-Test-Header', 'test-value');},//这⾥设置header
success: function() {}
});
也就是setRequestHeader函数
如何在ajax请求中设置特殊的RequestHeader
现在ajax应⽤已经相当⼴泛了,有很多不错的ajax框架可供使⽤。ajax是⼀个异步请求,也主要是⼀种客户端的脚本⾏为。那么,如何在请求之前为请求添加特殊的⼀些头部信息呢?
下⾯是⼀个简单的例⼦,我⽤jQuery编写,它的ajax函数中,有⼀个beforeSend⽅法,这个⽅法接受⼀个参数,就代表了发起异步请求的XMLHttpRequest对象,我们可以⽤该对象的setRequestHeader⽅法实现我们的⽬的
为什么要setRequestHeader?
⽐如,在及时通信系统中,每次获取消息或者发送消息,都需要去判断这个⽤户是否还在连线中,通过设置"accessToken",就可以实现正常通信;
beforeSend: function(request) {
request.setRequestHeader("accessToken", accessToken);
},
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="/1999/xhtml">
<head runat="server">
<title></title>
<script src="jquery-1.3.2-vsdoc.js" type="text/javascript"></script>
<script type="text/javascript" language="javascript">
$(function() {
$("#test").click(function() {
$.ajax({
type: "GET",
url: "default.aspx",
beforeSend: function(request) {
request.setRequestHeader("Test", "Chenxizhang");
},
success: function(result) {
alert(result);
}
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="v">
</div>
<input type="button" value="测试" id="test" />
</form>
</body>
</html>
jQuery.ajax() 如何设置 Headers 中的 Accept 内容
其实很简单,⾸先如果是常见类型,则请直接设置 dataType 属性
$.ajax({
dataType: "json",
type: "get",
success: function (data) {
}
});
设置 dataType 后,会去 accepts 属性(此属性会预置⼀些常⽤类型)中直接拿相应的类型添加到 Accept 中。
)%X02M](8[BKGW21{EY{0GD
如果想⾃⼰⾃定义 jQuery 中没有的 Accept 内容,可以⼿动设置 accepts 属性,使⽤键值对存储,然后再设置 dataType 属性为刚刚⾃定义的键。
$.ajax({
accepts: {
xxx: "application/xxx"
},
dataType: "xxx",
type: "get",
success: function (data) {
}
});
当然还可以直接设置 headers 属性,直接写 Accept 的内容是什么。
$.ajax({
headers: {
Accept: "application/json; charset=utf-8"
},
type: "get",
success: function (data) {
}
});
以上所述是⼩编给⼤家介绍的jQuery在header中设置请求信息的⽅法,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论