Diskuze: JSON promenné i v jiných fukncích
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 10 zpráv z 10.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Natiahnutý json proste ulož do premennej v nadradenom mennom priestore:
var uri = `json/${lang}.json?${new Date().getTime()}`;
var dict = {};
$.getJSON(uri, function(data) {
dict = data
});
$('#main').append('<div id="tab_header" class="header">' + dict.alarm.name + '</div>');
$('#main').append('<a href="#" onclick="new_alarm()"><img name="add_user" src="./icons/add_alarm.png"></a>');
Ahoj,
stále mi to nechodí, ale uvědomil jsem si, že to stejně musím udělat
pro celý systém, je to nastavení jazyka. Proto jsem k tomu přistoupil
takto:
do header.html jsem dal :
<script src="./json/lang.js"></script>
ten obashuje:
var lang = {"en":
{"alarm":{"name":"Alarms","navigation":"Navigation","environment":"Environment","propulsion":"Propulsion","electrical":"Electrical","notifications":"Notifications","steering":"Steering","tanks":"Tanks","sensors":"Sensors"}}}
pokud přímo v lang.js dopíšu
alert(lang.en.alarm.name);
vše chodí jak má, ale pokud to napíšu do nějakého dalšího scriptu, bohužel není proměnný lang dostupná. Zkoušel jsem změnit na "var lang = " i " lang = ", ale nic.
Nevíte náhodou někdo co s tím?
Díky a zatím.
???
--- soubor1.html ---
<script src="lang.js"></script>
<script>alert(lang.en.alarm.name);</script> // Alarms
--- soubor2.html ---
<script src="lang.js"></script>
<script src="x.js"></script>
--- x.js ---
alert(lang.en.alarm.name); // Alarms
--- lang.js ---
var lang = {"en": {"alarm":{"name":"Alarms","navigation":"Navigation","environment":"Environment","propulsion":"Propulsion","electrical":"Electrical","notifications":"Notifications","steering":"Steering","tanks":"Tanks","sensors":"Sensors"}}}
jo díky, ale ted mi to chodí tak na půl, když mám v x.js
alert(lang.en.alarm.name); // Alarms
je to OK, ale, když v x.js mám
function alarms(){
alert(lang.en.alarm.name); // Alarms
}
tak tu proměnnou tam nemám ....
Tak už mi to funguje, je to trochu kostrbaté, ale chodí to, x.js musí vypadat takto:
function alarms(){
jaz = $('input[name=lang]').val(); //nastavi jazyk podle input
obj={}
obj=lang[jaz]
alert(obj.alarm.name)
???
--- x.js ---
//alert(lang.en.alarm.name);
function alarms(){
alert(lang.en.alarm.name); // Alarms
}
alarms(); // Alarms
Stale mi to funguje. Takze opravdu nechapu, kde delas chybu.
A mimochodem, tvuj predchozi kod nebosahuje var. Takze, vsechny promene se
stavaji globalnimi. Coz ti muze delat problemy v jine casti programu.
A nemas tak ukoncovaci zavorku funkce.
function alarms(){
var jaz, obj;
jaz = $('input[name=lang]').val(); //nastavi jazyk podle input
obj={}
obj=lang[jaz]
alert(obj.alarm.name)
// nebo
// var jaz = $('input[name=lang]').val(); //nastavi jazyk podle input
// var obj={}
} // ukoncovaci zavorka
Moc díky, už to chodí ... měl jsi pravdu, nebyl tam var a udělalo mi to bordel někde jinde.
Zobrazeno 10 zpráv z 10.