简体   繁体   English

React Native SVG 导入返回号

[英]React Native SVG Import Return Number

Hello last 2 day I struggle with this SVG issue.您好,前 2 天我在为这个 SVG 问题而苦苦挣扎。 First problem is I cannot import svg file it says cannot find module then I fix it about declaring problem.第一个问题是我无法导入 svg 文件它说找不到模块然后我修复它关于声明问题。 Then I find a solution by writing svg data in func like that:然后我通过在 func 中编写 svg 数据来找到解决方案,如下所示:

const notifactionIcon = (
  width = 60,
  height = 60
) => `<svg width="${width}" height="${height}" viewBox="0 0 60 60" fill="none" xmlns="http://www.w3.org/2000/svg"
    xmlns:xlink="http://www.w3.org/1999/xlink">
    <rect width="60" height="60" fill="url(#pattern0)" />
    <defs>
        <pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
            <use xlink:href="#image0_18_78" transform="scale(0.01)" />
        </pattern>
        <image id="image0_18_78" width="100" height="100"
            xlink:href="" />
    </defs>
</svg>`

export { notifactionIcon }

But I want to import manually.但我想手动导入。

在此处输入图像描述 It's pretty interesting这很有趣
在此处输入图像描述

I search on internet.我在互联网上搜索。 I cannot find any solution with this problem我找不到这个问题的任何解决方案

Did anyone know why this happening?有谁知道为什么会这样?

other things其他事情

babel通天塔


module.exports = function (api) {
  api.cache(true)
  return {
    presets: ["babel-preset-expo"],
  }
}

tsconfig tsconfig

{
  "extends": "expo/tsconfig.base",
  "compilerOptions": {
    "strict": true,
  }
}

webpack webpack

import createExpoWebpackConfigAsync from "@expo/webpack-config/webpack"
import { Arguments, Environment } from "@expo/webpack-config/webpack/types"

module.exports = async function (env: Environment, argv: Arguments) {
  const config = await createExpoWebpackConfigAsync(env, argv)

  return config
}

package package

{
  "name": "cookingapp",
  "version": "1.0.0",
  "main": "node_modules/expo/AppEntry.js",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "web": "expo start --web",
    "lint": "eslint '**/* .{js,ts,tsx,jsx}'"
  },
  "dependencies": {
    "@expo/webpack-config": "^0.17.2",
    "babel-plugin-inline-import": "^3.0.0",
    "expo": "^46.0.10",
    "expo-cli": "^6.0.5",
    "expo-status-bar": "~1.4.0",
    "firebase": "9.6.11",
    "fs": "^0.0.1-security",
    "idb": "^7.0.2",
    "node-fs": "^0.1.7",
    "react": "18.0.0",
    "react-dom": "18.0.0",
    "react-native": "^0.70.1",
    "react-native-fs": "^2.20.0",
    "react-native-paper": "^4.12.4",
    "react-native-svg": "^9.13.2",
    "react-native-svg-uri": "^1.2.3",
    "react-native-vector-icons": "^9.2.0",
    "react-native-web": "~0.18.7"
  },
  "devDependencies": {
    "@babel/core": "^7.12.9",
    "@react-native-community/eslint-config": "^3.1.0",
    "@types/react": "~18.0.0",
    "@types/react-dom": "17.0.14",
    "@types/react-native": "~0.69.1",
    "@typescript-eslint/eslint-plugin": "^5.37.0",
    "@typescript-eslint/parser": "^5.37.0",
    "eslint": "^8.23.1",
    "eslint-config-airbnb": "19.0.4",
    "eslint-config-node": "^4.1.0",
    "eslint-config-prettier": "^8.5.0",
    "eslint-plugin-import": "2.25.3",
    "eslint-plugin-jsx-a11y": "6.5.1",
    "eslint-plugin-node": "^11.1.0",
    "eslint-plugin-prettier": "^4.2.1",
    "eslint-plugin-react": "^7.31.8",
    "eslint-plugin-react-hooks": "4.3.0",
    "eslint-plugin-react-native": "^4.0.0",
    "file-loader": "^6.2.0",
    "prettier": "^2.7.1",
    "ts-node": "^10.9.1",
    "typescript": "^4.8.3"
  },
  "private": true
}

Thanks for answer from now...感谢您从现在开始的回答...

Looks like you are using the SvgXml component to render the SVG file.看起来您正在使用SvgXml组件来呈现 SVG 文件。 Looking at their usage docs , you need to update your babel config file.查看他们的使用文档,您需要更新您的 babel 配置文件。

  1. Update the babel file with the module:metro-react-native-babel-preset preset and the babel-plugin-inline-import plugin.使用module:metro-react-native-babel-preset预设和babel-plugin-inline-import插件更新 babel 文件。
module.exports = function (api) {
  api.cache(true)
  return {
    presets: [
      "babel-preset-expo",
      "module:metro-react-native-babel-preset"
    ],
    plugins: [
    [
      "babel-plugin-inline-import",
      {
        "extensions": [".svg"]
      }
    ]
  }
}
  1. Import the SVG file and use the SvgXml Component导入 SVG 文件并使用 SvgXml 组件
import * as React from 'react';
import { SvgXml } from 'react-native-svg';
import testSvg from './test.svg';

export default () => <SvgXml width="200" height="200" xml={testSvg} />;

you can render your SVGs using XML strings instead of importing it:您可以使用XML 字符串而不是导入它来渲染您的 SVG:

1- import: import { SvgXml } from 'react-native-svg'; 1-导入: import { SvgXml } from 'react-native-svg';

2- go inside your SVG file , you'll notice a bunch of XML code with an <svg> tag copy everything inside that <svg> element from the SVG file's XML code and store it inside a variable. 2- go inside your SVG file , you'll notice a bunch of XML code with an <svg> tag copy everything inside that <svg> element from the SVG file's XML code and store it inside a variable. like this像这样

const icon = <svg ....>...</svg>

3- Then, pass the icon variable to the xml prop inside your <SvgXml> component, like this: 3-然后,将 icon 变量传递给 < SvgXml <SvgXml>组件内的 xml 属性,如下所示:

<SvgXml xml={icon} width="100%" height="100%" />

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM