JS如何定義用字符串拼接的變量
今天在寫js的時(shí)候碰到了難題,我又一個(gè)頁面需要生成很多的變量。但是變量的名稱是根據(jù)參數(shù)的不同而區(qū)分的。
例如可能需要生成 date_1,date_2,datet_3... (后面的數(shù)字是根據(jù)參數(shù)來的)。 所以我的函數(shù)名 應(yīng)該由 var name = 'test_'+num; 生成函數(shù)名 但這問題就來了。
1可以使用 window[name] = ' ' 這種方式來定義變量:
所以 var 'test_'+num = 100; 這中肯定是錯(cuò)誤的。后來問了大哥后才知道。可以使用 window[name] = 100 這種方式來定義變量。看代碼
function create_variable(num){ var name = 'test_'+num; //生成函數(shù)名 window[name] = 100; window[’name’] = 200; //注意看中括號(hào)里的內(nèi)容加引號(hào)和不加引號(hào)的區(qū)別 } create_variable(2); alert(test_2); // 100; alert(name); //200;
總結(jié) window用中括號(hào)的方式定義 變量時(shí),中括號(hào)里的內(nèi)容應(yīng)該是字符串。如果是一個(gè)變量的話,他就會(huì)解析這個(gè)變量找到具體的值。
他和點(diǎn)語法區(qū)別就是這里,點(diǎn)語法后面跟的內(nèi)容就是要定義的變量名。而不會(huì)在解析他是否為變量之類的。例如
var name = 'test' window.name = 200 alert(name); // 200 alert(test); ReferenceError: test is not defined
2用對(duì)象的形式
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 definedconsole.log(test[’test_0’]); //輸出:我是字符串0
3用數(shù)組的形式
var test = []; for(var i = 0; i < 3; i++){ test[i]=’我是字符串’+i; console.log(test[i]); //輸出:我是字符串0, 我是字符串1, 我是字符串2 }console.log(test[0]); //輸出:我是字符串0
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 無線標(biāo)記語言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁2. PHP8.0新功能之Match表達(dá)式的使用3. Android實(shí)現(xiàn)觸發(fā)html頁面的Button控件點(diǎn)擊事件方式4. JavaScript設(shè)計(jì)模式之策略模式實(shí)現(xiàn)原理詳解5. Nginx+php配置文件及原理解析6. 解決Python 進(jìn)程池Pool中一些坑7. ajax請(qǐng)求添加自定義header參數(shù)代碼8. php網(wǎng)絡(luò)安全中命令執(zhí)行漏洞的產(chǎn)生及本質(zhì)探究9. 八種Vue組件間通訊方式合集(推薦)10. JavaScript基于用戶照片姓名生成海報(bào)
