Специальные символы HTML и их ESCAPE CODES
Зарезервированные символы должны быть экранированы с помощью HTML: мы можем использовать экранирование символа для представления любого символа Юникода [Пример: & - U + 00026] в HTML, XHTML или XML, используя только символы ASCII. Ссылки на числовые символы [ Пример: амперсанд (&) - &
] & Ссылки на именованные символы [Пример: &
] являются типами character escape used in markup
.
Original Character XML entity replacement XML numeric replacement
< < <
> > >
" " "
& & &
' ' '
Для отображения HTML - теги в качестве нормальной формы в веб - страницы , мы используем <pre>
, <code>
теги или мы можем избежать их. Экранирование строки путем замены любым вхождением "&"
символа в строке "&"
и любых вхождений ">"
символа в строке ">"
. Пример: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=""/>