I have 2 cases here:
My Database contains lots of info which I want to fetch to the page, some of these info are name which contain non-ascii chars like Uwe Rü
Thanks to Aaron Digulla's answer, I followed the string from server to the page and found that it is gets misrepresented after the AJAX LOAD
, so I found this answer which resolved my problem. Although I had to use the charset="iso-8859-1"
for it to work rather than charset="UTF-8"
.
So the final answer is:
-Encoding in the HTML page:
<meta http-equiv="Content-Type" content="text/html"; charset="iso-8859-1">
-Encoding the Ajax data:
$.ajaxSetup({
'beforeSend' : function(xhr) {
xhr.overrideMimeType('text/html; charset=iso-8859-1');
},
});
And now chars are displayed correctly. Thanx for your help guys..
Javascript default encoding for strings is UTF-16 (16 bits) while iso-8859-1 is 8 bits.
Default Javascript Character Encoding?
I think you can use encodeURI()
to convert your special characters to ASCII characters and afterwards you can decode it with decodeURI()
http://www.w3schools.com/jsref/jsref_encodeuri.asp
The �
means that you used a character which can't be represented properly.
Somewhere between the server and the client, you need to encode the string data properly. I don't know how you transfer the data from the server to the client (generate JavaScript, AJAX, GET requests), it's hard to say how to fix this.
But what you need to do: For every step, you must make sure that you know what the current encoding of the data is and what the recipient expects.
For example if you generate inline JavaScript in a HTML page, then the string value must be encoded with the same encoding as the page (iso-8859-1
). If you use AJAX, then usually you have to use UTF-8
.