js中的異步獲取到的數(shù)據(jù)到底能不能賦值給一個(gè)全局變量問題
js異步獲取到的數(shù)據(jù)到底能不能賦值給一個(gè)全局變量
結(jié)論:能!
今天在做微信小程序中,需要將通過接口請(qǐng)求到的數(shù)據(jù)儲(chǔ)存到為一個(gè)當(dāng)前區(qū)域的全局變量,因?yàn)檎?qǐng)求是異步的,所以打印很多undefined 或者初始值;
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script> </head> <body> <div>萬物皆有自己的軌道,遷躍需要能量</div> <script> var goodsInfo = {}; $(document).ready(function(){ $.ajax({url:"https://api-hmugo-web.itheima.net/api/public/v1/home/catitems",success:function(result){ goodsInfo = result; console.log(goodsInfo); }}); console.log(goodsInfo); var time = 40; setTimeout(()=>{console.log(goodsInfo);},time); }); </script> </body> </html>
在設(shè)置延時(shí)時(shí)間為40ms時(shí),我用瀏覽器刷新,有時(shí)候有數(shù)據(jù),有時(shí)候沒有數(shù)據(jù)
沒數(shù)據(jù)打印情況
有數(shù)據(jù)打印情況
這種方式當(dāng)然有一些弊端,如果數(shù)據(jù)不是取出來立馬就要用,可以用,當(dāng)然還有更好的異步處理方法。
原生js設(shè)置并獲取全局變量
原生JS設(shè)置并獲取全局變量,干貨版。
一共有且只有以下五種方式
1.通過window對(duì)象設(shè)置和獲取全局變量
通過window對(duì)象設(shè)置和獲取全局變量。window對(duì)象是所有全局變量的擁有者,它是JavaScript的最頂層對(duì)象。我們可以通過window對(duì)象來設(shè)置和獲取全局變量。
例如:
// 設(shè)置全局變量 window.myGlobalVariable = "Hello World!"; // 獲取全局變量 alert(window.myGlobalVariable); // 輸出 "Hello World!"
2.使用ES6新增的let命令聲明全局變量
let命令聲明的全局變量是全局對(duì)象的屬性,它會(huì)變成全局對(duì)象的屬性,可以在任何地方被訪問到,而且不會(huì)因?yàn)楹瘮?shù)作用域或塊級(jí)作用域而改變。
例如:
// 使用let聲明全局變量 let myGlobalVariable = "Hello World!"; // 獲取全局變量 alert(window.myGlobalVariable); // 輸出 "Hello World!"
3.使用ES6新增的const命令聲明全局變量
const命令聲明的全局變量同樣是全局對(duì)象的屬性,它會(huì)變成全局對(duì)象的屬性,可以在任何地方被訪問到,而且不會(huì)因?yàn)楹瘮?shù)作用域或塊級(jí)作用域而改變。
此外,使用const聲明的全局變量一旦被聲明,在全局范圍內(nèi)都是不可變的,不能再次被重新賦值。
例如:
// 使用const聲明全局變量 const myGlobalVariable = "Hello World!"; // 獲取全局變量 alert(window.myGlobalVariable); // 輸出 "Hello World!"
4.使用Object對(duì)象設(shè)置和獲取全局變量
Object對(duì)象是JavaScript中的一個(gè)內(nèi)置對(duì)象,它可以用來訪問全局變量。我們可以在Object對(duì)象上新增一個(gè)屬性,然后通過該屬性就可以訪問到該變量。
例如:
// 使用Object對(duì)象設(shè)置全局變量 Object.myGlobalVariable = "Hello World!"; // 獲取全局變量 alert(window.myGlobalVariable); // 輸出 "Hello World!"
5.使用Function構(gòu)造函數(shù)設(shè)置和獲取全局變量
Function構(gòu)造函數(shù)是JavaScript中的一個(gè)內(nèi)置函數(shù),它可以用來創(chuàng)建新的函數(shù),也可以用來訪問全局變量。
我們可以使用Function構(gòu)造函數(shù)創(chuàng)建一個(gè)函數(shù),然后將全局變量作為該函數(shù)的參數(shù)傳遞進(jìn)來,就可以訪問到該變量。
例如:
// 使用Function構(gòu)造函數(shù)設(shè)置全局變量 var myGlobalVariable = "Hello World!"; var getGlobalVariable = new Function("return myGlobalVariable;"); // 獲取全局變量 alert(getGlobalVariable()); // 輸出 "Hello World!"
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于promise和async用法以及區(qū)別詳解
Promise是一個(gè)構(gòu)造函數(shù),我們就可以new Promise()得到一個(gè) Promise的實(shí)例,下面這篇文章主要給大家介紹了關(guān)于promise和async用法以及區(qū)別的相關(guān)資料,需要的朋友可以參考下2023-01-01使用原生的javascript來實(shí)現(xiàn)輪播圖
這篇文章主要介紹了使用原生的javascript來實(shí)現(xiàn)輪播圖,在代碼底部給大家補(bǔ)充了原生javascript實(shí)現(xiàn)banner圖自動(dòng)輪播切換 ,需要的朋友可以參考下2017-02-02JS封裝cookie操作函數(shù)實(shí)例(設(shè)置、讀取、刪除)
這篇文章主要介紹了JS封裝cookie操作函數(shù),以實(shí)例形式分析了JavaScript實(shí)現(xiàn)針對(duì)cookie的設(shè)置、獲取及刪除相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11身份證號(hào)碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載
身份證號(hào)碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載...2007-04-04基于Three.js實(shí)現(xiàn)360度全景圖片
這篇文章主要為大家詳細(xì)介紹了基于Three.js實(shí)現(xiàn)360度全景圖片,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12