在VSCode中為React Native開(kāi)發(fā)設(shè)置TypeScript, TSLint以及 Prettier

?原文鏈接

本文翻譯自:Configure TypeScript, TSLint, and Prettier in VS Code for React Native Development

前言

我本身是做Android和iOS開(kāi)發(fā)的擒权,一直想做混合開(kāi)發(fā),但是一旦工作,再加上自己喜歡偷懶,這事就總是擱淺了抠蚣。有幸進(jìn)入了新公司,老大給了不少時(shí)間和機(jī)會(huì)學(xué)習(xí)贫橙。特別感謝捍歪!

翻譯這篇文章的目的很簡(jiǎn)單,因?yàn)樵趯W(xué)習(xí)React Native的這兩個(gè)月里恨狈,爬了不少坑疏哗,走了不少?gòu)澛罚@篇文章一步步詳細(xì)的寫了出來(lái)禾怠。

之前用的是Flow返奉,主要看是Facebook自己維護(hù)的贝搁,應(yīng)該是不二之選。但是Flow這玩意兒剛用的時(shí)候感覺(jué)挺好的芽偏,幾乎沒(méi)有學(xué)習(xí)成本雷逆,但是用到后面總是會(huì)出現(xiàn)莫名奇妙的問(wèn)題,F(xiàn)low也不會(huì)給出詳細(xì)的解決方案污尉,再者很多類型莫名其妙的變成了any膀哲,慌的一匹。更被提自動(dòng)導(dǎo)入被碗、代碼補(bǔ)全提示了某宪。當(dāng)然以上吐槽未必準(zhǔn)確,很大的可能性是自己的能力不足锐朴。翻了『TypeScript VS Flow』之類的文章兴喂,最終選擇TypeScript。

對(duì)著VSCode大把的插件包颁,一時(shí)會(huì)淚流滿面瞻想,此等神器,我以前為什么沒(méi)發(fā)現(xiàn)娩嚼?蘑险!驚喜之后就成了,臥槽岳悟,用哪個(gè)佃迄?臥槽,怎么用贵少?臥槽呵俏,啥時(shí)候用?自己糊糊涂涂配置下來(lái)貌似也能行呀滔灶,就擼代碼吧普碎。問(wèn)題是,代碼在別人VScode打開(kāi)之后录平,就全線爆紅麻车。好在現(xiàn)在是單打獨(dú)斗,但是后面肯定會(huì)有新同事的斗这,這絕對(duì)不行动猬!

正如該文章講的『提供一致、可重用的開(kāi)發(fā)工作流程』表箭,哈哈哈赁咙,一級(jí)棒!

簡(jiǎn)介

這篇簡(jiǎn)短的文章為新創(chuàng)建或已有的React Native項(xiàng)目提供一致、可重用的開(kāi)發(fā)工作流程彼水。你在代碼質(zhì)量上付出越多的努力崔拥,在調(diào)試上花費(fèi)的時(shí)間就越少。你能夠通過(guò)統(tǒng)一的開(kāi)發(fā)流程來(lái)提高代碼質(zhì)量猿涨,減少調(diào)試時(shí)間握童。在這篇文章中,我將會(huì)向你展示怎樣設(shè)置VSCode叛赚,處理代碼格式化、分析以及類型檢測(cè)稽揭。

Testing不在該篇文章講述范圍之內(nèi)俺附,但是強(qiáng)烈推薦。

怎樣使用TypeScript也不在該文章的講述范圍之內(nèi)溪掀。

開(kāi)始

我們從創(chuàng)建新項(xiàng)目開(kāi)始事镣。如果你正在處理已有項(xiàng)目,可以直接跳到TypeScript設(shè)置揪胃。一起來(lái)初始化項(xiàng)目吧璃哟!這篇文章我們使用的是React Native CLI.

$ react-native init SweetApp &&cdSweetApp

使用VS Code打開(kāi)SweetApp工程。

$ code .

打開(kāi)VSCode之后在Activity Bar中點(diǎn)擊Extensions按鈕喊递,安裝以下擴(kuò)展:

Prettier Code Formatter

TSLint

TypeScript設(shè)置

受限在終端中鍵入以下命令為React Native APP安裝和設(shè)置TypeScript随闪。(我使用Yarn包管理器)

yarn add --dev typescript react-native-typescript-transformer@types/react@types/react-native

$ yarn tsc --init --pretty --jsx react

$ touch rn-cli.config.js

我們做了一下工作:

TypeScript作為開(kāi)發(fā)依賴庫(kù)添加到我們的項(xiàng)目中

React Native TypeScript Transformer作為開(kāi)發(fā)依賴庫(kù)安裝到我們的項(xiàng)目中,使TypeScript和React Native無(wú)縫鏈接骚勘;

創(chuàng)建了一個(gè)空的TypeScript配置文件铐伴,我們接下來(lái)配置它。

創(chuàng)建了一個(gè)空的TypeScript Transformer配置文件俏讹,我們馬上會(huì)配置它当宴。

為React和React Native安裝了typings,允許TypeScript對(duì)React Native進(jìn)行類型檢查泽疆。

配置TypeScript

以下是我設(shè)置允許的/不允許的户矢,在起始的時(shí)候,我建議你和我一樣的做法殉疼。當(dāng)你熟悉了TypeScript梯浪,有了更多經(jīng)驗(yàn)后,你可以根據(jù)自己的喜好修改這個(gè)文件(tsconfig.json)株依。

你想要允許或者不允許某選項(xiàng)驱证,簡(jiǎn)單的不注釋或者注釋對(duì)應(yīng)該行的代碼即可。

在『Module Resolution Options』分組中我啟用了下面三個(gè)選項(xiàng):

"allowSyntheticDefaultImports":true,"esModuleInterop":true,"resolveJsonModule":true

在『Module Resolution Options』分組中修改必要的設(shè)置恋腕,和下面的代碼一致:

"noImplicitAny":true,"strictFunctionTypes":true,"noImplicitThis":true,"alwaysStrict":true

注意:?我更喜歡把『target』屬性設(shè)置為"ES2015",目的是在沒(méi)有Promise聲明的情況下使用async / await抹锄。

配置React Native TypeScript Transformer

打開(kāi)我們之前創(chuàng)建的『rn-cli.config.js』文件,粘貼以下代碼,保存伙单、關(guān)閉获高。

module.exports= {? getTransformModulePath() {returnrequire.resolve('react-native-typescript-transformer')? },? getSourceExts() {return['ts','tsx']? },}

TypeScript遷移

把工程中的『App.js』文件名修改為『 App.tsx』。

注意: index.js文件需要使用.js后綴

所有包含JSX的新文件需要使用?.tsx?后綴吻育,純js文件使用?.ts?后綴念秧。

現(xiàn)在是瀏覽現(xiàn)有.tsx和.ts文件并修復(fù)任何TypeScript錯(cuò)誤的好時(shí)機(jī)。

TSLint安裝設(shè)置

首先布疼,安裝TSLint以及我個(gè)人在React Native development喜歡的TSLint擴(kuò)展摊趾。

$ yarn add --dev tslint tslint-config-prettier tslint-config-standard tslint-react

安裝tslint-config-prettier后,?TSLint?和?prettier在代碼格式化規(guī)則上就不會(huì)有沖突了游两。

現(xiàn)在項(xiàng)目中砾层,你應(yīng)該能看到一個(gè)tslint.json的文件。(我沒(méi)看到贱案,哈哈哈肛炮,自己創(chuàng)建了一個(gè))。

打開(kāi)ts.json文件宝踪,像下面一樣配置:

{"defaultSeverity":"error","extends": ["tslint:recommended","tslint-config-standard","tslint-react","tslint-config-prettier"],"jsRules": {},"rules": {"ordered-imports":false,"object-literal-sort-keys":false,"member-ordering":false,"jsx-no-lambda":false,"jsx-boolean-value":false},"rulesDirectory": []}

rules分組是我的偏好侨糟,你可以隨意地使用自己的規(guī)則。

Lint你的代碼

打開(kāi)項(xiàng)目根目錄中的package.json文件瘩燥,在scripts分組中添加下面的lint腳本秕重。

現(xiàn)在你就可以從終端執(zhí)行yarn lint命令。你喜歡修復(fù)linter錯(cuò)誤颤芬,你懂的悲幅!

$ yarn lint

Prettier設(shè)置

Prettier在它自己的規(guī)則基礎(chǔ)上自動(dòng)格式化代碼。

Prettier很贊.如果你從未使用過(guò)站蝠,就像在HDTV上看了TV之后再回來(lái)在non-HDTV上看TV一樣汰具。一旦用了Prettier,你再也不會(huì)回過(guò)來(lái)再格式化自己的代碼菱魔。

安裝Prettier留荔。

$ yarn add --dev prettier

接下來(lái)我們想在保存文件后讓『VSCOde』使用Prettier擴(kuò)展格式化代碼。

如果在Mac上澜倦,按快捷鍵CMD+,打開(kāi)VS Code Workspace Settings,添加以下內(nèi)容:

"editor.formatOnSave":true,"javascript.format.enable":false

現(xiàn)在來(lái)創(chuàng)建一個(gè)prettier配置文件聚蝶,該文件包含了你的prettier代碼格式化偏好。

$ touch .prettierrc

使用我的prettier規(guī)則或者依據(jù)個(gè)人偏好規(guī)則藻治。這里是我的Prettier偏好碘勉。沒(méi)錯(cuò),我所在的團(tuán)隊(duì)不使用分號(hào)桩卵。

"semi":false,"singleQuote":true,"trailingComma":"es5"

Prettier代碼格式化

不管何時(shí)你保存了文件验靡,Prettier根據(jù)你的喜好自動(dòng)格式化你的代碼倍宾。

打開(kāi)app.js文件添加一個(gè)數(shù)值數(shù)組。把這個(gè)數(shù)組賦值給一個(gè)test變量胜嗓。把數(shù)組中的數(shù)值格式化打亂高职。

現(xiàn)在保存文件并查看Prettier的神器效果。

現(xiàn)在test數(shù)組被完美格式化了辞州!

?? 一切都搞定了! ??

希望這個(gè)指南節(jié)省了你大量時(shí)間怔锌,不管現(xiàn)在還是將來(lái)都是一份很棒的參考指南。

編程快樂(lè)变过!??

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末埃元,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子媚狰,更是在濱河造成了極大的恐慌亚情,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哈雏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡衫生,警方通過(guò)查閱死者的電腦和手機(jī)裳瘪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)罪针,“玉大人彭羹,你說(shuō)我怎么就攤上這事±峤矗” “怎么了派殷?”我有些...
    開(kāi)封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)墓阀。 經(jīng)常有香客問(wèn)我毡惜,道長(zhǎng),這世上最難降的妖魔是什么斯撮? 我笑而不...
    開(kāi)封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任经伙,我火速辦了婚禮,結(jié)果婚禮上勿锅,老公的妹妹穿的比我還像新娘帕膜。我一直安慰自己,他們只是感情好溢十,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布垮刹。 她就那樣靜靜地躺著,像睡著了一般张弛。 火紅的嫁衣襯著肌膚如雪荒典。 梳的紋絲不亂的頭發(fā)上酪劫,一...
    開(kāi)封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音种蝶,去河邊找鬼契耿。 笑死,一個(gè)胖子當(dāng)著我的面吹牛螃征,可吹牛的內(nèi)容都是我干的搪桂。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼盯滚,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼踢械!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起魄藕,我...
    開(kāi)封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤内列,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后背率,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體话瞧,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年寝姿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了交排。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡饵筑,死狀恐怖埃篓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情根资,我是刑警寧澤架专,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站玄帕,受9級(jí)特大地震影響部脚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜桨仿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一睛低、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧服傍,春花似錦钱雷、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至灿椅,卻和暖如春套蒂,著一層夾襖步出監(jiān)牢的瞬間钞支,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工操刀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留烁挟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓骨坑,卻偏偏與公主長(zhǎng)得像撼嗓,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子欢唾,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容