URL字符串解析
說明: 本模塊首批接口從API version 7開始支持。后續(xù)版本的新增接口,采用上角標(biāo)單獨(dú)標(biāo)記接口的起始版本。 開發(fā)前請(qǐng)熟悉鴻蒙開發(fā)指導(dǎo)文檔 :[
gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md
]
導(dǎo)入模塊
import Url from '@ohos.url'
URLSearchParams
constructor
constructor(init?: string[][] | Record | string | URLSearchParams)
URLSearchParams的構(gòu)造函數(shù)。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
init | string[][] | Record | string |
示例:
var objectParams = new Url.URLSearchParams([ ['user1', 'abc1'], ['query2', 'first2'], ['query3', 'second3'] ]);
var objectParams1 = new Url.URLSearchParams({"fod" : 1 , "bard" : 2});
var objectParams2 = new Url.URLSearchParams('?fod=1&bard=2');
var urlObject = new Url.URL('https://developer.mozilla.org/?fod=1&bard=2');
var params = new Url.URLSearchParams(urlObject.search);
append
append(name: string, value: string): void
將新的鍵值對(duì)插入到查詢字符串。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
name | string | 是 | 需要插入搜索參數(shù)的鍵名。 |
value | string | 是 | 需要插入搜索參數(shù)的值。 |
示例:
let urlObject = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new Url.URLSearchParams(urlObject.search.slice(1));
paramsObject.append('fod', 3);
delete
delete(name: string): void
刪除指定名稱的鍵值對(duì)。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
name | string | 是 | 需要?jiǎng)h除的鍵值名稱。 |
示例:
let urlObject = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsobject = new Url.URLSearchParams(urlObject.search.slice(1));
paramsobject.delete('fod');
getAll
getAll(name: string): string[]
獲取指定名稱的所有鍵值對(duì)。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
name | string | 是 | 指定的鍵值名稱。 |
返回值:
類型 | 說明 |
---|---|
string[] | 返回指定名稱的所有鍵值對(duì)。 |
示例:
let urlObject = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new Url.URLSearchParams(urlObject.search.slice(1));
paramsObject.append('fod', 3); // Add a second value for the fod parameter.
console.log(params.getAll('fod')) // Output ["1","3"].
entries
entries(): IterableIterator<[string, string]>
返回一個(gè)ES6的迭代器,迭代器的每一項(xiàng)都是一個(gè) JavaScript Array。Array的第一項(xiàng)是name,Array的第二項(xiàng)是value。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明 |
---|---|
IterableIterator<[string, string]> | 返回一個(gè)ES6的迭代器。 |
示例:
var searchParamsObject = new Url.URLSearchParams("keyName1=valueName1&keyName2=valueName2");
for (var pair of searchParamsObject .entries()) { // Show keyName/valueName pairs
console.log(pair[0]+ ', '+ pair[1]);
}
forEach
forEach(callbackfn: (value: string, key: string, searchParams: this) => void, thisArg?: Object): void
通過回調(diào)函數(shù)來遍歷URLSearchParams實(shí)例對(duì)象上的鍵值對(duì)。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
callbackfn | function | 是 | 回調(diào)函數(shù)。 |
thisArg | Object | 否 | callbackfn被調(diào)用時(shí)用作this值 |
表1 callbackfn的參數(shù)說明
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
value | string | 是 | 當(dāng)前遍歷到的鍵值。 |
key | string | 是 | 當(dāng)前遍歷到的鍵名。 |
searchParams | Object | 是 | 當(dāng)前調(diào)用forEach方法的實(shí)例對(duì)象。 |
示例:
const myURLObject = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
myURLObject.searchParams.forEach((value, name, searchParams) = > {
console.log(name, value, myURLObject.searchParams === searchParams);
});
get
get(name: string): string | null
獲取指定名稱對(duì)應(yīng)的第一個(gè)值。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
name | string | 是 | 指定鍵值對(duì)的名稱。 |
返回值:
類型 | 說明 |
---|---|
string | 返回第一個(gè)值。 |
null | 如果沒找到,返回 null。 |
示例:
var paramsOject = new Url.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
has
has(name: string): boolean
判斷一個(gè)指定的鍵名對(duì)應(yīng)的值是否存在。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
name | string | 是 | 要查找的參數(shù)的鍵名。 |
返回值:
類型 | 說明 |
---|---|
boolean | 是否存在相對(duì)應(yīng)的key值,存在返回true,否則返回false。 |
示例:
let urlObject = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new Url.URLSearchParams(urlObject.search.slice(1));
paramsObject.has('bard') === true;
set
set(name: string, value: string): void
將與name關(guān)聯(lián)的URLSearchParams對(duì)象中的值設(shè)置為value。如果存在名稱為name的鍵值對(duì),請(qǐng)將第一個(gè)鍵值對(duì)的值設(shè)置為value并刪除所有其他值。如果不是,則將鍵值對(duì)附加到查詢字符串。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
name | string | 是 | 將要設(shè)置的參數(shù)的鍵值名。 |
value | string | 是 | 所要設(shè)置的參數(shù)值。 |
示例:
let urlObject = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
let paramsObject = new Url.URLSearchParams(urlObject.search.slice(1));
paramsObject.set('baz', 3); // Add a third parameter.
sort
sort(): void
對(duì)包含在此對(duì)象中的所有鍵值對(duì)進(jìn)行排序,并返回undefined。排序順序是根據(jù)鍵的Unicode代碼點(diǎn)。該方法使用穩(wěn)定的排序算法 (即,將保留具有相等鍵的鍵值對(duì)之間的相對(duì)順序)。
系統(tǒng)能力: SystemCapability.Utils.Lang
示例:
var searchParamsObject = new Url.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
keys
keys(): IterableIterator
返回一個(gè)所有鍵值對(duì)的name的ES6迭代器。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明 |
---|---|
IterableIterator | 返回一個(gè)所有鍵值對(duì)的name的ES6迭代器。 |
示例:
var searchParamsObject = new Url.URLSearchParams("key1=value1&key2=value2"); // Create a URLSearchParamsObject object for testing
for (var key of searchParamsObject .keys()) { // Output key-value pairs
console.log(key);
}
values
values(): IterableIterator
返回一個(gè)所有鍵值對(duì)的value的ES6迭代器。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明 |
---|---|
IterableIterator | 返回一個(gè)所有鍵值對(duì)的value的ES6迭代器。 |
示例:
var searchParams = new Url.URLSearchParams("key1=value1&key2=value2"); // Create a URLSearchParamsObject object for testing
for (var value of searchParams.values()) {
console.log(value);
}
[Symbol.iterator]
Symbol.iterator: IterableIterator<[string, string]>
返回一個(gè)ES6的迭代器,迭代器的每一項(xiàng)都是一個(gè) JavaScript Array。Array的第一項(xiàng)是name,Array的第二項(xiàng)是value。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明 |
---|---|
IterableIterator<[string, string]> | 返回一個(gè)ES6的迭代器。 |
示例:
const paramsObject = new Url.URLSearchParams('fod=bay&edg=bap');
for (const [name, value] of paramsObject) {
console.log(name, value);
}
tostring
toString(): string
返回序列化為字符串的搜索參數(shù),必要時(shí)對(duì)字符進(jìn)行百分比編碼。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明 |
---|---|
string | 返回序列化為字符串的搜索參數(shù),必要時(shí)對(duì)字符進(jìn)行百分比編碼。 |
示例:
let url = new Url.URL('https://developer.exampleUrl/?fod=1&bard=2');
let params = new Url.URLSearchParams(url.search.slice(1));
params.append('fod', 3);
console.log(params.toString());
URL
屬性
系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang
名稱 | 參數(shù)類型 | 可讀 | 可寫 | 說明 |
---|---|---|---|---|
hash | string | 是 | 是 | 獲取和設(shè)置URL的片段部分。 |
host | string | 是 | 是 | 獲取和設(shè)置URL的主機(jī)部分。 |
hostname | string | 是 | 是 | 獲取和設(shè)置URL的主機(jī)名部分,不帶端口。 |
href | string | 是 | 是 | 獲取和設(shè)置序列化的URL。 |
origin | string | 是 | 否 | 獲取URL源的只讀序列化。 |
password | string | 是 | 是 | 獲取和設(shè)置URL的密碼部分。 |
pathname | string | 是 | 是 | 獲取和設(shè)置URL的路徑部分。 |
port | string | 是 | 是 | 獲取和設(shè)置URL的端口部分。 |
protocol | string | 是 | 是 | 獲取和設(shè)置URL的協(xié)議部分。 |
search | string | 是 | 是 | 獲取和設(shè)置URL的序列化查詢部分。 |
searchParams | URLsearchParams | 是 | 否 | 獲取URLSearchParams表示URL查詢參數(shù)的對(duì)象。 |
username | string | 是 | 是 | 獲取和設(shè)置URL的用戶名部分。 |
constructor
constructor(url: string, base?: string | URL)
URL的構(gòu)造函數(shù)。
系統(tǒng)能力: SystemCapability.Utils.Lang
參數(shù):
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
url | string | 是 | 入?yún)?duì)象。 |
base | string | URL | 否 |
示例:
var mm = 'http://username:password@host:8080';
var a = new Url.URL("/", mm); // Output 'http://username:password@host:8080/';
var b = new Url.URL(mm); // Output 'http://username:password@host:8080/';
new Url.URL('path/path1', b); // Output 'http://username:password@host:8080/path/path1';
var c = new Url.URL('/path/path1', b); // Output 'http://username:password@host:8080/path/path1';
new Url.URL('/path/path1', c); // Output 'http://username:password@host:8080/path/path1';
new Url.URL('/path/path1', a); // Output 'http://username:password@host:8080/path/path1';
new Url.URL('/path/path1', "https://www.exampleUrl/fr-FR/toto"); // Output https://www.exampleUrl/path/path1
new Url.URL('/path/path1', ''); // Raises a TypeError exception as '' is not a valid URL
new Url.URL('/path/path1'); // Raises a TypeError exception as '/path/path1' is not a valid URL
new Url.URL('http://www.shanxi.com', ); // Output http://www.shanxi.com/
new Url.URL('http://www.shanxi.com', b); // Output http://www.shanxi.com/
tostring
toString(): string
將解析過后的URL轉(zhuǎn)化為字符串。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明 |
---|---|
string | 用于返回網(wǎng)址的字符串序列化。 |
示例:
const url = new Url.URL('http://username:password@host:8080/directory/file?query=pppppp#qwer=da');
url.toString()
toJSON
toJSON(): string
將解析過后的URL轉(zhuǎn)化為JSON字符串。
系統(tǒng)能力: SystemCapability.Utils.Lang
返回值:
類型 | 說明HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿 |
---|---|
string | 用于返回網(wǎng)址的字符串序列化。 |
示例:
const url = new Url.URL('http://username:password@host:8080/directory/file?query=pppppp#qwer=da');
審核編輯 黃宇
-
URL
+關(guān)注
關(guān)注
0文章
139瀏覽量
15299 -
字符串
+關(guān)注
關(guān)注
1文章
575瀏覽量
20470 -
鴻蒙
+關(guān)注
關(guān)注
57文章
2303瀏覽量
42691
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論