新建的React Native就遇到vscode報警解除方法
新建的RN項目有警告
我相信AwesomeProject是很多人的第一個RN項目,包括我在內(nèi)。
npx react-native init AwesomeProject
但是當利用RN的腳手架搭建起來后,在vscode里打開項目,直接就會遇到如下這個vscode的警告:
'import type' declarations can only be used in TypeScript files. ts(8006)
這個vscode的警告不會影響程序的編譯和運行,但是任何一個有代碼潔癖的程序員,肯定是無法忍受的。我就被它折磨過一段時間,我先后采用了兩種方式解決它。
直接刪除vscode報警的部分
在我剛接觸RN時,為了集中精力關注主要矛盾,我當時直接刪除了那些vscode報警的地方。因為那個報警就是Flow的語法,而Flow只是靜態(tài)類型檢查的一種方式,是為了補齊javascript沒有類型這塊短板的,所以即使不使用它,而僅僅保留js的語法部分,也是不會影響運行的。
// import type {Node} from 'react'; ... const Section = ({children, title}) /*: Node*/ => { ... const App /*: () => Node*/ = () => { ...
這樣刪除或者注釋掉這些語法之后,vscdoe的報警就解除了。
禁掉vscode內(nèi)置的TypeScript插件
過了一段時間,我漸漸熟悉了React Native的一些東西,主要矛盾解決的差不多了,是時候回過頭來看看怎么處理它了。Flow的類型定義和Typescript還是蠻相似的,很多地方的語法都一模一樣,也難怪vscode把它識別成了TypeScript。
因為我默認生成RN項目時,并不打算使用TypeScript,而是打算全套用FB的東西:RN配Flow。所以,第一步,就是針對我的workspace,關閉vscode的Typescript檢查。
廢話不多說,直接上圖:
在vscode中disable掉內(nèi)置的兩個TypeScript插件,注意要選擇僅僅是當前worksapce下disable就好。
引入Flow Language Support解除報警
既然禁止了TypeSCript,那么就需要引入Flow的插件了,還是上圖:
該插件名字叫Flow Language Support
,也是人氣超高的插件啊。
引入插件后,你會發(fā)現(xiàn),似乎這個插件并沒有工作。因為一個插件的工作,其實有時候是需要node_modules里有讓這個插件使用的命令行工具才行。插件本身,只是為了契合vscdoe的一個殼,殼子里的內(nèi)容,是需要有對應的包的支持的。
yarn add flow-bin flow-parser -D
安裝這兩個包為插件賦予真正的靈魂。關閉vscode,然后重新打開。之所以這么做的目的是因為有些插件需要重新啟動vscode才行,我的習慣就是每次安裝完插件,甭管是否有重啟的提示,都會主動重啟。
很遺憾,這次又有了新的報錯:
根據(jù)提示,好像是因為插件依賴的flow版本是0.183.0,而.flowconfig中的版本是^0.182.0。這個錯誤提醒了我們,要保證當前項目中,各個地方使用的flow版本,都一致才行。知道插件用的是0.183.0,那么也要保證其余地方也是這個版本。
yarn add flow-bin@0.183.0 flow-parser@0.183.0 -D
于是我們重新安裝flow-bin和flow-parser,保證他倆的版本和插件依賴的版本一致。然后再把.flowconfig里的version改了。
重啟一下vscode,再次打開后,F(xiàn)low插件就工作正常了。
我在安裝Flow插件的時候的版本提示是0.183.0,但是這個版本隨著時間的推移,必然會變化,記得隨機應變哦。
以上就是新建的React Native就遇到vscode報警解除方法的詳細內(nèi)容,更多關于React Native解除vscode報警的資料請關注腳本之家其它相關文章!
相關文章
React+umi+typeScript創(chuàng)建項目的過程
這篇文章主要介紹了React+umi+typeScript創(chuàng)建項目的過程,結(jié)合代碼介紹了項目框架搭建的方式,本文給大家講解的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-02-02簡析React Native startReactApplication 方法
這篇文章主要介紹了React Native startReactApplication 方法簡析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09react.js 獲取真實的DOM節(jié)點實例(必看)
下面小編就為大家?guī)硪黄猺eact.js 獲取真實的DOM節(jié)點實例(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04React18+TS通用后臺管理系統(tǒng)解決方案落地實戰(zhàn)示例
這篇文章主要為大家介紹了React18+TS通用后臺管理系統(tǒng)解決方案落地實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08ReactNative-JS 調(diào)用原生方法實例代碼
這篇文章主要介紹了ReactNative-JS 調(diào)用原生方法實例代碼的相關資料,需要的朋友可以參考下2016-10-10關于React16.0的componentDidCatch方法解讀
這篇文章主要介紹了關于React16.0的componentDidCatch方法解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05