PHP's rawurlencode 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 { rawurlencode } from 'locutus/php/url/rawurlencode'.

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

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
1rawurlencode('Kevin van Zonneveld!')'Kevin%20van%20Zonneveld%21'
2rawurlencode('https://kvz.io/')'https%3A%2F%2Fkvz.io%2F'
3rawurlencode('https://www.google.nl/search?q=Locutus&ie=utf-8')'https%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3DLocutus%26ie%3Dutf-8'

Notes

  • This reflects PHP 5.3/6.0+ behavior Please be aware that this function expects
    to encode into UTF-8 encoded strings, as found on pages served as UTF-8

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

export function rawurlencode(str: string): string {
// discuss at: https://locutus.io/php/rawurlencode/
// 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: Michael Grier
// input by: Ratheous
// bugfixed by: Kevin van Zonneveld (https://kvz.io)
// bugfixed by: Brett Zamir (https://brett-zamir.me)
// bugfixed by: Joris
// reimplemented by: Brett Zamir (https://brett-zamir.me)
// reimplemented by: Brett Zamir (https://brett-zamir.me)
// note 1: This reflects PHP 5.3/6.0+ behavior
// note 1: Please be aware that this function expects \
// note 1: to encode into UTF-8 encoded strings, as found on
// note 1: pages served as UTF-8
// example 1: rawurlencode('Kevin van Zonneveld!')
// returns 1: 'Kevin%20van%20Zonneveld%21'
// example 2: rawurlencode('https://kvz.io/')
// returns 2: 'https%3A%2F%2Fkvz.io%2F'
// example 3: rawurlencode('https://www.google.nl/search?q=Locutus&ie=utf-8')
// returns 3: 'https%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3DLocutus%26ie%3Dutf-8'

str = str + ''

// Tilde should be allowed unescaped in future versions of PHP (as reflected below),
// but if you want to reflect current
// PHP behavior, you would need to add ".replace(/~/g, '%7E');" to the following.
return encodeURIComponent(str)
.replace(/!/g, '%21')
.replace(/'/g, '%27')
.replace(/\(/g, '%28')
.replace(/\)/g, '%29')
.replace(/\*/g, '%2A')
}

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