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

詳解React?Native中如何使用自定義的引用路徑

 更新時(shí)間:2022年10月12日 08:41:59   作者:前百花真君  
這篇文章主要為大家介紹了React?Native中如何使用自定義的引用路徑詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

RN的相對(duì)路徑地獄

我剛接觸RN時(shí),就發(fā)現(xiàn)所有的demo中給出來(lái)的路徑都是相對(duì)路徑,我自己的練習(xí)項(xiàng)目中想改成自定義的絕對(duì)路徑,但是發(fā)現(xiàn)并沒(méi)有我做前端時(shí)熟悉的webpack.config.js,所以也就不知道該怎么改了。伴隨著RN的學(xué)習(xí)和開(kāi)發(fā)練習(xí),我的代碼也變得越來(lái)越多,越來(lái)越復(fù)雜,我逐漸發(fā)現(xiàn)RN的相對(duì)路徑越來(lái)越麻煩,比如我把某個(gè)文件移動(dòng)到另一個(gè)不同深度的文件夾中,那么就需要把所有引用這個(gè)文件的地方都改一遍。請(qǐng)看下面這些例子,這些小點(diǎn)點(diǎn),晃得我眼暈。

import { deviceInfo } from '../../utilities/device'
...
import { API, DEV } from '../../../config/api'
...
import { Headers } from '../../widgets/nav'
...
import { basic } from '../../styles/theme'
...

RN的自定義路徑需要的依賴(lài)

作為前端開(kāi)發(fā)時(shí)熟悉的webpack.config.js,在RN的腳手架中并沒(méi)有看到,但是要知道,webpack.config.js里用來(lái)自定義import路徑的resolve.alias最終目的也是讓babel在翻譯代碼時(shí),能夠找到正確的路徑。所以RN里想用自定義的引用路徑,還得靠babel的配置才行。

  • 安裝依賴(lài)babel-plugin-module-resolver
yarn add babel-plugin-module-resolver -D
  • 配置babel.config.js
plugins: [
    [
      require.resolve('babel-plugin-module-resolver'),
      {
        extensions: ['.js', '.jsx'],
        root: ['.'],
        alias: {
          utilities: './src/utilities',
          config: './src/config',          
          widgets: './src/widgets',
          styles: './src/styles'
        }
      },
    ],
  ]
  • 配置jsconfig.json
{
  "compilerOptions": {
    "baseUrl": ".",
    "paths": {
      "utilities": ["./src/utilities/*"],
      "config": ["./src/config/*"],
      "widgets": ["./src/widgets/*"],
      "styles": ["./src/styles/*"],
    }
  }
}

RN腳手架默認(rèn)的情況下,是沒(méi)有這個(gè)文件的,需要自己新建。

  • 把相對(duì)路徑都改成自定義引用
import { deviceInfo } from 'utilities/device'
...
import { API, DEV } from 'config/api'
...
import { Headers } from 'widgets/nav'
...
import { basic } from 'styles/theme'
...
  • 重啟
yarn start

此時(shí)我發(fā)現(xiàn),自定義的路徑并沒(méi)有起作用,Metro報(bào)錯(cuò)說(shuō)找不到路徑。因?yàn)槲业乃蠷eact組件的定義,都是以jsx為文件后綴的。我在項(xiàng)目里使用了eslint-plugin-react這個(gè)eslint插件,它的推薦規(guī)則就是要React的組件的文件后綴為jsx。當(dāng)我把文件后綴改成js后,代碼就能正常運(yùn)行了。

我覺(jué)得文件后綴為jsx的情況下,jsconfig.js也能通過(guò)某種方式起作用,可惜我現(xiàn)在還不知道。

解決自定義引用路徑導(dǎo)致的eslint報(bào)錯(cuò)問(wèn)題

如果你使用了eslint-plugin-react,那么當(dāng)你用js作為React組件的文件后綴時(shí),eslint會(huì)報(bào)錯(cuò)。為了解決自定義引用路徑問(wèn)題,我只能犧牲掉這條eslint的rule。在.eslintrc.js加上這一條rule,就可以解決掉它。

rules:[
    'react/jsx-filename-extension': ['error', { extensions: ['.js', '.jsx']}]
]

如果你使用了airbnb或者單獨(dú)引用了eslint-plugin-import,那么當(dāng)你利用babel-plugin-module-resolver成功解析了自定義引用路徑的同時(shí),eslint就會(huì)因?yàn)闊o(wú)法找到這些路徑而報(bào)錯(cuò)。因?yàn)樯婕暗秸麄€(gè)項(xiàng)目的所有文件,不可能在文件里簡(jiǎn)單的ignore某個(gè)rule來(lái)消除錯(cuò)誤,而是需要在.eslintrc.js里覆蓋eslint-plugin-import的import/no-unresolved這條rule才行。

rules:[
    'import/no-unresolved': [2, { ignore: ['^utilities', '^config', '^widgets', '^styles']}]
]

至此,解決了自定義引用路徑問(wèn)題,同時(shí)避免了eslint的報(bào)錯(cuò)。

以上就是詳解React Native中如何使用自定義的引用路徑的詳細(xì)內(nèi)容,更多關(guān)于React Native自定義引用路徑的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React-Native中props具體使用詳解

    React-Native中props具體使用詳解

    本篇文章主要介紹了React-Native中props具體使用詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 圖文示例講解useState與useReducer性能區(qū)別

    圖文示例講解useState與useReducer性能區(qū)別

    這篇文章主要為大家介紹了useState與useReducer性能區(qū)別圖文示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • 在react-antd中彈出層form內(nèi)容傳遞給父組件的操作

    在react-antd中彈出層form內(nèi)容傳遞給父組件的操作

    這篇文章主要介紹了在react-antd中彈出層form內(nèi)容傳遞給父組件的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • react+antd.3x實(shí)現(xiàn)ip輸入框

    react+antd.3x實(shí)現(xiàn)ip輸入框

    這篇文章主要為大家詳細(xì)介紹了react+antd.3x實(shí)現(xiàn)ip輸入框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 淺談React-router v6 實(shí)現(xiàn)登錄驗(yàn)證流程

    淺談React-router v6 實(shí)現(xiàn)登錄驗(yàn)證流程

    本文主要介紹了React-router v6 實(shí)現(xiàn)登錄驗(yàn)證流程,主要介紹了公共頁(yè)面、受保護(hù)頁(yè)面和登錄頁(yè)面,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • React中useEffect函數(shù)的使用詳解

    React中useEffect函數(shù)的使用詳解

    useEffect是React中的一個(gè)鉤子函數(shù),用于處理副作用操作,這篇文章主要為大家介紹了React中useEffect函數(shù)的具體用法,希望對(duì)大家有所幫助
    2023-08-08
  • 基于React實(shí)現(xiàn)下拉刷新效果

    基于React實(shí)現(xiàn)下拉刷新效果

    這篇文章主要介紹了如何基于react實(shí)現(xiàn)下拉刷新效果,在下拉的時(shí)候會(huì)進(jìn)入loading狀態(tài),文中有詳細(xì)的代碼示例供大家參考,對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-03-03
  • Electron打包React生成桌面應(yīng)用方法詳解

    Electron打包React生成桌面應(yīng)用方法詳解

    這篇文章主要介紹了React+Electron快速創(chuàng)建并打包成桌面應(yīng)用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-12-12
  • React commit源碼分析詳解

    React commit源碼分析詳解

    前兩章講到了,react 在 render 階段的 completeUnitWork 執(zhí)行完畢后,就執(zhí)行 commitRoot 進(jìn)入到了 commit 階段,本章將講解 commit 階段執(zhí)行過(guò)程源碼
    2022-11-11
  • 為react組件庫(kù)添加typescript類(lèi)型提示的方法

    為react組件庫(kù)添加typescript類(lèi)型提示的方法

    這篇文章主要介紹了為react組件庫(kù)添加typescript類(lèi)型提示,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06

最新評(píng)論