您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關如何使用JS 定義用字符串拼接的變量,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
今天在寫js的時候碰到了難題,我又一個頁面需要生成很多的變量。但是變量的名稱是根據參數的不同而區分的。
例如可能需要生成 date_1,date_2,datet_3...
(后面的數字是根據參數來的)。 所以我的函數名 應該由 var name = "test_"+num;
生成函數名 但這問題就來了。
1可以使用 window[name] = " " 這種方式來定義變量:
所以 var "test_"+num = 100; 這中肯定是錯誤的。后來問了大哥后才知道。可以使用 window[name] = 100 這種方式來定義變量。看代碼
function create_variable(num){ var name = "test_"+num; //生成函數名 window[name] = 100; window['name'] = 200; //注意看中括號里的內容加引號和不加引號的區別 } create_variable(2); alert(test_2); // 100; alert(name); //200;
總結
window用中括號的方式定義 變量時,中括號里的內容應該是字符串。如果是一個變量的話,他就會解析這個變量找到具體的值。
他和點語法區別就是這里,點語法后面跟的內容就是要定義的變量名。而不會在解析他是否為變量之類的。例如
var name = "test" window.name = 200 alert(name); // 200 alert(test); ReferenceError: test is not defined
2用對象的形式
var test = {}; for(var i = 0; i < 3; i++){ test['test_'+i]='我是字符串'+i; console.log(test['test_'+i]); //輸出:我是字符串0, 我是字符串1, 我是字符串2 } console.log(test_0); //輸出:ReferenceError: test_0 is not defined console.log(test['test_0']); //輸出:我是字符串0
3用數組的形式
var test = []; for(var i = 0; i < 3; i++){ test[i]='我是字符串'+i; console.log(test[i]); //輸出:我是字符串0, 我是字符串1, 我是字符串2 } console.log(test[0]); //輸出:我是字符串0
上述就是小編為大家分享的如何使用JS 定義用字符串拼接的變量了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。