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

教你使用vscode 搭建react-native開(kāi)發(fā)環(huán)境

 更新時(shí)間:2021年07月07日 11:43:35   作者:過(guò)兒9973  
本文記錄如何使用vscode打造一個(gè)現(xiàn)代化的react-native開(kāi)發(fā)環(huán)境,旨在提高開(kāi)發(fā)效率和質(zhì)量。本文給大家分享我遇到的問(wèn)題及解決方法,感興趣的朋友跟隨小編一起看看吧

問(wèn)題

代碼沒(méi)有提示:
許多剛接觸RN開(kāi)發(fā)的非前端同學(xué),都會(huì)問(wèn)“哪個(gè)編輯器有智能提示?”。。。而對(duì)于前端同學(xué)來(lái)說(shuō),現(xiàn)在的日子已經(jīng)好很多了,要什么自行車(chē)。

低級(jí)代碼錯(cuò)誤:
這里的錯(cuò)誤是指類(lèi)似拼寫(xiě)錯(cuò)誤,符號(hào)錯(cuò)誤等。寫(xiě)完代碼,跑起來(lái)各種報(bào)錯(cuò),有時(shí)候費(fèi)死勁的找,最后發(fā)現(xiàn)是個(gè)中文的分號(hào)問(wèn)題。

解決辦法

可選的方案大概有:

  1. 使用typescript: 直接使用有靜態(tài)類(lèi)型支持的js版本,but要再學(xué)習(xí)一套語(yǔ)法,而且我的代碼都是ts寫(xiě)的,但很多好的公共庫(kù)不是啊。
  2. 使用flow: 由于網(wǎng)絡(luò)的原因,這個(gè)環(huán)境真的難配,同時(shí)也是要學(xué)習(xí)一些新的語(yǔ)法。

我們的選擇:vscode + typings + eslint

  • vscode: 宇宙最強(qiáng)IDE家族的最新產(chǎn)品
  • typings: 基于typescirpt的接口文件
  • eslint: 代碼靜態(tài)檢查,技能檢測(cè)低級(jí)的語(yǔ)法錯(cuò)誤,又能規(guī)范代碼格式和應(yīng)用最佳實(shí)踐

工具和插件

編輯器:vscode.

必裝和推薦的插件如下:

注:

  • 點(diǎn)擊各個(gè)插件,會(huì)有對(duì)應(yīng)的詳細(xì)的說(shuō)明
  • vscode和插件的更新頻率還是比較快的,推薦及時(shí)更新
  • vscode的插件安裝很簡(jiǎn)單,左側(cè)最下面那個(gè)按鈕就是擴(kuò)展面板,直接搜索插件名字,點(diǎn)擊安裝即可

代碼智能提示

對(duì)于第三方包,比如react-native:

全局安裝typings:

npm install typings -g

安裝react和react-native的接口說(shuō)明文件:

typings install dt~react --save

typings install dt~react-native --save

等待安裝完成后(會(huì)取決于包的數(shù)目和網(wǎng)絡(luò)狀況),在項(xiàng)目的根目錄下會(huì)有一個(gè)typings目錄和typings.json配置文件:


完成后重啟一下code , 或者使用reload命令,現(xiàn)在react-native和react相關(guān)的代碼就有提示說(shuō)明了,效果如下:

方法智能提示:

顯示方法的參數(shù):

hover時(shí)顯示說(shuō)明:

注: 對(duì)于其他的第三方包,可以用類(lèi)似的方法,或者借助于上面提到的插件。

如果是業(yè)務(wù)代碼開(kāi)發(fā)者:

對(duì)于規(guī)范的模塊化js代碼,vscode可以自動(dòng)建立聯(lián)系并提示的,我們只需要寫(xiě)好注釋即可。

如果是工具包或者SDK開(kāi)發(fā)者:

我們的代碼是要發(fā)布給其他同學(xué)用的,則需要我們?cè)诎l(fā)布時(shí)提供相應(yīng)的.d.ts接口文件。
默認(rèn)是包根目錄下index.d.ts文件,否則需要在package.json配置中指明typings項(xiàng)(類(lèi)似main)。

如何編寫(xiě)接口文件:文檔

代碼靜態(tài)檢查

代碼靜態(tài)借助于 eslint,它由CLI和配置文件(規(guī)則)組成。

vscode中安裝了對(duì)應(yīng)插件后,就可以實(shí)時(shí)在編輯器上看到檢測(cè)結(jié)果,不用自己運(yùn)行CLI。

注:本文會(huì)涉及eslint-cli的參數(shù),一般開(kāi)發(fā)用不到,在寫(xiě)自動(dòng)化腳本命令時(shí)查下文檔。

先安裝eslint cli和相關(guān)插件,項(xiàng)目package.json中開(kāi)發(fā)依賴(lài)增加(這是比較流行的RN配置):

"devDependencies": {
    "eslint": "^3.3.1",
    "babel-eslint": "^6.1.2",
    "eslint-config-airbnb": "^10.0.1",
    "eslint-plugin-import": "^1.14.0",
    "eslint-plugin-jsx-a11y": "^2.1.0",
    "eslint-plugin-react": "^6.1.2"
}

然后運(yùn)行npm install安裝。

配置文件.eslintrc.js(這里我們采用了js格式,因?yàn)榭梢约幼⑨???蛇xjson格式)

這里可以用eslint init啟動(dòng)向?qū)梢粋€(gè)。

我們可直接使用現(xiàn)成的(好處是和團(tuán)隊(duì)其他項(xiàng)目保持一致),在項(xiàng)目根目錄新建一個(gè).eslintr.js文件,內(nèi)容如下

module.exports = {
  parser: 'babel-eslint',
  parserOptions: {
    sourceType: 'module'
  },
  extends: "airbnb",
  plugins: [
    "react",
    "jsx-a11y",
    "import"
  ],
  rules: {
    // 0 = off, 1 = warn, 2 = error
    // FB配置參考:
    // https://github.com/facebook/react-native/blob/8baaad9b0fbda2b02bb1834452aa63cac7910dc5/.eslintrc

    "global-require": 0,
    "no-use-before-define": 0,       // disallow use of variables before they are defined
    "max-len": 0,                    // specify the maximum length of a line in your program (off by default)
    "no-console": 0,                 // disallow use of console (off by default in the node environment)
    "no-undef": 2,                   // disallow use of undeclared variables unless mentioned in a /*global */ block

    "no-unused-vars": 0,
    "block-scoped-var": 0,           // treat var statements as if they were block scoped (off by default)
    "complexity": 0,                 // specify the maximum cyclomatic complexity allowed in a program (off by default)
    "consistent-return": 0,          // require return statements to either always or never specify values

    // allow async-await
    'generator-star-spacing': 0,

    "no-return-assign": 1,           // disallow use of assignment in return statement

    "react/jsx-filename-extension": 0,
    "react/self-closing-comp": 1,
    "react/jsx-closing-bracket-location": 0,
    "react/prop-types": 0, // 避免redux等注入屬性的情況
  },

  // 這里設(shè)置可能用到的全局變量
  "globals": {
    "window": true,
    "fetch": true,
    "__DEV__": true,
    "__APP__": true,
    "__ANDROID__": true,
    "__IOS__": true
  }
};

這里主要配置了插件和檢測(cè)規(guī)則,一些說(shuō)明:

  • 規(guī)則列表
  • 規(guī)則后面的 0 代表關(guān)閉, 1 代表顯示警告, 2 代表顯示錯(cuò)誤。有些規(guī)則可以配置參數(shù),具體看上面的規(guī)則列表文檔
  • 有一些簡(jiǎn)單錯(cuò)誤,vscode是可以自動(dòng)修復(fù)的(如果出現(xiàn)小燈泡的icon,就是可以自動(dòng)修復(fù))

這里的規(guī)則基本都是實(shí)踐總結(jié)的js代碼編寫(xiě)的最佳實(shí)踐,遇到檢測(cè)錯(cuò)誤時(shí),直接搜索規(guī)則,并閱讀說(shuō)明。

不要隨便就關(guān)閉。

安裝vscode的eslint插件后:

What's more:

可以使用pre-commit工具,在每次提交之前運(yùn)行eslint監(jiān)測(cè)代碼,如果失敗,則禁止提交。

Debug

vscode安裝了react-native-tools插件后,可以代替chromDevTools調(diào)試代碼。

更接近原生的調(diào)試方式。

我們常使用的方式是:

  • 在終端開(kāi)啟package server
  • vscode選擇,dbug, attach to packager
  • 在終端上,調(diào)出調(diào)試菜單,選擇 Debug JS Remotly

總結(jié)

工欲善其事必先利其器,折騰是值得的。

好的開(kāi)發(fā)環(huán)境提交提供效率,同時(shí)保障質(zhì)量。

好的開(kāi)發(fā)體驗(yàn),可以讓你快樂(lè)coding。

到此這篇關(guān)于教你使用vscode 搭建react-native開(kāi)發(fā)環(huán)境的文章就介紹到這了,更多相關(guān)vscode 搭建react-native內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 編寫(xiě)React組件項(xiàng)目實(shí)踐分析

    編寫(xiě)React組件項(xiàng)目實(shí)踐分析

    本文通過(guò)實(shí)例給大家分享了編寫(xiě)React組件項(xiàng)目實(shí)踐的全過(guò)程,對(duì)此有興趣的朋友可以參考下。
    2018-03-03
  • react 父子組件之間通訊props

    react 父子組件之間通訊props

    這篇文章主要介紹了react 父子組件之間通訊props,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • React 中的重新渲染實(shí)現(xiàn)

    React 中的重新渲染實(shí)現(xiàn)

    本文主要介紹了React 中的重新渲染實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • React之虛擬DOM的實(shí)現(xiàn)原理

    React之虛擬DOM的實(shí)現(xiàn)原理

    這篇文章主要介紹了React之虛擬DOM的實(shí)現(xiàn)原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 詳解React Hooks是如何工作的

    詳解React Hooks是如何工作的

    React Hooks是在React 16.8版本新增的特性,在我看了React官網(wǎng)和一些博客對(duì)React Hook的講解后還是覺(jué)得沒(méi)有g(shù)et到本質(zhì)。本篇博客通過(guò)手動(dòng)實(shí)現(xiàn)useState()來(lái)了解Hook的原理和本質(zhì)。閱讀此篇博客的前提是你要知道一些 React Hooks的基本用法和使用規(guī)則,不然會(huì)看得云里霧里。
    2021-05-05
  • 詳解React Native開(kāi)源時(shí)間日期選擇器組件(react-native-datetime)

    詳解React Native開(kāi)源時(shí)間日期選擇器組件(react-native-datetime)

    本篇文章主要介紹了詳解React Native開(kāi)源時(shí)間日期選擇器組件(react-native-datetime),具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-09-09
  • 詳解react setState

    詳解react setState

    這篇文章主要介紹了react setState的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下
    2021-04-04
  • create-react-app常用自定義配置教程示例

    create-react-app常用自定義配置教程示例

    這篇文章主要為大家介紹了create-react-app常用自定義配置教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • React超詳細(xì)講述Fiber的使用

    React超詳細(xì)講述Fiber的使用

    在fiber出現(xiàn)之前,react的架構(gòu)體系只有協(xié)調(diào)器reconciler和渲染器render。當(dāng)前有新的update時(shí),react會(huì)遞歸所有的vdom節(jié)點(diǎn),如果dom節(jié)點(diǎn)過(guò)多,會(huì)導(dǎo)致其他事件影響滯后,造成卡頓。即之前的react版本無(wú)法中斷工作過(guò)程,一旦遞歸開(kāi)始無(wú)法停留下來(lái)
    2023-02-02
  • React Native基礎(chǔ)入門(mén)之調(diào)試React Native應(yīng)用的一小步

    React Native基礎(chǔ)入門(mén)之調(diào)試React Native應(yīng)用的一小步

    這篇文章主要給大家介紹了關(guān)于React Native基礎(chǔ)入門(mén)之調(diào)試React Native應(yīng)用的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07

最新評(píng)論