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

Or with CommonJS: const { html_entity_decode } = require('locutus/php/strings/html_entity_decode')

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
1html_entity_decode('Kevin & van Zonneveld')'Kevin & van Zonneveld'
2html_entity_decode('<')'<'

Dependencies

This function uses the following Locutus functions:

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

import { type PhpInput, toPhpArrayObject } from '../_helpers/_phpTypes.ts'
import { get_html_translation_table as getHtmlTranslationTable } from '../strings/get_html_translation_table.ts'

export function html_entity_decode(string: string, quoteStyle?: string | number): string | false {
// discuss at: https://locutus.io/php/html_entity_decode/
// parity verified: PHP 8.3
// original by: john (https://www.jd-tech.net)
// input by: ger
// input by: Ratheous
// input by: Nick Kolosov (https://sammy.ru)
// improved by: Kevin van Zonneveld (https://kvz.io)
// improved by: marc andreu
// revised by: Kevin van Zonneveld (https://kvz.io)
// revised by: Kevin van Zonneveld (https://kvz.io)
// bugfixed by: Onno Marsman (https://twitter.com/onnomarsman)
// bugfixed by: Brett Zamir (https://brett-zamir.me)
// bugfixed by: Fox
// example 1: html_entity_decode('Kevin & van Zonneveld')
// returns 1: 'Kevin & van Zonneveld'
// example 2: html_entity_decode('<')
// returns 2: '<'

let tmpStr = string.toString()

const hashMapUnknown: PhpInput = getHtmlTranslationTable('HTML_ENTITIES', quoteStyle)
if (hashMapUnknown === false || !hashMapUnknown || typeof hashMapUnknown !== 'object') {
return false
}
const normalizedHashMap: { [key: string]: string } = {}
const hashMapObject = toPhpArrayObject(hashMapUnknown)
for (const [symbol, entity] of Object.entries(hashMapObject)) {
if (typeof entity === 'string') {
normalizedHashMap[symbol] = entity
}
}

// @todo: & problem
// https://locutus.io/php/get_html_translation_table:416#comment_97660
delete normalizedHashMap['&']
normalizedHashMap['&'] = '&'

for (const [symbol, entity] of Object.entries(normalizedHashMap)) {
tmpStr = tmpStr.replaceAll(entity, symbol)
}
tmpStr = tmpStr.replaceAll(''', "'")

return tmpStr
}

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 strings functions


Star