schangxiang@126.com
2025-09-19 0821aa23eabe557c0d9ef5dbe6989c68be35d1fe
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
## Caseless -- wrap an object to set and get property with caseless semantics but also preserve caseing.
 
This library is incredibly useful when working with HTTP headers. It allows you to get/set/check for headers in a caseless manner while also preserving the caseing of headers the first time they are set.
 
## Usage
 
```javascript
var headers = {}
  , c = caseless(headers)
  ;
c.set('a-Header', 'asdf')
c.get('a-header') === 'asdf'
```
 
## has(key)
 
Has takes a name and if it finds a matching header will return that header name with the preserved caseing it was set with.
 
```javascript
c.has('a-header') === 'a-Header'
```
 
## set(key, value[, clobber=true])
 
Set is fairly straight forward except that if the header exists and clobber is disabled it will add `','+value` to the existing header.
 
```javascript
c.set('a-Header', 'fdas')
c.set('a-HEADER', 'more', false)
c.get('a-header') === 'fdsa,more'
```
 
## swap(key)
 
Swaps the casing of a header with the new one that is passed in.
 
```javascript
var headers = {}
  , c = caseless(headers)
  ;
c.set('a-Header', 'fdas')
c.swap('a-HEADER')
c.has('a-header') === 'a-HEADER'
headers === {'a-HEADER': 'fdas'}
```