<!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": []
}
}
第一种情况
存储在tag_value
变量
在txtDisplay部分使用$("#txtDisplay").html(tag_value);
进行显示。
正常工作
但
时第二种情况 从api中检索标记值(值与上面相同)
在txtResponse部分使用$("#txtResponse").html(data.schedule.friday[0].tag);
显示。
无法显示表情符号。它是显示文字。
答案 0 :(得分:2)
在了解了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 );
});