mirror of
https://github.com/nodejs/node.git
synced 2025-05-05 07:27:49 +00:00

- Make URLSearchParams constructor spec-compliant - Strip leading `?` in URL#search's setter - Spec-compliant iterable interface - More precise handling of update steps as mandated by the spec - Add class strings to URLSearchParams objects and their prototype - Make sure `this instanceof URLSearchParams` in methods Also included are relevant tests from W3C's Web Platform Tests (https://github.com/w3c/web-platform-tests/tree/master/url). Fixes: https://github.com/nodejs/node/issues/9302 PR-URL: https://github.com/nodejs/node/pull/9484 Reviewed-By: James M Snell <jasnell@gmail.com>
39 lines
1.3 KiB
JavaScript
39 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
require('../common');
|
|
const assert = require('assert');
|
|
const URL = require('url').URL;
|
|
|
|
const m = new URL('http://example.org');
|
|
let params = m.searchParams;
|
|
|
|
// Until we export URLSearchParams
|
|
const URLSearchParams = params.constructor;
|
|
|
|
// Set basics
|
|
params = new URLSearchParams('a=b&c=d');
|
|
params.set('a', 'B');
|
|
assert.strictEqual(params + '', 'a=B&c=d');
|
|
params = new URLSearchParams('a=b&c=d&a=e');
|
|
params.set('a', 'B');
|
|
assert.strictEqual(params + '', 'a=B&c=d');
|
|
params.set('e', 'f');
|
|
assert.strictEqual(params + '', 'a=B&c=d&e=f');
|
|
|
|
// URLSearchParams.set
|
|
params = new URLSearchParams('a=1&a=2&a=3');
|
|
assert.strictEqual(true, params.has('a'),
|
|
'Search params object has name "a"');
|
|
assert.strictEqual(params.get('a'), '1',
|
|
'Search params object has name "a" with value "1"');
|
|
params.set('first', 4);
|
|
assert.strictEqual(true, params.has('a'),
|
|
'Search params object has name "a"');
|
|
assert.strictEqual(params.get('a'), '1',
|
|
'Search params object has name "a" with value "1"');
|
|
params.set('a', 4);
|
|
assert.strictEqual(true, params.has('a'),
|
|
'Search params object has name "a"');
|
|
assert.strictEqual(params.get('a'), '4',
|
|
'Search params object has name "a" with value "4"');
|