js-apis-url.md 11.8 KB
Newer Older
Z
zengyawen 已提交
1
# URL字符串解析
Z
zengyawen 已提交
2

Z
zengyawen 已提交
3 4
> ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:**
> 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
Z
zengyawen 已提交
5

Z
zengyawen 已提交
6 7

## 导入模块
Z
zengyawen 已提交
8 9 10 11 12

```
import Url from '@ohos.url' 
```

Z
zengyawen 已提交
13 14 15
## 系统能力

SystemCapability.Utils.Lang
Z
zengyawen 已提交
16 17 18 19 20

## URLSearchParams


### constructor
Z
zengyawen 已提交
21

Z
zengyawen 已提交
22
constructor(init?: string[][] | Record<string, string> | string | URLSearchParams)
Z
zengyawen 已提交
23 24 25

URLSearchParams的构造函数。

Z
zengyawen 已提交
26 27 28 29 30
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| init | string[][]&nbsp;\|&nbsp;Record&lt;string,&nbsp;string&gt;&nbsp;\|&nbsp;string&nbsp;\|&nbsp;URLSearchParams | 否 | 入参对象。<br/>-&nbsp;string[][]:字符串二维数组<br/>-&nbsp;Record&lt;string,&nbsp;string&gt;:对象列表<br/>-&nbsp;string:字符串<br/>-&nbsp;URLSearchParams:对象 |
Z
zengyawen 已提交
31

Z
zengyawen 已提交
32 33
**示例:**

34
```js
Z
zengyawen 已提交
35 36 37 38
var objectParams = new URLSearchParams([ ['user1', 'abc1'], ['query2', 'first2'], ['query3', 'second3'] ]);
var objectParams1 = new URLSearchParams({"fod" : 1 , "bard" : 2});
var objectParams2 = new URLSearchParams('?fod=1&bard=2');
var urlObject = new URL('https://developer.mozilla.org/?fod=1&bard=2');
39
var params = new URLSearchParams(urlObject.search);
Z
zengyawen 已提交
40
```
Z
zengyawen 已提交
41 42 43 44 45


### append

append(name: string, value: string): void
Z
zengyawen 已提交
46 47 48

将新的键值对插入到查询字符串。

Z
zengyawen 已提交
49 50 51 52 53 54
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 需要插入搜索参数的键名。 |
| value | string | 是 | 需要插入搜索参数的值。 |
Z
zengyawen 已提交
55

Z
zengyawen 已提交
56 57
**示例:**

58
```js
Z
zengyawen 已提交
59 60 61 62
let urlObject = new URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new URLSearchParams(urlObject.search.slice(1));
paramsObject.append('fod', 3);
```
Z
zengyawen 已提交
63 64 65 66 67


### delete

delete(name: string): void
Z
zengyawen 已提交
68 69 70

删除指定名称的键值对。

Z
zengyawen 已提交
71 72 73 74 75
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 需要删除的键值名称。 |
Z
zengyawen 已提交
76

Z
zengyawen 已提交
77 78
**示例:**

79
```js
Z
zengyawen 已提交
80 81
let urlObject = new URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsobject = new URLSearchParams(urlObject.search.slice(1));
82
paramsobject.delete('fod');
Z
zengyawen 已提交
83
```
Z
zengyawen 已提交
84 85 86 87 88


### getAll

getAll(name: string): string[]
Z
zengyawen 已提交
89 90 91

获取指定名称的所有键值对。

Z
zengyawen 已提交
92 93 94 95 96 97 98 99 100 101 102
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 指定的键值名称。 |

**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| string[] | 返回指定名称的所有键值对。 |
Z
zengyawen 已提交
103

Z
zengyawen 已提交
104
**示例:**
Z
zengyawen 已提交
105

106
```js
Z
zengyawen 已提交
107 108
let urlObject = new URL('https://developer.exampleUrl/?fod=1&bard=2'); 
let paramsObject = new URLSearchParams(urlObject.search.slice(1)); 
109
paramsObject.append('fod', 3); // Add a second value for the fod parameter.
Z
zengyawen 已提交
110 111
console.log(params.getAll('fod')) // Output ["1","3"].
```
Z
zengyawen 已提交
112 113


Z
zengyawen 已提交
114
### entries
Z
zengyawen 已提交
115

X
xdmal 已提交
116
entries(): IterableIterator<[string, string]>
Z
zengyawen 已提交
117 118

返回一个ES6的迭代器,迭代器的每一项都是一个 JavaScript Array。Array的第一项是name,Array的第二项是value。
Z
zengyawen 已提交
119

Z
zengyawen 已提交
120 121 122 123 124 125 126
**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| IterableIterator&lt;[string,&nbsp;string]&gt; | 返回一个ES6的迭代器。 |

**示例:**
Z
zengyawen 已提交
127

128
```js
Z
zengyawen 已提交
129 130 131 132 133
var searchParamsObject = new URLSearchParams("keyName1=valueName1&keyName2=valueName2"); 
for (var pair of searchParamsObject .entries()) { // Show keyName/valueName pairs
    console.log(pair[0]+ ', '+ pair[1]);
}
```
Z
zengyawen 已提交
134 135


Z
zengyawen 已提交
136
### forEach
Z
zengyawen 已提交
137

X
xdmal 已提交
138
forEach(callbackfn: (value: string, key: string, searchParams: this) => void, thisArg?: Object): void
Z
zengyawen 已提交
139 140 141

通过回调函数来遍历URLSearchParams实例对象上的键值对。

Z
zengyawen 已提交
142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| callbackfn | function | 是 | 回调函数。 |
| thisArg | Object | 否 | callbackfn被调用时用作this值 |

**表1** callbackfn的参数说明

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| value | string | 是 | 当前遍历到的键值。 |
| key | string | 是 | 当前遍历到的键名。 |
| searchParams | Object | 是 | 当前调用forEach方法的实例对象。 |

**示例:**

159
```js
Z
zengyawen 已提交
160 161 162 163 164
const myURLObject = new URL('https://developer.exampleUrl/?fod=1&bard=2'); 
myURLObject.searchParams.forEach((value, name, searchParams) => {  
    console.log(name, value, myURLObject.searchParams === searchParams);
});
```
Z
zengyawen 已提交
165 166 167 168 169


### get

get(name: string): string | null
Z
zengyawen 已提交
170 171 172

获取指定名称对应的第一个值。

Z
zengyawen 已提交
173 174 175 176 177
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 指定键值对的名称。 |
Z
zengyawen 已提交
178

Z
zengyawen 已提交
179
**返回值:**
Z
zengyawen 已提交
180

Z
zengyawen 已提交
181 182 183 184 185 186 187
| 类型 | 说明 |
| -------- | -------- |
| string | 返回第一个值。 |
| null | 如果没找到,返回&nbsp;null。 |

**示例:**

188
```js
Z
zengyawen 已提交
189 190 191 192 193
var paramsOject = new URLSearchParams(document.location.search.substring(1)); 
var name = paramsOject.get("name"); // is the string "Jonathan" 
var age = parseInt(paramsOject.get("age"), 10); // is the number 18
var address = paramsOject.get("address"); // null
```
Z
zengyawen 已提交
194 195 196 197 198


### has

has(name: string): boolean
Z
zengyawen 已提交
199 200

判断一个指定的键名对应的值是否存在。
Z
zengyawen 已提交
201

Z
zengyawen 已提交
202 203 204 205 206 207 208
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 要查找的参数的键名。 |

**返回值:**
Z
zengyawen 已提交
209

Z
zengyawen 已提交
210 211 212 213 214 215
| 类型 | 说明 |
| -------- | -------- |
| boolean | 是否存在相对应的key值,存在返回true,否则返回false。 |

**示例:**

216
```js
Z
zengyawen 已提交
217 218 219 220
let urlObject = new URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new URLSearchParams(urlObject.search.slice(1)); 
paramsObject.has('bard') === true;
```
Z
zengyawen 已提交
221 222 223 224 225


### set

set(name: string, value: string): void
Z
zengyawen 已提交
226 227 228

将与name关联的URLSearchParams对象中的值设置为value。如果存在名称为name的键值对,请将第一个键值对的值设置为value并删除所有其他值。如果不是,则将键值对附加到查询字符串。

Z
zengyawen 已提交
229
**参数:**
Z
zengyawen 已提交
230

Z
zengyawen 已提交
231 232 233 234 235 236 237
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 将要设置的参数的键值名。 |
| value | string | 是 | 所要设置的参数值。 |

**示例:**

238
```js
Z
zengyawen 已提交
239 240 241 242
let urlObject = new URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new URLSearchParams(urlObject.search.slice(1));
paramsObject.set('baz', 3); // Add a third parameter.
```
Z
zengyawen 已提交
243 244


Z
zengyawen 已提交
245
### sort
Z
zengyawen 已提交
246

Z
zengyawen 已提交
247
sort(): void
Z
zengyawen 已提交
248 249


Z
zengyawen 已提交
250
对包含在此对象中的所有键值对进行排序,并返回undefined。排序顺序是根据键的Unicode代码点。该方法使用稳定的排序算法 (即,将保留具有相等键的键值对之间的相对顺序)。
Z
zengyawen 已提交
251

Z
zengyawen 已提交
252
**示例:**
Z
zengyawen 已提交
253

254
```js
Z
zengyawen 已提交
255 256 257 258
var searchParamsObject = new URLSearchParams("c=3&a=9&b=4&d=2"); // Create a test URLSearchParams object
searchParamsObject.sort(); // Sort the key/value pairs
console.log(searchParamsObject.toString()); // Display the sorted query string // Output a=9&b=2&c=3&d=4
```
Z
zengyawen 已提交
259 260


Z
zengyawen 已提交
261
### keys
Z
zengyawen 已提交
262

Z
zengyawen 已提交
263
keys(): IterableIterator&lt;string&gt;
Z
zengyawen 已提交
264 265


Z
zengyawen 已提交
266
返回一个所有键值对的name的ES6迭代器。
Z
zengyawen 已提交
267

Z
zengyawen 已提交
268
**返回值:**
Z
zengyawen 已提交
269

Z
zengyawen 已提交
270 271 272
| 类型 | 说明 |
| -------- | -------- |
| IterableIterator&lt;string&gt; | 返回一个所有键值对的name的ES6迭代器。 |
Z
zengyawen 已提交
273

Z
zengyawen 已提交
274
**示例:**
Z
zengyawen 已提交
275

276
```js
Z
zengyawen 已提交
277 278 279 280 281
var searchParamsObject = new URLSearchParams("key1=value1&key2=value2"); // Create a URLSearchParamsObject object for testing
for (var key of searchParamsObject .keys()) { // Output key-value pairs
    console.log(key);
}
```
Z
zengyawen 已提交
282 283


Z
zengyawen 已提交
284
### values
Z
zengyawen 已提交
285

Z
zengyawen 已提交
286 287 288 289
values(): IterableIterator&lt;string&gt;

返回一个所有键值对的value的ES6迭代器。

Z
zengyawen 已提交
290
**返回值:**
Z
zengyawen 已提交
291

Z
zengyawen 已提交
292 293 294 295 296 297
| 类型 | 说明 |
| -------- | -------- |
| IterableIterator&lt;string&gt; | 返回一个所有键值对的value的ES6迭代器。 |

**示例:**

298
```js
Z
zengyawen 已提交
299 300 301 302 303
var searchParams = new URLSearchParams("key1=value1&key2=value2"); // Create a URLSearchParamsObject object for testing
for (var value of searchParams.values()) { 
    console.log(value);
}
```
Z
zengyawen 已提交
304 305


Z
zengyawen 已提交
306
### [Symbol.iterator]
Z
zengyawen 已提交
307

Z
zengyawen 已提交
308
[Symbol.iterator]\(): IterableIterator&lt;[string, string]&gt;
Z
zengyawen 已提交
309 310 311 312


返回一个ES6的迭代器,迭代器的每一项都是一个 JavaScript Array。Array的第一项是name,Array的第二项是value。

Z
zengyawen 已提交
313
**返回值:**
Z
zengyawen 已提交
314

Z
zengyawen 已提交
315 316 317
| 类型 | 说明 |
| -------- | -------- |
| IterableIterator&lt;[string,&nbsp;string]&gt; | 返回一个ES6的迭代器。 |
Z
zengyawen 已提交
318

Z
zengyawen 已提交
319
**示例:**
Z
zengyawen 已提交
320

321
```js
Z
zengyawen 已提交
322 323 324 325 326
const paramsObject = new URLSearchParams('fod=bay&edg=bap');
for (const [name, value] of paramsObject) { 
    console.log(name, value); 
} 
```
Z
zengyawen 已提交
327 328


Z
zengyawen 已提交
329
### tostring
Z
zengyawen 已提交
330

Z
zengyawen 已提交
331
toString(): string
Z
zengyawen 已提交
332 333 334 335


返回序列化为字符串的搜索参数,必要时对字符进行百分比编码。

Z
zengyawen 已提交
336
**返回值:**
Z
zengyawen 已提交
337

Z
zengyawen 已提交
338 339 340
| 类型 | 说明 |
| -------- | -------- |
| string | 返回序列化为字符串的搜索参数,必要时对字符进行百分比编码。 |
Z
zengyawen 已提交
341

Z
zengyawen 已提交
342
**示例:**
Z
zengyawen 已提交
343

344
```js
Z
zengyawen 已提交
345 346 347 348 349
let url = new URL('https://developer.exampleUrl/?fod=1&bard=2');
let params = new URLSearchParams(url.search.slice(1)); 
params.append('fod', 3);
console.log(params.toString());
```
Z
zengyawen 已提交
350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376


## URL


### 属性

| 名称 | 参数类型 | 可读 | 可写 | 说明 |
| -------- | -------- | -------- | -------- | -------- |
| hash | string | 是 | 是 | 获取和设置URL的片段部分。 |
| host | string | 是 | 是 | 获取和设置URL的主机部分。 |
| hostname | string | 是 | 是 | 获取和设置URL的主机名部分,不带端口。 |
| href | string | 是 | 是 | 获取和设置序列化的URL。 |
| origin | string | 是 | 否 | 获取URL源的只读序列化。 |
| password | string | 是 | 是 | 获取和设置URL的密码部分。 |
| pathname | string | 是 | 是 | 获取和设置URL的路径部分。 |
| port | string | 是 | 是 | 获取和设置URL的端口部分。 |
| protocol | string | 是 | 是 | 获取和设置URL的协议部分。 |
| search | string | 是 | 是 | 获取和设置URL的序列化查询部分。 |
| searchParams | URLsearchParams | 是 | 否 | 获取URLSearchParams表示URL查询参数的对象。 |
| username | string | 是 | 是 | 获取和设置URL的用户名部分。 |


### constructor

constructor(url: string, base?: string | URL)

Z
zengyawen 已提交
377 378 379

URL的构造函数。

Z
zengyawen 已提交
380
**参数:**
Z
zengyawen 已提交
381

Z
zengyawen 已提交
382 383 384 385
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| url | string | 是 | 入参对象。 |
| base | string&nbsp;\|&nbsp;URL | 否 | 入参字符串或者对象。<br/>-&nbsp;string:字符串<br/>-&nbsp;URL:字符串或对象 |
Z
zengyawen 已提交
386

Z
zengyawen 已提交
387
**示例:**
Z
zengyawen 已提交
388

389
```js
Z
zengyawen 已提交
390 391 392 393 394 395 396 397 398 399 400 401 402
var mm = 'http://username:password@host:8080';
var a = new URL("/", mm); // Output 'http://username:password@host:8080/';
var b = new URL(mm); // Output 'http://username:password@host:8080/';
new URL('path/path1', b); // Output 'http://username:password@host:8080/path/path1';
var c = new URL('/path/path1', b);  // Output 'http://username:password@host:8080/path/path1'; 
new URL('/path/path1', c); // Output 'http://username:password@host:8080/path/path1';
new URL('/path/path1', a); // Output 'http://username:password@host:8080/path/path1';
new URL('/path/path1', "https://www.exampleUrl/fr-FR/toto"); // Output https://www.exampleUrl/path/path1
new URL('/path/path1', ''); // Raises a TypeError exception as '' is not a valid URL
new URL('/path/path1'); // Raises a TypeError exception as '/path/path1' is not a valid URL
new URL('http://www.shanxi.com', ); // Output http://www.shanxi.com/
new URL('http://www.shanxi.com', b); // Output http://www.shanxi.com/
```
Z
zengyawen 已提交
403 404


Z
zengyawen 已提交
405
### tostring
Z
zengyawen 已提交
406

Z
zengyawen 已提交
407
toString(): string
Z
zengyawen 已提交
408

Z
zengyawen 已提交
409
将解析过后的URL转化为字符串。
Z
zengyawen 已提交
410

Z
zengyawen 已提交
411
**返回值:**
Z
zengyawen 已提交
412

Z
zengyawen 已提交
413 414 415
| 类型 | 说明 |
| -------- | -------- |
| string | 用于返回网址的字符串序列化。 |
Z
zengyawen 已提交
416

Z
zengyawen 已提交
417
**示例:**
Z
zengyawen 已提交
418

419
```js
Z
zengyawen 已提交
420 421 422
const url = new URL('http://username:password@host:8080/directory/file?query=pppppp#qwer=da');
url.toString()
```
Z
zengyawen 已提交
423 424


Z
zengyawen 已提交
425
### toJSON
Z
zengyawen 已提交
426

Z
zengyawen 已提交
427 428 429 430
toJSON(): string


将解析过后的URL转化为JSON字符串。
Z
zengyawen 已提交
431

Z
zengyawen 已提交
432
**返回值:**
Z
zengyawen 已提交
433

Z
zengyawen 已提交
434 435 436
| 类型 | 说明 |
| -------- | -------- |
| string | 用于返回网址的字符串序列化。 |
Z
zengyawen 已提交
437

Z
zengyawen 已提交
438
**示例:**
439
```js
Z
zengyawen 已提交
440 441 442
const url = new URL('http://username:password@host:8080/directory/file?query=pppppp#qwer=da');
url.toJSON()
```