javascript - 如何使用javascript访问对象数组
问题描述
console.log (dict) 会给你
{"点击这里:":{"message":"点击这里"},"apply":{"message":"应用"},"翻译测试!":{"message":"js 翻译示例!" },"tabLanding":"欢迎","tabSetup":{"message":"安装"}}
我希望 tabSetup 在 html 中显示为安装,这里是 html 代码:
<li class="tab_setup"><a href="#" i18n="tabSetup"></a></li>
我看到的是它没有正确显示只是显示为 [object Object] 它应该显示为安装
这是我的java脚本。谢谢
var dict = {};
var systemLang = navigator.language.toLowerCase().slice(0,2);
$(function () {
registerWords();
switch(getCookieVal("lang")) {
case "en" :
setLanguage("en");
break
case "zh" :
setLanguage("zh");
break
default:
setLanguage(systemLang);
}
console.log (dict);
console.log(JSON.stringify(dict));
// 切换语言事件
$("#enBtn").bind("click", function () {
setLanguage("en");
});
$("#zhBtn").bind("click", function () {
setLanguage("zh");
});
// $("#applyBtn").bind("click", function () {
// alert(__tr("a translation test!"));
// });
});
function setLanguage(lang) {
setCookie("lang=" + lang + "; path=/;");
translate(lang);
}
function getCookieVal(name) {
var items = document.cookie.split(";");
for (var i in items) {
var cookie = $.trim(items[i]);
var eqIdx = cookie.indexOf("=");
var key = cookie.substring(0, eqIdx);
if (name == $.trim(key)) {
return $.trim(cookie.substring(eqIdx + 1));
}
}
return null;
}
function setCookie(cookie) {
var Days = 30; //此 cookie 将被保存 30 天
var exp = new Date(); //new Date("December 31, 9998");
exp.setTime(exp.getTime() + Days * 24 * 60 * 60 * 1000);
document.cookie = cookie+ ";expires=" + exp.toGMTString();
}
function translate(lang) {
if(sessionStorage.getItem(lang + "Data") != null){
dict = JSON.parse(sessionStorage.getItem(lang + "Data"));
}else{
loadDict();
}
$("[i18n]").each(function () {
switch (this.tagName.toLowerCase()) {
case "input":
$(this).val(__tr($(this).attr("i18n")));
break;
default:
$(this).text(__tr($(this).attr("i18n")));
}
});
}
function __tr(src) {
return (dict[src] || src);
}
function loadDict() {
var lang = (getCookieVal("lang") || "en");
$.ajax({
async: false,
type: "GET",
url: "/lang/"+lang + ".json",
success: function (msg) {
dict = msg;
sessionStorage.setItem(lang + 'Data', JSON.stringify(dict));
}
});
}
// 遍历所有lang属性的标签赋值
function registerWords() {
$('[i18n]:not(.i18n-replaced').each(function() {
var element = $(this);
element.html(translate(element.attr('i18n')));
element.addClass('i18n-replaced');
});
}
如果像“tabSetup”:“设置”这样的json文件,它可以工作。.如果像“tabSetup”这样的json文件不起作用:{“消息”:“设置”}
解决方案
函数__tr有错误,这样修复
function __tr(src) {
return (dict[src].message || src);
}
推荐阅读
- pdf - 如何在保持格式的同时使用 borb 和 Translate API 翻译 PDF?
- node.js - nodejs 从克隆的 git 存储库中获取目录中的最新文件
- c++ - 如何使用 cin>> 模拟 scanf("%*c) 和 scanf(":") 行为
- android - 如何在列表颤动中构建搜索栏?
- list - 从嵌套列表中检索信息 (Flutter)
- c# - UWP:Int 参数在 RelayCommand 上失败
- android - 如何在 kotlin 的 Recycler View Adapter 中添加更多数据列表而不清除先前的数据?
- php - 在 tcppdf 中需要帮助,在数组中格式化图像
- java - 迭代对象列表并获得平均值
- javascript - 由 AJAX 插入创建时 HTML 代码不起作用