无法使用jquery显示希伯来语

时间:2013-01-22 14:55:02

标签: jquery json node.js hebrew

我正在写一个小小的电子邮件服务器。客户端写在javascript/jquery和服务器端nodeJS(这是家庭作业)

在客户端,我发送电子邮件如下

function send() {
var dataString = 'to=' + $("#to").val() + '&subject=' + $("#subject").val() + '&body=' + $("#body").val();
var lines = $("#body").val().split("\n");
for (var i = 0;i < lines.length;i++ ) {
    dataString += '&line' + i + '=' + lines[i];
}
$.ajax({
            type: "POST",
        url: "/send",
            cache: false,
        data: dataString,
        success: function(data) {
        location.reload();
            },
        error: function(xhr, textStatus, errorThrown) {
        location.reload();
        }
        });
}

其中$("body")是textarea元素。我在客户端上输出了body,这确实是希伯来语。我使用此功能检索电子邮件:

function getMail() {
    $("#navigationButtons").show();
    $("#workingAread").empty();
    var dataString = 'start=' + start + '&url=' + url;
    $.ajax({type: "GET", data: dataString, dataType:"json", url: 'getMail', cache: false})
    .done(function(data){
        mails = data;
        $("#workingArea").empty();
        if (mails.length === 0) {
                $("#workingArea").html("Your inbox is empty");
        }
        var mailContainer = $("<div></div>");
        numOfMails = mails.pop();
            mails.forEach(function(elem,i){
                var mail =  $("<span></span>");
                mail.text(elem.fullName + ", " + elem.date + ": " + elem.subject);
                mail.click(showMail.bind(this,i));
            var chk = $("<input></input>")
                    .attr("type","checkbox")
                    .attr("id",elem.uuid);
                mailContainer.append(chk).append(mail);
                mailContainer.append("<br>");
            });
            $("#workingArea").append(mailContainer);
        return;
    })
}

正如您所看到的,dataType设置为json。问题是我得到了胡言乱语,主要是问号。

有没有人知道如何解决它?

谢谢!

1 个答案:

答案 0 :(得分:2)

确保您的HTML页面编码为UTF-8,服务器发送UTF-8,并且您的电子邮件存储为UTF-8。