decodeURIComponent()

decodeURIComponent() 関数は、encodeURIComponent 関数あるいは同様のルーチンによって事前に作成された URI (Uniform Resource Identifier; 統一資源識別子) の構成要素をデコードします。

構文

decodeURIComponent(encodedURI)

引数

encodedURI
エンコードされた URI の構成要素。

戻り値

特定の文字がデコードされた新しい文字列。

例外

不正なURIが使用された場合、URIError ("malformed URI sequence") がスローされる

説明

エンコードされた URI の構成要素内のエスケープシーケンスを、それぞれが表す文字に置き換えます。

使用例

キリル文字の URL 構成要素をデコード

decodeURIComponent("JavaScript_%D1%88%D0%B5%D0%BB%D0%BB%D1%8B");
// "JavaScript_шеллы"

Catching errors

try { 
  var a = decodeURIComponent('%E0%A4%A'); 
} catch(e) { 
  console.error(e); 
}

// URIError: malformed URI sequence

Decoding query parameters from a URL

decodeURIComponent cannot be used directly to parse query parameters from a URL. It needs a bit of preparation.

function decodeQueryParam(p) {
  return decodeURIComponent(p.replace(/\+/g, ' '));
}

decodeQueryParam('search+query%20%28correct%29');
// 'search query (correct)'

仕様

仕様 策定状況 コメント
ECMAScript 3rd Edition (ECMA-262) 標準 初期定義。
ECMAScript 5.1 (ECMA-262)
decodeURIComponent の定義
標準
ECMAScript 2015 (6th Edition, ECMA-262)
decodeURIComponent の定義
標準
ECMAScript Latest Draft (ECMA-262)
decodeURIComponent の定義
ドラフト

ブラウザ実装状況

Browser compatibility

Update compatibility data on GitHub
デスクトップモバイルサーバー
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewAndroid 版 ChromeAndroid 版 FirefoxAndroid 版 OperaiOSのSafariSamsung InternetNode.js
decodeURIComponentChrome 完全対応 1Edge 完全対応 12Firefox 完全対応 1IE 完全対応 5.5Opera 完全対応 7Safari 完全対応 1.1WebView Android 完全対応 1Chrome Android 完全対応 18Firefox Android 完全対応 4Opera Android 完全対応 10.1Safari iOS 完全対応 1Samsung Internet Android 完全対応 1.0nodejs 完全対応 あり

凡例

完全対応  
完全対応

関連情報