首頁  >  文章  >  web前端  >  JS 定義用字串拼接的變數的解析

JS 定義用字串拼接的變數的解析

coldplay.xixi
coldplay.xixi轉載
2020-07-14 17:38:173928瀏覽

JS 定義用字串拼接的變數的解析

今天在寫js的時候碰到了一個難題,我又一個頁面需要產生很多的變數。但是變數的名稱是根據參數的不同而區分的。

例如可能需要產生 date_1,date_2,datet_3... (後面的數字是根據參數來的)。所以我的函數名稱 應該由 var name = "test_" num; 產生函數名稱 但這問題就來了。

相關學習推薦:javascript影片教學

#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[&#39;test_&#39;+i]=&#39;我是字符串&#39;+i;
 
    console.log(test[&#39;test_&#39;+i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
  }
console.log(test_0); //输出:ReferenceError: test_0 is not defined
console.log(test[&#39;test_0&#39;]); //输出:我是字符串0

#3用陣列的形式

var test = [];
  for(var i = 0; i < 3; i++){
    test[i]=&#39;我是字符串&#39;+i;
    console.log(test[i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
  }
console.log(test[0]); //输出:我是字符串0

以上是JS 定義用字串拼接的變數的解析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除