【React Native】自定義格式的資源文件引入及使用

前言

很多時候React Native在引入資源文件的時候比如SVG绪励,JSON文件資源的時候攒霹,需要把文件放在對應的原生工程里面去(IOS和Android分別放入),這樣其實對于資源使用的整理是很麻煩的穆刻,其實官網(wǎng)也是有考慮到這個問題的亲轨,在React Native中文文檔的圖片-靜態(tài)資源說明中也有提到(點擊此處連接)妄讯。


如何使用非圖片資源

這個配置是在node_modules文件及里面的metro打包工具下,從這里可以看到React Native支持的文件格式衙荐,我們只要往里面添加想要的格式就可以捞挥。


默認支持的格式

當然浮创,你也可以從外部導入忧吟,在React Native創(chuàng)建項目的時候,也會生成一個名為metro.config.js的配置文件斩披,直接在這里面添加就可以(注意溜族,直接添加的話會覆蓋之前的配置文件的內容,需要通過...方式進行添加)垦沉。

/**
 * Metro configuration for React Native
 * https://github.com/facebook/react-native
 *
 * @format
 */

// get defaults assetExts array
const defaultAssetExts = require('metro-config/src/defaults/defaults').assetExts;

module.exports = {
  transformer: {
    getTransformOptions: async () => ({
      transform: {
        experimentalImportSupport: false,
        inlineRequires: false,
      },
    }),
  },
  resolver: {
    assetExts: [
      ...defaultAssetExts, // <- array spreading defaults
      'svga',//這里添加你需要支持的格式
    ],
  },
};

當然metro還可以添加各種配置煌抒,具體可以見Metro官網(wǎng)

如何使用資源文件

使用的方式其實就是跟平常的React Native引入資源的方式是一樣的厕倍,直接require()進行引入就行寡壮,我們這里舉一個例子。

console.log('資源導入', require('../image/powerLine.svga'));

log打出的效果如下:

打印結果

會發(fā)現(xiàn)打出來的是一個Int類型的數(shù)字讹弯,這是React Native內部給每一個資源文件定義的Id編號况既,require()方法是在編譯階段就會生效的,但是如果給一個編號我們該怎么使用呢组民,對于這個棒仍,React Native的Image組件有提供一個方法(此處鏈接)
方法說明

該方法會根據(jù)資源Id來返回一個ImageSource對象臭胜,里面有包含文件的uri等相關信息莫其,uri的返回結果在debug模糊和release會稍微不同。

debug模式返回的結果為:

console.log('資源導入結果', Image.resolveAssetSource(require('../image/powerLine.svga')));

//log輸出
 資源導入結果 {"__packager_asset": true, "height": undefined, "scale": 1, "uri": "http://localhost:8081/assets/assets/powerLine.svga?platform=android&hash=42cddc5c14b5521e54c68fd62caed73a", "width": undefined}

debug模式下會得到資源文件的url地址連接耸三,這是因為React Native會debug模式中會把所有資源文件打包到index.js服務器上面去乱陡,url的話就可以傳到原生自己去處理了。

release的返回結果為(Android):


release返回的結果

在release模式下返回的結果其實就是這個資源文件的名字仪壮,這是因為React Native會通過Metro打包工具來吧外部依賴的資源文件全部進行打包進apk蛋褥,并且小重新命名,它的命名規(guī)則是路徑路徑資源文件名字睛驳,而我們直接打開apk則可以在raw下看到這個文件烙心,我們自己自定義支持的文件格式都會被打到raw文件夾下(經(jīng)小部分測試,部分React Native官方支持的文件格式也會被打包進raw文件夾下乏沸,比如ttf和svg等淫茵,暫時沒找到怎么自定義打包資源路徑,如果有知道的大神請指教)蹬跃。

apk下的的文件路徑

既然是在raw下匙瘪,而且有資源文件的名字的話铆铆,我們就可以直接拿到文件的uri了。

拿到文件的uri丹喻,imageUri為React Native傳遞過來的文件名字
Uri uri = Uri.parse(ContentResolver.SCHEME_ANDROID_RESOURCE + "://" + mContext.getPackageName() + "/raw/" + imageUri)
//后續(xù)進行業(yè)務邏輯處理

至于IOS的release模式下薄货,拿到的是一個路徑而不是文件名字,需要另外做處理碍论,然后在傳遞給原生進行業(yè)務處理谅猾。


let uri = Image.resolveAssetSource(require('../image/powerLine.svga')).uri;
if (Platform.OS === 'ios' && uri.indexOf('file:///') !== -1) {
  uri = uri.substring(8, uri.length);
}
//uri傳遞給原生進行處理
......
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鳍悠,隨后出現(xiàn)的幾起案子税娜,更是在濱河造成了極大的恐慌,老刑警劉巖藏研,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件敬矩,死亡現(xiàn)場離奇詭異,居然都是意外死亡蠢挡,警方通過查閱死者的電腦和手機弧岳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來业踏,“玉大人禽炬,你說我怎么就攤上這事”こ疲” “怎么了瞎抛?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長却紧。 經(jīng)常有香客問我桐臊,道長,這世上最難降的妖魔是什么晓殊? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任断凶,我火速辦了婚禮,結果婚禮上巫俺,老公的妹妹穿的比我還像新娘认烁。我一直安慰自己,他們只是感情好介汹,可當我...
    茶點故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布却嗡。 她就那樣靜靜地躺著,像睡著了一般嘹承。 火紅的嫁衣襯著肌膚如雪窗价。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天叹卷,我揣著相機與錄音撼港,去河邊找鬼坪它。 笑死,一個胖子當著我的面吹牛帝牡,可吹牛的內容都是我干的往毡。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼靶溜,長吁一口氣:“原來是場噩夢啊……” “哼开瞭!你這毒婦竟也來了?” 一聲冷哼從身側響起墨技,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤惩阶,失蹤者是張志新(化名)和其女友劉穎挎狸,沒想到半個月后扣汪,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡锨匆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年崭别,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片恐锣。...
    茶點故事閱讀 38,654評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡茅主,死狀恐怖,靈堂內的尸體忽然破棺而出土榴,到底是詐尸還是另有隱情诀姚,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布玷禽,位于F島的核電站赫段,受9級特大地震影響,放射性物質發(fā)生泄漏矢赁。R本人自食惡果不足惜糯笙,卻給世界環(huán)境...
    茶點故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望撩银。 院中可真熱鬧给涕,春花似錦、人聲如沸额获。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抄邀。三九已至耘眨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間撤摸,已是汗流浹背毅桃。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工褒纲, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人钥飞。 一個月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓莺掠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親读宙。 傳聞我的和親對象是個殘疾皇子彻秆,可洞房花燭夜當晚...
    茶點故事閱讀 43,543評論 2 349

推薦閱讀更多精彩內容