如何使用当前代码切换标志?

时间:2017-09-26 03:16:49

标签: 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?

1 个答案:

答案 0 :(得分:1)

好的,我的第一个答案还没有结束,但我看到你已经更新了你的小提琴,所以我有更多的背景

我已将HTML添加到您的HTML中,每当语言切换时,语言值也会作为类添加到div中。然后使用CSS添加背景图像,其中包含所有标记,并且它的位置不同(显示不同的标记),具体取决于当前添加到元素的类(基于current_lang

不要担心小提琴中的巨大数据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("");

请看这里的小提琴: https://jsfiddle.net/ppppz1gL/

您还可以添加实际图像并更新脚本中的src属性,但单个背景图像(一个http请求),尤其是数据URI(无http请求)更有效(尽管有大量文本,在事物计划中相当轻松(图像可能是大多数人可以减少他们网站的大小 - 它很容易不打扰 - 我很有罪!)

我希望有帮助