javascript - React Native导入错误: unable to resolve module with . bin(如何导入某种类型的文件?)

标签 javascript react-native tensorflow require tensorflow.js

我在运行 React Native 应用程序时收到错误。

Unable to resolve "./tfjs_model_to_use_quantized/content/tfjs_model_to_use/group1-shard1of1.bin" from "components\ImageInput.js"

我正在尝试在 JS 代码中导入一个名为 group1-shardof1.bin 的文件。

其他 require 函数(例如,对于 json 文件)工作正常,并且该特定 require 函数的文件路径是正确的。我认为问题是 .bin 扩展名不支持在 React Native 中导出 代码:

const modelWeights = require('./tfjs_model_to_use_quantized/content/tfjs_model_to_use/group1-shard1of1.bin')

我尝试过,我添加了:

"packagerOpts": {
      "assetExts": ["bin", "pb", "txt"]
}

在我的 app.json 中,带有 bin 扩展名。

如何配置我的 React-Native 应用程序以便能够将 .bin 文件扩展名导入到 JS 文件中?如果有人能帮助我解决这个问题,那就太好了。

最佳答案

我找到了答案。可以在 Metro.config.js 中配置要由 React Native 解析的其他文件类型:

const blacklist = require('metro-config/src/defaults/blacklist');
module.exports = {
  transformer: {
    getTransformOptions: async () => ({
      transform: {
        experimentalImportSupport: false,
        inlineRequires: false,
      },
    }),
  },
  resolver: {
    // (add 'bin' to assetExts)
    assetExts: ['bin', 'txt', 'jpg', 'png', 'ttf'],
    sourceExts: ['js', 'json', 'ts', 'tsx', 'jsx'],
    blacklistRE: blacklist([/platform_node/])
  },
};

关键部分是 assetExts 部分,将“bin”添加到列表中。在我的具体情况下,由于某种原因没有创建 Metro.config.js 文件,但我使用上述代码创建了一个新文件,并且 .bin 的导入工作正常。

关于javascript - React Native导入错误: unable to resolve module with . bin(如何导入某种类型的文件?),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60715615/

相关文章:

javascript - Angular : Accessing a promise from a controller within a service

javascript - 如何实现当用户在 native 中按下图片时动态显示口袋妖怪详细信息的详细信息屏幕?

ios - react native ssl 固定

javascript - 如何为禁用的 HTML 输入文本字段启用 HTML 验证

javascript - 将键盘永久安装在屏幕上

tensorflow - 如何使用 tf.saved_model 加载模型并调用预测函数 [TENSORFLOW 2.0 API]

machine-learning - 重新训练 tensorflow 模型

python - 手动将 tf.contrib.slim 升级到 tf 2.0

javascript - jquery选择表中的所有单元格,除了

react-native - 如何为输入(react-native-elements)标签设置 fontFamily?