1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
---
title: Headers.append()
slug: Web/API/Headers/append
tags:
- Append
- Headers.append()
translation_of: Web/API/Headers/append
---
<p>{{APIRef("Fetch")}}</p>
<p>在一个<code>Headers</code>对象内部,{{domxref("Headers")}}接口的<strong><code>append()</code></strong>方法可以追加一个新值到已存在的headers上,或者新增一个原本不存在的header。</p>
<p>{{domxref("Headers.set")}} 和 <code>append()</code> 两者之间的不同之处在于当指定header是已经存在的并且允许接收多个值时,{{domxref("Headers.set")}}会重写此值为新值,而<code>append()</code>会追加到值序列的尾部。</p>
<p>因为安全性原因,一些headers仅受用户代理控制。包括{{Glossary("Forbidden_header_name", "forbidden header names", 1)}}和{{Glossary("Forbidden_response_header_name", "forbidden response header names", 1)}}。</p>
<h2 id="语法">语法</h2>
<pre class="brush: js">myHeaders.append(name,value);</pre>
<h3 id="参数">参数</h3>
<dl>
<dt><em>name</em></dt>
<dd>要追加给Headers对象的HTTP header名称.</dd>
<dt><em>value</em></dt>
<dd>要追加给Headers对象的HTTP header值.</dd>
</dl>
<h3 id="返回">返回</h3>
<p>Void.</p>
<h2 id="例程">例程</h2>
<p>创建一个空的Headers对象:</p>
<pre class="brush: js">var myHeaders = new Headers(); // Currently empty</pre>
<p>可以通过append()方法添加header:</p>
<pre class="brush: js">myHeaders.append('Content-Type', 'image/jpeg');
myHeaders.get('Content-Type'); // Returns 'image/jpeg'
</pre>
<p>如果指定header不存在, <code>append()</code>将会添加这个header并赋值 . 如果指定header已存在并允许有多个值, <code>append()</code>将会把指定值添加到值队列的末尾。</p>
<pre class="brush: js">myHeaders.append('Accept-Encoding', 'deflate');
myHeaders.append('Accept-Encoding', 'gzip');
myHeaders.getAll('Accept-Encoding'); // Returns [ "deflate", "gzip" ]
</pre>
<p>要使用新值覆盖旧值,请使用{{domxref("Headers.set")}}。</p>
<h2 id="规范">规范</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
<tr>
<td>{{SpecName('Fetch','#dom-headers-append','append()')}}</td>
<td>{{Spec2('Fetch')}}</td>
<td> </td>
</tr>
</tbody>
</table>
<h2 id="浏览器兼容性">浏览器兼容性</h2>
<p>{{Compat("api.Headers.append")}}</p>
<div id="compat-mobile"> </div>
<h2 id="参见">参见</h2>
<ul>
<li><a href="/en-US/docs/Web/API/ServiceWorker_API">ServiceWorker API</a></li>
<li><a href="/en-US/docs/Web/HTTP/Access_control_CORS">HTTP access control (CORS)</a></li>
<li><a href="/en-US/docs/Web/HTTP">HTTP</a></li>
</ul>
|