import提升導致Fundebug報錯怎么辦?這個問題可能是我們?nèi)粘W習或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
成都網(wǎng)站建設哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁設計、成都網(wǎng)站建設、微信開發(fā)、小程序開發(fā)、集團成都企業(yè)網(wǎng)站建設等服務項目。核心團隊均擁有互聯(lián)網(wǎng)行業(yè)多年經(jīng)驗,服務眾多知名企業(yè)客戶;涵蓋的客戶類型包括:水泥攪拌車等眾多領域,積累了大量豐富的經(jīng)驗,同時也獲得了客戶的一致稱譽!
摘要:解釋一下“請配置apikey”報錯的原因。
部分Fundebug用戶使用import來導入js文件時,出現(xiàn)了"請配置apikey"的報錯,這是由于import提升導致的,下面我會詳細解釋一下這一點。
關于import提升,我們可以參考阮一峰的《ECMAScript 6 入門》。
import命令具有提升效果,會提升到整個模塊的頭部,首先執(zhí)行。
foo(); import { foo } from 'my_module';
上面的代碼不會報錯,因為import的執(zhí)行早于foo的調(diào)用。這種行為的本質(zhì)是,import命令是編譯階段執(zhí)行的,在代碼運行之前。
因此,即使我們把import語句寫在后面,它仍然會在其他語句之前執(zhí)行。
Fundebug用戶應該清楚,在接入fundebug-javascript插件之后,需要配置apikey,如下:
import * as fundebug from "fundebug-javascript"; fundebug.apikey = "API-KEY";
假設我們還需要import一個test.js文件,這個文件會拋出一個Error,如下:
// test.js throw new Error("test")
一切看起來沒有問題:
// main.js import * as fundebug from "fundebug-javascript"; fundebug.apikey = "API-KEY"; import "./test"
但是,根據(jù)import提升,代碼的實際執(zhí)行順序如下:
// main.js import * as fundebug from "fundebug-javascript"; import "./test" fundebug.apikey = "API-KEY";
這種情況下,第二行代碼就會拋出錯誤,導致apikey復制語句不會執(zhí)行,從而導致報錯:“請配置apikey”。
出于測試的目的,用戶會去import一個立即報錯的js文件,類似于前文提到的test.js。但是實際開發(fā)中,我們不可能這樣做,否則應用會立即崩潰,更談不上部署了。
我們寫這篇博客的目的僅僅是解釋一下原因,并分享一個非常簡單的知識點“import提升”。
僅供參考,實際上沒有必要這樣做。
新建一個配置文件config.js,在這個文件中配置apikey:
fundebug.apikey = "API-KEY";
import配置文件:
// main.js import * as fundebug from "fundebug-javascript"; import "./config" import "./test"
這種情況下,配置apikey的語句被import代替了,也就不存在所謂"import提升"的問題,F(xiàn)undebug將可以正常報錯。
感謝各位的閱讀!看完上述內(nèi)容,你們對import提升導致Fundebug報錯怎么辦大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關文章內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。