<!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": []
  }
}

javascript - 无法显示Unicode JSON响应中的表情符号-LMLPHP

第一种情况

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

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

可以正常工作

但当

第二种情况
从api检索标签值(与上面相同的值)

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

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

最佳答案

了解javascript的内部工作后得到解决方案。

javascript仅在用引号之间的unicode字符串硬编码时才解释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 );
});

关于javascript - 无法显示Unicode JSON响应中的表情符号,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/39808225/

10-09 20:28
查看更多