JS如何定義用字串拼接的變數
阿新 • • 發佈:2020-07-14
今天在寫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,我是字串2 } console.log(test[0]); //輸出:我是字串0
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。