title | tags | author_title | author_url | author_image_url | description | image |
---|---|---|---|---|---|---|
escapeHTML |
string,browser,regexp,intermediate |
Deepak Vishwakarma |
Implementation of "escapeHTML" in typescript, javascript and deno. |
Escapes a string for use in HTML.
Use String.prototype.replace()
with a regexp that matches the characters that need to be escaped, using a callback function to replace each character instance with its associated escaped character using a dictionary (object).
export enum HTMLEscapeChars {
"&" = "&",
"<" = "<",
">" = ">",
"'" = "'",
'"' = """,
}
const htmlEscapeReg = new RegExp(`[${Object.keys(HTMLEscapeChars)}]`, "g");
const escapeHTML = (str: string) =>
str.replace(
htmlEscapeReg,
(tag: string) => (HTMLEscapeChars as StringMap<string>)[tag] || tag
);
escapeHTML('<a href="#">Me & you</a>'); // '<a href="#">Me & you</a>'