简体   繁体   中英

how can I use svg as background image in react?

I want to use svg as background image in div, and can't find how to use!

I tried two ways.

common settings in webpack config files.

{
        test: /\.svg$/,
        use: ['@svgr/webpack','svg-url-loader'], // I tried url-loader either 
},
  1. I tried to embed src file as a props of styled-components
import styled from 'styled-components';
import categoryImage from 'src/asset/monitor-tv.svg';

export const CategoryIcon = styled.div<{
}>`
  width: 24px;
  height: 100%;
  background: url(${categoryImage}) no-repeat center;
  background-size: cover; 
` 




but it throws error in typescript compiler

Argument of type 'FunctionComponent<SVGAttributes<SVGElement>>' is not assignable to parameter of type 'Interpolation<ThemedStyledProps<Pick<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "slot" | "style" | "title" | ... 251 more ... | "onTransitionEndCapture"> & { ...; }, any>>'.
  Type 'FunctionComponent<SVGAttributes<SVGElement>>' is not assignable to type 'InterpolationFunction<ThemedStyledProps<Pick<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "slot" | "style" | "title" | ... 251 more ... | "onTransitionEndCapture"> & { ...; }, any>>'.
    Types of parameters 'props' and 'props' are incompatible.
      Type 'ThemedStyledProps<Pick<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "slot" | "style" | "title" | ... 251 more ... | "onTransitionEndCapture"> & { ...; }, any>' is not assignable to type 'PropsWithChildren<SVGAttributes<SVGElement>>'.
        Type 'ThemedStyledProps<Pick<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "slot" | "style" | "title" | ... 251 more ... | "onTransitionEndCapture"> & { ...; }, any>' is not assignable to type 'SVGAttributes<SVGElement>'.
          Types of property 'onCopy' are incompatible.
            Type '((event: ClipboardEvent<HTMLDivElement>) => void) | undefined' is not assignable to type '((event: ClipboardEvent<SVGElement>) => void) | undefined'.
              Type '(event: ClipboardEvent<HTMLDivElement>) => void' is not assignable to type '(event: ClipboardEvent<SVGElement>) => void'.
                Types of parameters 'event' and 'event' are incompatible.
                  Type 'ClipboardEvent<SVGElement>' is not assignable to type 'ClipboardEvent<HTMLDivElement>'.
                    Type 'SVGElement' is missing the following properties from type 'HTMLDivElement': align, accessKey, accessKeyLabel, autocapitalize, and 17 more.ts(2345)
Peek Problem (Alt+F8)
No quick fixes available


  1. I tried to embed as path where svg located.
import styled from 'styled-components';
import categoryImage from 'src/asset/monitor-tv.svg';

export const CategoryIcon = styled.div<{
}>`
  width: 24px;
  height: 100%;
  background: url('src/asset/monitor-tv.svg') no-repeat center;
  background-size: cover; 
` 

and the browser show me this error

Error: Invalid tag: ' width='200' height='64'/%3e %3c/g%3e %3c/svg%3e
    at validateDangerousTag (C:\Users\Desktop\web\fe\node_modules\react-dom\cjs\react-dom-server.node.development.js:2748:15)
    at ReactDOMServerRenderer.renderDOM (C:\Users\Desktop\web\fe\node_modules\react-dom\cjs\react-dom-server.node.development.js:3767:5)
    at ReactDOMServerRenderer.render (C:\Users\Desktop\web\fe\node_modules\react-dom\cjs\react-dom-server.node.development.js:3484:21)
    at ReactDOMServerRenderer.read (C:\Users\Desktop\web\fe\node_modules\react-dom\cjs\react-dom-server.node.development.js:3373:29)
    at renderToString (C:\Users\Desktop\web\fe\node_modules\react-dom\cjs\react-dom-server.node.development.js:3988:27)
    at app.get (webpack:///./src/server.tsx?:71:87)
    at Layer.handle [as handle_request] (C:\Users\Desktop\web\fe\node_modules\express\lib\router\layer.js:95:5)
    at next (C:\Users\Desktop\web\fe\node_modules\express\lib\router\route.js:137:13)
    at Route.dispatch (C:\Users\Desktop\web\fe\node_modules\express\lib\router\route.js:112:3)
    at Layer.handle [as handle_request] (C:\Users\Desktop\web\fe\node_modules\express\lib\router\layer.js:95:5)

You can do this setting it as the background of an element:

background: url()
    no-repeat center center;

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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