I'm trying to unescape a HTML-escaped apostrophe ("'"
) in JavaScript, but the following doesn't seem to work on a devtools console line:
unescape(''');
The output is simply:
"'"
It doesn't work in Underscore's unescape either:
_.unescape(''')
What am I doing wrong?
unescape() Deprecated: This feature is no longer recommended. Though some browsers might still support it, it may have already been removed from the relevant web standards, may be in the process of being dropped, or may only be kept for compatibility purposes.
Unescape apostrophe (') in JavaScript?
The escape() function is used to encode a string, making it safe for use in a URL. The unescape() function is used to decode an encoded string.
The escape() and unescape() functions is to Encode and decode a string in JavaScript. The escape() function in JavaScript to make a string portable to transmit it over a network and we can use unscape() function to get back the original string.
unescape
has nothing to do with HTML character entities. It's an old, deprecated function for decoding text encoded with escape
, which is an old, deprecated function for encoding text in a way that is unlikely to be useful in the modern world. :-)
If you need to turn that HTML into plain text, the easiest way is via an element:
var div = document.createElement('div');
div.innerHTML = "'";
alert(div.firstChild.nodeValue);
Live Example | Live Source
Note that the above relies on the fact that there are no elements defined in your HTML text, so it knows there is exactly one child node of div
, which is a text node.
For more complicated use cases, you might use div.innerText
(if it has one) or div.textContent
:
var div = document.createElement('div');
div.innerHTML = "'";
alert(div.innerText || div.textContent || "");
Live Example | Live Source
By using createElement
like in T.J.'s answer, you open yourself up to XSS attacks.
DOMParser
is a much safer way to correctly unescape HTML entities (including '
)
function unescape(string) {
return new DOMParser().parseFromString(string,'text/html').querySelector('html').textContent;
}
console.log(unescape('''));
You can use the function above with a string from any source, and the string won't be able to modify your page or steal data by including JavaScript.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With