PHP's rawurldecode in TypeScript

✓ Verified: PHP 8.3
Examples tested against actual runtime. CI re-verifies continuously. Only documented examples are tested.

How to use

Install via yarn add locutus and import: import { rawurldecode } from 'locutus/php/url/rawurldecode'.

Or with CommonJS: const { rawurldecode } = require('locutus/php/url/rawurldecode')

Use a bundler that supports tree-shaking so you only ship the functions you actually use. Vite, webpack, Rollup, and Parcel all handle this. For server-side use this is less of a concern.

Examples

These examples are extracted from test cases that automatically verify our functions against their native counterparts.

#codeexpected result
1rawurldecode('Kevin+van+Zonneveld%21')'Kevin+van+Zonneveld!'
2rawurldecode('https%3A%2F%2Fkvz.io%2F')'https://kvz.io/'
3rawurldecode('https%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3DLocutus%26ie%3D')'https://www.google.nl/search?q=Locutus&ie='

Notes

  • Please be aware that this function expects to decode from UTF-8 encoded strings, as found on pages served as UTF-8

Here's what our current TypeScript equivalent to PHP's rawurldecode looks like.

export function rawurldecode(str: string): string {
// discuss at: https://locutus.io/php/rawurldecode/
// parity verified: PHP 8.3
// original by: Brett Zamir (https://brett-zamir.me)
// input by: travc
// input by: Brett Zamir (https://brett-zamir.me)
// input by: Ratheous
// input by: lovio
// bugfixed by: Kevin van Zonneveld (https://kvz.io)
// reimplemented by: Brett Zamir (https://brett-zamir.me)
// improved by: Brett Zamir (https://brett-zamir.me)
// note 1: Please be aware that this function expects to decode
// note 1: from UTF-8 encoded strings, as found on
// note 1: pages served as UTF-8
// example 1: rawurldecode('Kevin+van+Zonneveld%21')
// returns 1: 'Kevin+van+Zonneveld!'
// example 2: rawurldecode('https%3A%2F%2Fkvz.io%2F')
// returns 2: 'https://kvz.io/'
// example 3: rawurldecode('https%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3DLocutus%26ie%3D')
// returns 3: 'https://www.google.nl/search?q=Locutus&ie='

return decodeURIComponent(
(str + '').replace(/%(?![\da-f]{2})/gi, function () {
// PHP tolerates poorly formed escape sequences
return '%25'
}),
)
}

Improve this function

Locutus is a community effort following The McDonald's Theory: we ship first iterations, hoping others will improve them. If you see something that could be better, we'd love your contribution.

View on GitHub · Edit on GitHub · View Raw


« More PHP url functions


Star