欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決javascript 全局變量失效的問題

 更新時(shí)間:2021年01月25日 12:10:15   作者:白夜  
這篇文章主要介紹了解決javascript 全局變量失效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

問題:

我在js文件中定義了一個(gè)全局變量:var a,在函數(shù)B()中給a賦值,然后在函數(shù)C()中訪問a結(jié)果發(fā)現(xiàn)a居然是undefined

找原因:

查了不少資料感覺和我的情況都不同,仔細(xì)分析了一下,發(fā)現(xiàn)了一些端倪:我的操作是這樣的,我在A頁面中加了iframe,iframe的地址是B,我在A頁面中調(diào)用了B()函數(shù),然后又在B頁面中調(diào)用了C()函數(shù)。問題就出在這了,javascript的全局變量的作用范圍實(shí)際上是只在當(dāng)前頁面起作用(仔細(xì)想一下也應(yīng)是這樣,要不然豈不是要亂套了),從這個(gè)意義上講javascript的全局變量也談不上是全局變量,它只在當(dāng)前頁面中起作用,我們要是把當(dāng)前頁面看做一個(gè)類的話,那我們就完全可以把這中全局變量看做為private的。

至此,問題原因就很簡單了,我在A頁面中訪問的a變量和我在B頁面中訪問的a變量中訪問的a變來那個(gè)并不是同一個(gè)變量,就好像是一個(gè)類里面的private變量,我在A實(shí)例中訪問的和我在B實(shí)例中訪問的并不是同一個(gè)變量是同樣的道理。

解決:

原因找的了,問題也就好解決了,首先我是在A頁面中調(diào)用的B()函數(shù),我只要在A頁面中調(diào)用C()函數(shù),那么A、B函數(shù)訪問的變量就是同一變量了,那我怎么才能在A頁面中調(diào)用B()函數(shù)呢,我要把B頁面當(dāng)中返回值作為參數(shù)傳入B函數(shù)啊,呵呵,其實(shí)方法很簡單了啊,只要這樣就可以了:我在B頁面中寫了這么一句:window.parent.C(str)。

str為我要返回的值,好了我的問題就這么解決了,就好像是我在B實(shí)例中調(diào)用A實(shí)例的方法,然后傳遞參數(shù)一樣,呵呵其實(shí)在C#真的很好理解,但在js中就難了點(diǎn),其實(shí)我們可以這么理解,一個(gè)js文件就相當(dāng)于一個(gè)類,我們在頁面中引用這個(gè)文件時(shí)就相當(dāng)于實(shí)例化了這個(gè)類,那么一切都好理解了。

我們寫在js文件函數(shù)中的變量當(dāng)然作用域就是這個(gè)函數(shù),那我們寫在js文件中的變量就相當(dāng)于我們寫在類中的變量,那么它的作用域就是這個(gè)類的實(shí)例。

補(bǔ)充:JavaScript中的坑--全局變量惹得禍

概述

身為一名程序員,因?yàn)閎ug周末加班是必不可少的事情,當(dāng)解決bug的時(shí)候,總有些bug是因?yàn)橐?guī)范導(dǎo)致的,但是這些bug往往不好找,也就是“前人挖坑,后人好踩”。前段時(shí)間,出現(xiàn)了一個(gè)很莫名其妙的bug

就是有個(gè)模塊頁面數(shù)據(jù)不對(duì)。當(dāng)時(shí)找了半天(以為是頁面?zhèn)髦档膯栴}),到最后才發(fā)現(xiàn) 主頁面引用的幾個(gè)js文件中存在一個(gè)相同的全局變量。

對(duì)js中的變量作用域的誤解

很多寫js的都是需要前后臺(tái)一起寫的,我就是后臺(tái)java,前臺(tái)js分模塊一起寫的。在這里,我有一個(gè)誤區(qū),就是以為js和java中的語法是一樣的。但實(shí)際上還是存在著一些不同的地方。比如js中作用域只是函數(shù)級(jí)別的

1:在{}體內(nèi)定義的局部變量,和在{}體外定義的局部變量 實(shí)際上是一個(gè),并不會(huì)新建

2:在函數(shù)體內(nèi)定義的局部變量 ,和函數(shù)體外定義的沒什么關(guān)系。

方便記憶的代碼如下:

 <script>
  var test_id = "my love";
  if(true){
   console.log(test_id);
   var test_id = "where my love?";
   console.log(test_id);
  }
  console.log(test_id);
  </script>

顯示結(jié)果:

這就是js中沒有塊級(jí)作用域的證明: 很顯然發(fā)現(xiàn)test_id實(shí)際上只有一個(gè)

證明js中變量是函數(shù)級(jí)別的

 <script>
  var test_id = "my love";
  function findLove(){
   var test_id ;
   console.log(test_id);
   test_id = "is you?";
   console.log(test_id);
  }
  findLove();
  console.log(test_id);
  </script>

輸出結(jié)果:

然后我試了一下: 在{}體內(nèi)不用var聲明:

<script>
  
 var a = "heh"
  if(true){
   console.log(a);
  }
  </script>

其實(shí)也是可以的 輸出 heh

試一下 函數(shù)體內(nèi)部用var ,注意一下:代碼不同之處

<script>
  var a = "heh"
  function findLove(){
   console.log(a);
  }
  findLove();
  </script>
<script>
  var a = "heh"
  function findLove(){
   console.log(a);
   var a
  }
  findLove();
  </script>

第一個(gè)輸出的是 heh ;第二個(gè)輸出的是 undifined,一目了然。這個(gè)地方 還有一個(gè)細(xì)節(jié):就是在函數(shù)體內(nèi),先定義后打印和先打印和定義,實(shí)際上是一樣。

自我測試一下吧:(猜一下輸出結(jié)果,在驗(yàn)證一下吧)

 <script>
  var a = "heh"
  function findLove(){
   console.log(a);
   function findforyou(){
   var a ="you";
   console.log(a);
   }
   function findother(){
   console.log(a)
   }
   findforyou();
   findother();
  }
  findLove();
  </script>

二:函數(shù)閉包

因?yàn)閖s中變量的作用域是函數(shù)級(jí)的,所以用閉包來解決一些傳值問題(比如遞歸)。篇幅太長了,這次不介紹了。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Nuxt v-bind綁定img src不顯示的解決

    Nuxt v-bind綁定img src不顯示的解決

    這篇文章主要介紹了Nuxt v-bind綁定img src不顯示的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Javascript連接多個(gè)數(shù)組不用concat來解決

    Javascript連接多個(gè)數(shù)組不用concat來解決

    這篇文章主要介紹了不用concat解決Javascript連接多個(gè)數(shù)組,需要的朋友可以參考下
    2014-03-03
  • ES6 class的應(yīng)用實(shí)例分析

    ES6 class的應(yīng)用實(shí)例分析

    這篇文章主要介紹了ES6 class的應(yīng)用,結(jié)合實(shí)例形式分析了class在ES6面向?qū)ο蟪绦蛟O(shè)計(jì)中定義類的相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • js中刪除數(shù)組中的某一元素實(shí)例(無下標(biāo)時(shí))

    js中刪除數(shù)組中的某一元素實(shí)例(無下標(biāo)時(shí))

    下面小編就為大家?guī)硪黄猨s中刪除數(shù)組中的某一元素實(shí)例(無下標(biāo)時(shí))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02
  • 淺談前端JS沙箱實(shí)現(xiàn)的幾種方式

    淺談前端JS沙箱實(shí)現(xiàn)的幾種方式

    在微前端領(lǐng)域當(dāng)中,沙箱是很重要的一件事情。本文就淺談前端JS沙箱實(shí)現(xiàn)的幾種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • JavaScript 中級(jí)筆記 第二章

    JavaScript 中級(jí)筆記 第二章

    對(duì)象是組成JavaScript的基本單元。本章將從JavaScript語言中最重要的幾個(gè)部分開始介紹:引用,函數(shù)重載,作用域,閉包和上下文。有了這些知識(shí)后,面向?qū)ο箝_發(fā)就將變得簡單。
    2009-09-09
  • 關(guān)于微信小程序map組件z-index的層級(jí)問題分析

    關(guān)于微信小程序map組件z-index的層級(jí)問題分析

    這篇文章主要給大家介紹了關(guān)于微信小程序map組件z-index的層級(jí)問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用微信小程序具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • JS高級(jí)調(diào)試技巧:捕獲和分析 JavaScript Error詳解

    JS高級(jí)調(diào)試技巧:捕獲和分析 JavaScript Error詳解

    前端工程師都知道 JavaScript 有基本的異常處理能力。我們可以 throw new Error(),瀏覽器也會(huì)在我們調(diào)用 API 出錯(cuò)時(shí)拋出異常。但估計(jì)絕大多數(shù)前端工程師都沒考慮過收集這些異常信息
    2014-03-03
  • Bootstrap標(biāo)簽頁(Tab)插件使用方法

    Bootstrap標(biāo)簽頁(Tab)插件使用方法

    這篇文章主要為大家詳細(xì)介紹了Bootstrap標(biāo)簽頁(Tab)插件的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • TypeScript中類型映射的使用

    TypeScript中類型映射的使用

    TypeScript中的映射類型和數(shù)學(xué)中的映射類似,能夠?qū)⒁粋€(gè)集合的元素轉(zhuǎn)換為新集合的元素,本文就來介紹一下TypeScript中類型映射的使用,感興趣的可以了解一下
    2023-10-10

最新評(píng)論