Headers
{{APIRef("Fetch API")}}
{{AvailableInWorkers}}
The Headers
interface of the Fetch API allows you to perform various actions on HTTP request and response headers. These actions include retrieving, setting, adding to, and removing headers from the list of the request’s headers.
You can retrieve a Headers
object via the {{domxref("Request.headers")}}
and {{domxref("Response.headers")}}
properties, and create a new Headers
object using the {{domxref("Headers.Headers", "Headers()")}}
constructor. Compared to using plain objects, using Headers
objects to send requests provides some additional input sanitization. For example, it normalizes header names to lowercase, strips leading and trailing whitespace from header values, and prevents certain headers from being set.
[!NOTE] You can find out more about the available headers by reading our HTTP headers reference.
Description
A Headers
object has an associated header list, which is initially empty and consists of zero or more name and value pairs. You can add to this using methods like {{domxref("Headers.append","append()")}}
(see Examples.) In all methods of this interface, header names are matched by case-insensitive byte sequence.
An object implementing Headers
can directly be used in a {{jsxref("Statements/for...of", "for...of")}}
structure, instead of {{domxref('Headers.entries()', 'entries()')}}
: for (const p of myHeaders)
is equivalent to for (const p of myHeaders.entries())
.
Modification restrictions
Some Headers
objects have restrictions on whether the {{domxref("Headers.set","set()")}}
, {{domxref("Headers.delete","delete()")}}
, and {{domxref("Headers.append","append()")}}
methods can mutate the header. The modification restrictions are set depending on how the Headers
object is created.
- For headers created with
{{domxref("Headers.Headers","Headers()")}}
constructor, there are no modification restrictions. - For headers of
{{domxref("Request")}}
objects:- If the request’s
{{domxref("Request.mode","mode")}}
isno-cors
, you can modify any{{Glossary("CORS-safelisted request header")}}
name/value. - Otherwise, you can modify any
{{Glossary("forbidden header name", "non-forbidden header")}}
name/value.
- If the request’s
- For headers of
{{domxref("Response")}}
objects:- If the response is created using
{{domxref("Response.error_static", "Response.error()")}}
or{{domxref("Response.redirect_static", "Response.redirect()")}}
, or received from a{{domxref("Window/fetch", "fetch()")}}
call, the headers are immutable and cannot be modified. - Otherwise, if the response is created using
{{domxref("Response.Response","Response()")}}
or{{domxref("Response.json_static","Response.json()")}}
, you can modify any{{Glossary("forbidden response header name", "non-forbidden response header")}}
name/value.
- If the response is created using
All of the Headers methods will throw a {{jsxref("TypeError")}}
if you try to pass in a reference to a name that isn’t a valid HTTP Header name. The mutation operations will throw a TypeError
if the header is immutable. In any other failure case they fail silently.
Constructor
{{domxref("Headers.Headers()", "Headers()")}}
- : Creates a new
Headers
object.
- : Creates a new
Instance methods
{{domxref("Headers.append()")}}
- : Appends a new value onto an existing header inside a
Headers
object, or adds the header if it does not already exist.
- : Appends a new value onto an existing header inside a
{{domxref("Headers.delete()")}}
- : Deletes a header from a
Headers
object.
- : Deletes a header from a
{{domxref("Headers.entries()")}}
- : Returns an
{{jsxref("Iteration_protocols","iterator")}}
allowing to go through all key/value pairs contained in this object.
- : Returns an
{{domxref("Headers.forEach()")}}
- : Executes a provided function once for each key/value pair in this
Headers
object.
- : Executes a provided function once for each key/value pair in this
{{domxref("Headers.get()")}}
- : Returns a
{{jsxref("String")}}
sequence of all the values of a header within aHeaders
object with a given name.
- : Returns a
{{domxref("Headers.getSetCookie()")}}
- : Returns an array containing the values of all
{{httpheader("Set-Cookie")}}
headers associated with a response.
- : Returns an array containing the values of all
{{domxref("Headers.has()")}}
- : Returns a boolean stating whether a
Headers
object contains a certain header.
- : Returns a boolean stating whether a
{{domxref("Headers.keys()")}}
- : Returns an
{{jsxref("Iteration_protocols", "iterator")}}
allowing you to go through all keys of the key/value pairs contained in this object.
- : Returns an
{{domxref("Headers.set()")}}
- : Sets a new value for an existing header inside a
Headers
object, or adds the header if it does not already exist.
- : Sets a new value for an existing header inside a
{{domxref("Headers.values()")}}
- : Returns an
{{jsxref("Iteration_protocols", "iterator")}}
allowing you to go through all values of the key/value pairs contained in this object.
- : Returns an
[!NOTE] To be clear, the difference between
{{domxref("Headers.set()")}}
and{{domxref("Headers.append()")}}
is that if the specified header does already exist and does accept multiple values,{{domxref("Headers.set()")}}
will overwrite the existing value with the new one, whereas{{domxref("Headers.append()")}}
will append the new value onto the end of the set of values. See their dedicated pages for example code.
[!NOTE] When Header values are iterated over, they are automatically sorted in lexicographical order, and values from duplicate header names are combined.
Examples
In the following snippet, we create a new header using the Headers()
constructor, add a new header to it using append()
, then return that header value using get()
:
const myHeaders = new Headers();
myHeaders.append("Content-Type", "text/xml");
myHeaders.get("Content-Type"); // should return 'text/xml'
The same can be achieved by passing an array of arrays or an object literal to the constructor:
let myHeaders = new Headers({
"Content-Type": "text/xml",
});
// or, using an array of arrays:
myHeaders = new Headers([["Content-Type", "text/xml"]]);
myHeaders.get("Content-Type"); // should return 'text/xml'
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}