亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js中的異步獲取到的數(shù)據(jù)到底能不能賦值給一個(gè)全局變量問(wèn)題

 更新時(shí)間:2023年04月24日 10:02:44   作者:321茄子  
這篇文章主要介紹了js中的異步獲取到的數(shù)據(jù)到底能不能賦值給一個(gè)全局變量問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

js異步獲取到的數(shù)據(jù)到底能不能賦值給一個(gè)全局變量

結(jié)論:能! 

今天在做微信小程序中,需要將通過(guò)接口請(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>萬(wàn)物皆有自己的軌道,遷躍需要能量</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ù)不是取出來(lái)立馬就要用,可以用,當(dāng)然還有更好的異步處理方法。

原生js設(shè)置并獲取全局變量

原生JS設(shè)置并獲取全局變量,干貨版。

一共有且只有以下五種方式

1.通過(guò)window對(duì)象設(shè)置和獲取全局變量

通過(guò)window對(duì)象設(shè)置和獲取全局變量。window對(duì)象是所有全局變量的擁有者,它是JavaScript的最頂層對(duì)象。我們可以通過(guò)window對(duì)象來(lái)設(shè)置和獲取全局變量。

例如:

// 設(shè)置全局變量
window.myGlobalVariable = "Hello World!";

// 獲取全局變量
alert(window.myGlobalVariable); // 輸出 "Hello World!"

2.使用ES6新增的let命令聲明全局變量

let命令聲明的全局變量是全局對(duì)象的屬性,它會(huì)變成全局對(duì)象的屬性,可以在任何地方被訪問(wèn)到,而且不會(huì)因?yàn)楹瘮?shù)作用域或塊級(jí)作用域而改變。

例如:

// 使用let聲明全局變量
let myGlobalVariable = "Hello World!";

// 獲取全局變量
alert(window.myGlobalVariable); // 輸出 "Hello World!"

3.使用ES6新增的const命令聲明全局變量

const命令聲明的全局變量同樣是全局對(duì)象的屬性,它會(huì)變成全局對(duì)象的屬性,可以在任何地方被訪問(wèn)到,而且不會(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ì)象,它可以用來(lái)訪問(wèn)全局變量。我們可以在Object對(duì)象上新增一個(gè)屬性,然后通過(guò)該屬性就可以訪問(wèn)到該變量。

例如:

// 使用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ù),它可以用來(lái)創(chuàng)建新的函數(shù),也可以用來(lái)訪問(wèn)全局變量。

我們可以使用Function構(gòu)造函數(shù)創(chuàng)建一個(gè)函數(shù),然后將全局變量作為該函數(shù)的參數(shù)傳遞進(jìn)來(lái),就可以訪問(wè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)文章

  • 使用layui定義一個(gè)模塊并使用的例子

    使用layui定義一個(gè)模塊并使用的例子

    今天小編就為大家分享一篇使用layui定義一個(gè)模塊并使用的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • 固定表格行列(expression)在IE下適用

    固定表格行列(expression)在IE下適用

    本文為大家介紹下使用expression固定表格行列,這是一種在IE下適用的固定行列的方法,感興趣的朋友可以學(xué)習(xí)下,希望對(duì)大家有所幫助
    2013-07-07
  • 關(guān)于promise和async用法以及區(qū)別詳解

    關(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
  • webpack模塊化的原理解析

    webpack模塊化的原理解析

    webpack 中實(shí)現(xiàn)模塊化的核心就是 __webpack_require__ 函數(shù),無(wú)論是commonjs模塊化還是es 模塊都是通過(guò)該函數(shù)來(lái)導(dǎo)入的,這篇文章主要介紹了webpack模塊化的原理,需要的朋友可以參考下
    2023-02-02
  • 使用原生的javascript來(lái)實(shí)現(xiàn)輪播圖

    使用原生的javascript來(lái)實(shí)現(xiàn)輪播圖

    這篇文章主要介紹了使用原生的javascript來(lái)實(shí)現(xiàn)輪播圖,在代碼底部給大家補(bǔ)充了原生javascript實(shí)現(xiàn)banner圖自動(dòng)輪播切換 ,需要的朋友可以參考下
    2017-02-02
  • JS封裝cookie操作函數(shù)實(shí)例(設(shè)置、讀取、刪除)

    JS封裝cookie操作函數(shù)實(shí)例(設(shè)置、讀取、刪除)

    這篇文章主要介紹了JS封裝cookie操作函數(shù),以實(shí)例形式分析了JavaScript實(shí)現(xiàn)針對(duì)cookie的設(shè)置、獲取及刪除相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-11-11
  • javascript中的作用域scope介紹

    javascript中的作用域scope介紹

    在一般程序設(shè)計(jì)語(yǔ)言中,作用域是按塊來(lái)劃分的。即“變量定義在哪個(gè)塊之內(nèi),這個(gè)塊就是變量的有效范圍”。
    2010-12-12
  • 身份證號(hào)碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載

    身份證號(hào)碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載

    身份證號(hào)碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載...
    2007-04-04
  • Bootstrap3制作圖片輪播效果

    Bootstrap3制作圖片輪播效果

    這篇文章主要教大家如何利用Bootstrap3制作圖片輪播效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-05-05
  • 基于Three.js實(shí)現(xiàn)360度全景圖片

    基于Three.js實(shí)現(xiàn)360度全景圖片

    這篇文章主要為大家詳細(xì)介紹了基于Three.js實(shí)現(xiàn)360度全景圖片,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12

最新評(píng)論