Znaki specjalne HTML i jego ESCAPE CODES
Zastrzeżone znaki muszą być chronione kodem HTML: możemy użyć znaku ucieczki, aby przedstawić dowolny znak Unicode [np: & - U + 00026] w HTML, XHTML lub XML, używając tylko znaków ASCII. Odniesienia do znaków numerycznych [ np. Ampersand (&) - &
] i Odniesienia do nazwanych znaków [np.: &
] To typy character escape used in markup
.
Original Character XML entity replacement XML numeric replacement
< < <
> > >
" " "
& & &
' ' '
Aby wyświetlić znaczniki HTML jako normalny w postaci strony internetowej używamy <pre>
, <code>
tagi czy możemy im uciec. Zmiana znaczenia dla ciągu znaków poprzez zastąpienie dowolnego wystąpienia "&"
znaku w ciągu "&"
i wszelkich wystąpień ">"
znaku w ciągu ">"
. Dawny:stackoverflow post
function escapeCharEntities() {
var map = {
"&": "&",
"<": "<",
">": ">",
"\"": """,
"'": "'"
};
return map;
}
var mapkeys = '', mapvalues = '';
var html = {
encodeRex : function () {
return new RegExp(mapkeys, 'g');
},
decodeRex : function () {
return new RegExp(mapvalues, 'g');
},
encodeMap : JSON.parse( JSON.stringify( escapeCharEntities () ) ),
decodeMap : JSON.parse( JSON.stringify( swapJsonKeyValues( escapeCharEntities () ) ) ),
encode : function ( str ) {
var encodeRexs = html.encodeRex();
console.log('Encode Rex: ', encodeRexs);
return str.replace(encodeRexs, function(m) { console.log('Encode M: ', m); return html.encodeMap[m]; });
},
decode : function ( str ) {
var decodeRexs = html.decodeRex();
console.log('Decode Rex: ', decodeRexs);
return str.replace(decodeRexs, function(m) { console.log('Decode M: ', m); return html.decodeMap[m]; });
}
};
function swapJsonKeyValues ( json ) {
var count = Object.keys( json ).length;
var obj = {};
var keys = '[', val = '(', keysCount = 1;
for(var key in json) {
if ( json.hasOwnProperty( key ) ) {
obj[ json[ key ] ] = key;
keys += key;
if( keysCount < count ) {
val += json[ key ]+'|';
} else {
val += json[ key ];
}
keysCount++;
}
}
keys += ']'; val += ')';
console.log( keys, ' == ', val);
mapkeys = keys;
mapvalues = val;
return obj;
}
console.log('Encode: ', html.encode('<input type="password" name="password" value=""/>') );
console.log('Decode: ', html.decode(html.encode('<input type="password" name="password" value=""/>')) );
O/P:
Encode: <input type="password" name="password" value=""/>
Decode: <input type="password" name="password" value=""/>