无法从Unicode JSON响应中显示表情符号

3
<!DOCTYPE html>
<html>
<head>
    <title>WeekAPI</title>
    <meta charset="utf-8">
</head>
<body>
    Tag Value from Variable
    <h1 id="txtDisplay">Please Wait..</h1>

    Tag Value from API
    <h1 id="txtResponse">Please Wait..<h1>

    <script type="text/javascript" src="https://code.jquery.com/jquery-1.12.4.min.js"></script>

    <script>

        var tag_value = "\uD83D\uDE05\uD83D\uDE00\uD83D\uDE02\uD83D\uDE2C\uD83D\uDE10\uD83D\uDE0E";

        $("#txtDisplay").html(tag_value);


        var api = "http://week.esy.es/api?id=140393107018&institute=039&branch=07&semester=7&callback=?";

        $.getJSON(api, function(data) {
            //response tag value is same as tag_value variable
            $("#txtResponse").html(data.schedule.friday[0].tag);
        });   
    </script>
</body>
</html>

API响应数据

{
  "ok": true,
  "message": "Successful.",
  "schedule": {
    "monday": [
      {
        "type": "lecture",
        "_id": 2,
        "start": "11:32 AM",
        "end": "11:32 AM",
        "teacher": "KPP",
        "subject": "Compiler Design",
        "tag": ""
      }
    ],
    "tuesday": [],
    "wednesday": [],
    "thursday": [],
    "friday": [
      {
        "type": "holiday",
        "_id": 2,
        "start": "09:30 AM",
        "end": "10:21 AM",
        "name": "\\u0928\\u0935\\u0930\\u093E\\u0924\\u094D\\u0930\\u093F",
        "tag": "\\uD83D\\uDE05\\uD83D\\uDE00\\uD83D\\uDE02\\uD83D\\uDE2C\\uD83D\\uDE10\\uD83D\\uDE0E"
      }
    ],
    "saturday": [],
    "sunday": []
  }
}

WeekAPI输出

第一种情况

将表情符号的unicode值存储在tag_value变量中

使用$("#txtDisplay").html(tag_value);在txtDisplay部分显示。

正常工作

但是当

第二种情况

从api检索标签值(与上述相同的值)

使用$("#txtResponse").html(data.schedule.friday[0].tag);在txtResponse部分显示。

它无法显示表情符号。 它显示文本而不是表情符号。


你能否更新帖子并提供完整的JSON示例? - Aravind
帖子已更新 :) - asissuthar
1
问题出在服务器端,它实际上返回了带有字母“u”和反斜杠的字符串。试图在JS消费者端解决这个问题可能会很脆弱(特别是使用可怕的eval)。最好在源头解决这个问题。 - bobince
我已经解决了 API 服务器的问题。你可以查看下面的回答并告诉我是否需要改进。 - asissuthar
1个回答

4

理解javascript内部工作后,我找到了解决方案。

只有当Unicode字符串在引号之间硬编码时,javascript才会解释Unicode。

因此,我使用eval函数并创建了下面的代码片段来运行时解释Unicode数据。

function interpret(s) {
    return eval("(function(){ return '" + s + "'})()");
}  

$.getJSON(api, function(data) {
    $("#txtResponse").html( interpret( data.schedule.friday[0].tag ) );
});

找到另一个解决方案

在服务器端,只需在打印响应之前添加 str_replace 函数,将json中的 \\ 替换为 \

$response = json_encode($result);

echo str_replace( '\\\\' , '\\' , $response);

在客户端

$.getJSON(api, function(data) {
    $("#txtResponse").html( data.schedule.friday[0].tag );
});

eval("(function(){ return '" + s + "'})()").... 感谢 @asissithar,你救了我的一天。我给你点赞。 - Ananthaselvam P

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接