新建的React Native就遇到vscode報(bào)警解除方法
新建的RN項(xiàng)目有警告
我相信AwesomeProject是很多人的第一個(gè)RN項(xiàng)目,包括我在內(nèi)。
npx react-native init AwesomeProject
但是當(dāng)利用RN的腳手架搭建起來(lái)后,在vscode里打開(kāi)項(xiàng)目,直接就會(huì)遇到如下這個(gè)vscode的警告:
'import type' declarations can only be used in TypeScript files. ts(8006)



這個(gè)vscode的警告不會(huì)影響程序的編譯和運(yùn)行,但是任何一個(gè)有代碼潔癖的程序員,肯定是無(wú)法忍受的。我就被它折磨過(guò)一段時(shí)間,我先后采用了兩種方式解決它。
直接刪除vscode報(bào)警的部分
在我剛接觸RN時(shí),為了集中精力關(guān)注主要矛盾,我當(dāng)時(shí)直接刪除了那些vscode報(bào)警的地方。因?yàn)槟莻€(gè)報(bào)警就是Flow的語(yǔ)法,而Flow只是靜態(tài)類(lèi)型檢查的一種方式,是為了補(bǔ)齊javascript沒(méi)有類(lèi)型這塊短板的,所以即使不使用它,而僅僅保留js的語(yǔ)法部分,也是不會(huì)影響運(yùn)行的。
// import type {Node} from 'react';
...
const Section = ({children, title}) /*: Node*/ => {
...
const App /*: () => Node*/ = () => {
...
這樣刪除或者注釋掉這些語(yǔ)法之后,vscdoe的報(bào)警就解除了。
禁掉vscode內(nèi)置的TypeScript插件
過(guò)了一段時(shí)間,我漸漸熟悉了React Native的一些東西,主要矛盾解決的差不多了,是時(shí)候回過(guò)頭來(lái)看看怎么處理它了。Flow的類(lèi)型定義和Typescript還是蠻相似的,很多地方的語(yǔ)法都一模一樣,也難怪vscode把它識(shí)別成了TypeScript。
因?yàn)槲夷J(rèn)生成RN項(xiàng)目時(shí),并不打算使用TypeScript,而是打算全套用FB的東西:RN配Flow。所以,第一步,就是針對(duì)我的workspace,關(guān)閉vscode的Typescript檢查。
廢話(huà)不多說(shuō),直接上圖:

在vscode中disable掉內(nèi)置的兩個(gè)TypeScript插件,注意要選擇僅僅是當(dāng)前worksapce下disable就好。
引入Flow Language Support解除報(bào)警
既然禁止了TypeSCript,那么就需要引入Flow的插件了,還是上圖:

該插件名字叫Flow Language Support,也是人氣超高的插件啊。
引入插件后,你會(huì)發(fā)現(xiàn),似乎這個(gè)插件并沒(méi)有工作。因?yàn)橐粋€(gè)插件的工作,其實(shí)有時(shí)候是需要node_modules里有讓這個(gè)插件使用的命令行工具才行。插件本身,只是為了契合vscdoe的一個(gè)殼,殼子里的內(nèi)容,是需要有對(duì)應(yīng)的包的支持的。
yarn add flow-bin flow-parser -D
安裝這兩個(gè)包為插件賦予真正的靈魂。關(guān)閉vscode,然后重新打開(kāi)。之所以這么做的目的是因?yàn)橛行┎寮枰匦聠?dòng)vscode才行,我的習(xí)慣就是每次安裝完插件,甭管是否有重啟的提示,都會(huì)主動(dòng)重啟。
很遺憾,這次又有了新的報(bào)錯(cuò):

根據(jù)提示,好像是因?yàn)椴寮蕾?lài)的flow版本是0.183.0,而.flowconfig中的版本是^0.182.0。這個(gè)錯(cuò)誤提醒了我們,要保證當(dāng)前項(xiàng)目中,各個(gè)地方使用的flow版本,都一致才行。知道插件用的是0.183.0,那么也要保證其余地方也是這個(gè)版本。
yarn add flow-bin@0.183.0 flow-parser@0.183.0 -D
于是我們重新安裝flow-bin和flow-parser,保證他倆的版本和插件依賴(lài)的版本一致。然后再把.flowconfig里的version改了。

重啟一下vscode,再次打開(kāi)后,F(xiàn)low插件就工作正常了。

我在安裝Flow插件的時(shí)候的版本提示是0.183.0,但是這個(gè)版本隨著時(shí)間的推移,必然會(huì)變化,記得隨機(jī)應(yīng)變哦。
以上就是新建的React Native就遇到vscode報(bào)警解除方法的詳細(xì)內(nèi)容,更多關(guān)于React Native解除vscode報(bào)警的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解React Native開(kāi)源時(shí)間日期選擇器組件(react-native-datetime)
本篇文章主要介紹了詳解React Native開(kāi)源時(shí)間日期選擇器組件(react-native-datetime),具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09
react-router?v6實(shí)現(xiàn)權(quán)限管理+自動(dòng)替換頁(yè)面標(biāo)題的案例
這篇文章主要介紹了react-router?v6實(shí)現(xiàn)權(quán)限管理+自動(dòng)替換頁(yè)面標(biāo)題,這次項(xiàng)目是有三種權(quán)限,分別是用戶(hù),商家以及管理員,這次寫(xiě)的權(quán)限管理是高級(jí)權(quán)限能訪(fǎng)問(wèn)低級(jí)權(quán)限的所有頁(yè)面,但是低級(jí)權(quán)限不能訪(fǎng)問(wèn)高級(jí)權(quán)限的頁(yè)面,需要的朋友可以參考下2023-05-05
antd+react中upload手動(dòng)上傳單限制上傳一張
本文主要介紹了antd+react中upload手動(dòng)上傳單限制上傳一張,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
react-native使用leanclound消息推送的方法
這篇文章主要介紹了react-native使用leanclound消息推送的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08

