我有2个案例:
我的数据库包含许多我想要提取到页面的信息,其中一些信息是包含非{ascii字符的名称,如Uwe Rülke
- 旧解决方案运作良好:
我从数据库中获取数据并直接从 VB while
循环填充页面。在这种情况下,所有字符都正确显示Uwe Rülke
- 新的解决方案无法正常工作:
VB的While
循环不会将数据直接抛出到页面中,而是放在JS字符串中(通过不时调用DB来提高性能)。但是当我使用存储在JS变量中的信息时,我得到了这样的信息:Uwe R�lke
。
在这两种情况下,网页的编码都是:
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
我哪里出错了?
这是用于获取(从DB)然后保存到js Strings的代码。
我在名为AJAX LOAD
的网页中使用ISEquery
来构建特定请求并从数据库中查询。它用于将数据作为excel
文件或普通HTML
获取。 此时,字符代表性很好。
然后神奇的事情发生了,而且字符被错误表示,我在exctractFields
函数中检查了它
$("<div></div>").load("ISEquery.asp?isExcel=0&" + info, function(){
// Extracting the fields into an array
var rows = "";
var options = "";
$(this).children().each(function(index){
var fieldsArray = exctractFields($(this).html());
rows += createISELine(fieldsArray);
options += createISELine_ComboBox(fieldsArray);
});
});
答案 0 :(得分:5)
�
表示您使用了无法正确表示的字符。
在服务器和客户端之间的某处,您需要正确编码字符串数据。我不知道你如何将数据从服务器传输到客户端(生成JavaScript,AJAX,GET请求),很难说如何解决这个问题。
但是你需要做什么:对于每一步,你必须确保你知道数据的当前编码是什么以及收件人期望什么。
例如,如果您在HTML页面中生成内联JavaScript,则必须使用与页面(iso-8859-1
)相同的编码对字符串值进行编码。如果您使用AJAX,那么通常您必须使用UTF-8
。
答案 1 :(得分:2)
感谢Aaron Digulla的answer,我跟踪了从服务器到页面的字符串,发现它在AJAX LOAD
之后被误传,所以我发现这个answer解决了我的问题。虽然我必须使用charset="iso-8859-1"
才能使用{而不是charset="UTF-8"
。
所以最终的答案是:
- 在HTML页面中编码:
<meta http-equiv="Content-Type" content="text/html"; charset="iso-8859-1">
- 编写Ajax数据:
$.ajaxSetup({
'beforeSend' : function(xhr) {
xhr.overrideMimeType('text/html; charset=iso-8859-1');
},
});
现在字符显示正确。 Thanx为你帮助的人..
答案 2 :(得分:-2)
字符串的Javascript默认编码是UTF-16(16位),而iso-8859-1是8位。
Default Javascript Character Encoding?
我认为您可以使用encodeURI()
将特殊字符转换为ASCII字符,之后您可以使用decodeURI()