javascript - 如何用我当前的代码切换标志?

标签 javascript html css

我目前正在使用以下代码作为我的语言标志

<a href="#" onclick="change_lang()"><i class="flag-icon flag-icon-gb></i></a>

我的Javascript是

var dictionary = {
    'greet': {
        'it': 'Ciao',
        'en': 'Hello',
        'fr': 'Salut',
    }
};
var langs = ['it', 'en', 'fr'];
var current_lang_index = 0;
var current_lang = langs[current_lang_index];

window.change_lang = function() {
current_lang_index = ++current_lang_index % 3;
current_lang = langs[current_lang_index];
translate();
}

function translate() {
$("[data-translate]").each(function(){
    var key = $(this).data('translate');
    $(this).html(dictionary[key][current_lang] || "N/A");
});
}

translate();

可在 https://jsfiddle.net/x93oLad8/4/ 上找到

如何使用相同的 javascript 将 flag-icon-gb 更改为 flag-icon-cn?

最佳答案

好的,我的第一个答案还差得远,但我看到你已经更新了你的 fiddle ,所以我有更多的背景信息

我已将 div 添加到您的 HTML 中,每当切换语言时,语言值也会作为类添加到 div。然后使用 CSS 添加一个背景图片,上面有所有标志,并且根据当前添加到元素的类(基于 current_lang)定位不同(显示不同的标志)

不用担心 fiddle 中的巨大数据 URI,我没有背景图片可以使用,我制作了一张并将其转换为数据 URI - 你可以使用实际图片(如果你愿意)或者坚持使用数据 URI

所以我在 HTML 中添加了:

<div id="langflag"></div>

您可以将 ID(或将其更改为类)添加到任何内容并在其上放置背景图片 - 只需确保添加一些填充,以便有一些背景空间不会被覆盖。

然后我在您的 js 中添加了一行以更改 div 上的类:

function translate() {
    $("[data-translate]").each(function(){
        var key = $(this).data('translate');
        $(this).html(dictionary[key][current_lang] || "N/A");
        $("#langflag").attr('class', current_lang); // this is new
    });
}

然后添加了添加背景图片并根据类更改位置的样式:

#langflag {
  height: 20px;
  width: 32px;
  border: 1px solid #cccccc;
  background-color: white;
  background-repeat: no-repeat;
  background-image: url("yourpic.png");
}
#langflag.it { background-position: 0 0; }
#langflag.en { background-position: -32px 0; }
#langflag.fr { background-position: -64px 0; }

您可以使用数据 uri 作为图片 - 丑陋但高效!:

background-image: url("");

请看这里的 fiddle : https://jsfiddle.net/ppppz1gL/

您还可以添加实际图像并更新脚本中的 src 属性,但单个背景图像(一个 http 请求),尤其是数据 URI(无 http 请求)效率更高(尽管有大量文本事情的计划非常简单(图像可能是大多数人可以减少其网站大小的方式 - 虽然很容易不打扰 - 我很内疚!))

希望对你有帮助

关于javascript - 如何用我当前的代码切换标志?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46417295/

相关文章:

javascript - outerWidth(true) 连续两次返回不同的值,无需重新加载页面

javascript - JS/CSS Accordion 滑动过渡问题

javascript - 服务器 API 说它已插入数据库,但事实并非如此

javascript - 使用钛金属半径网络进行信标检测

html - 允许行内 block 元素在堆叠之前换行

javascript - 当您调整窗口大小时图表自动缩放(使用谷歌网络应用程序制作)

javascript - jquery - ajax 加载内容上的日期选择器(颜色选择器等)

html - Shiny 中相同值的两个输入

CSS a.className :attr properties

css - 手写笔选择器内部的过滤