Javascript SVG图标无法在应用程序中显示。有什么解决办法吗?
在我的一个React应用程序中,我正在使用Google材质设计图标。像往常一样,有一些图标和徽标不属于谷歌材料设计的一部分,需要手动添加图标。在其中一种情况下,我试图在我的应用程序中实现XING图标,但它无法在应用程序中显示 XING.js组件Javascript SVG图标无法在应用程序中显示。有什么解决办法吗?,javascript,reactjs,google-material-icons,Javascript,Reactjs,Google Material Icons,在我的一个React应用程序中,我正在使用Google材质设计图标。像往常一样,有一些图标和徽标不属于谷歌材料设计的一部分,需要手动添加图标。在其中一种情况下,我试图在我的应用程序中实现XING图标,但它无法在应用程序中显示 XING.js组件 import React from 'react'; import pure from 'recompose/pure'; import {SvgIcon} from '@material-ui/core'; let xing = (props) =&
import React from 'react';
import pure from 'recompose/pure';
import {SvgIcon} from '@material-ui/core';
let xing = (props) => (
<SvgIcon {...props} >
<path d="M442.394 142c-1.736 0-3.197.61-3.934 1.803-.76 1.231-.645 2.818.166 4.424l19.503 33.761c.033.064.033.105 0 .164l-30.648 54.084c-.799 1.592-.76 3.191 0 4.425.736 1.187 2.033 1.966 3.771 1.966h28.844c4.312 0 6.393-2.91 7.867-5.57 0 0 29.973-53.01 31.14-55.068-.118-.19-19.83-34.58-19.83-34.58-1.439-2.557-3.606-5.41-8.03-5.41h-28.849z" fill="#005a5f"/><path d="M563.574 102.501c-4.309 0-6.176 2.714-7.723 5.494 0 0-62.14 110.2-64.188 113.818.105.196 40.984 75.191 40.984 75.191 1.432 2.558 3.641 5.494 8.06 5.494h28.81c1.738 0 3.096-.654 3.828-1.843.77-1.23.748-2.857-.059-4.458l-40.664-74.295a.167.167 0 0 1 0-.189l63.863-112.92c.803-1.594.82-3.22.061-4.452-.736-1.188-2.098-1.843-3.836-1.843h-29.139v.002h.003z" fill="#d4d600"/>
</SvgIcon>
);
xing = pure(xing);
xing.displayName = 'xing';
xing.muiName = 'SvgIcon';
export default xing;
从“React”导入React;
从“重新组合/纯”导入纯;
从'@material ui/core'导入{SvgIcon};
让星=(道具)=>(
);
兴=纯(兴);
xing.displayName='xing';
xing.muiName='SvgIcon';
出口违约;
footer.js
在这里,我尝试使用谷歌Material设计图标以及XING图标:
import React from "react";
import { Facebook, YouTube } from '@material-ui/icons';
import Xing from '../footer/Xing';
import { makeStyles } from '@material-ui/styles';
...
...
const socialMedia = (
<div class="has-text-centered">
<section class="hero">
<div class="hero-body">
<div class="container">
<h1 class="title">{L10n.format("social_media")}</h1>
</div>
</div>
<br/>
</section>
<div class="social-media-margin">
<div class="columns">
<div class="column">
<span className="social-media-icon">
<a
href={"https://www.youtube.com/"}
target="_blank"
><YouTube /></a>
</span>
</div>
<div class="column">
<span className="social-media-icon">
<a
href={"https://www.facebook.com/"}
target="_blank"
><Facebook/></a>
</span>
</div>
<div class="column">
<span className="social-media-icon">
<a
href={"https://www.xing.com/"}
target="_blank"
><Xing/>
</a>
</span>
</div>
</div>
</div>
</div>
);
return (
<footer className="footer">
{bannerAddition}
{socialMedia}
<div className="columns is-centered footer-colmns">
{products}
{solutions}
{service}
{company}
</div>
{legalInformation}
</footer>
);
};
export default footer;
从“React”导入React;
从“@materialui/icons”导入{Facebook,YouTube};
从“../footer/Xing”导入Xing;
从'@material ui/styles'导入{makeStyles};
...
...
常量社会媒体=(
{L10n.format(“社交媒体”)}
);
返回(
{banneradition}
{社会媒体}
{产品}
{解决方案}
{service}
{公司}
{法律信息}
);
};
导出默认页脚;
*XING的SVG数据
<svg xmlns="http://www.w3.org/2000/svg" width="2128" height="2500" viewBox="426.896 102.499 170.207 200">
<path d="M442.394 142c-1.736 0-3.197.61-3.934 1.803-.76 1.231-.645 2.818.166 4.424l19.503 33.761c.033.064.033.105 0 .164l-30.648 54.084c-.799 1.592-.76 3.191 0 4.425.736 1.187 2.033 1.966 3.771 1.966h28.844c4.312 0 6.393-2.91 7.867-5.57 0 0 29.973-53.01 31.14-55.068-.118-.19-19.83-34.58-19.83-34.58-1.439-2.557-3.606-5.41-8.03-5.41h-28.849z" fill="#005a5f"/>
<path d="M563.574 102.501c-4.309 0-6.176 2.714-7.723 5.494 0 0-62.14 110.2-64.188 113.818.105.196 40.984 75.191 40.984 75.191 1.432 2.558 3.641 5.494 8.06 5.494h28.81c1.738 0 3.096-.654 3.828-1.843.77-1.23.748-2.857-.059-4.458l-40.664-74.295a.167.167 0 0 1 0-.189l63.863-112.92c.803-1.594.82-3.22.061-4.452-.736-1.188-2.098-1.843-3.836-1.843h-29.139v.002h.003z" fill="#d4d600"/>
</svg>
两个问题:
React组件必须以大写字母开头。所以不是星,而是星
除此之外,一切都很好,只是svg中的路径似乎已损坏。无论它是包装在组件中还是直接作为svg元素概述,它都不起作用。见:
您从何处获得该路径?也许您需要设置svg的样式?比如说,在检查员的眼睛里放上一个高度或宽度?或者只是检查一下它的高度和宽度
我不知道Xing的情况,但大多数情况下,Xing没有应用宽度,您必须在css中指定宽度(如FontAwesome)谢谢您的回答。我从他们的网站下载了XING徽标,然后用VS代码打开了它。在VS代码中,我可以看到SVG文件的路径。如果您完全复制了它,请检查您的路径字符串。我刚刚将svg路径字符串复制到上面链接的代码沙盒中,它显示了徽标。这个字符串比您拥有的要长得多。再次感谢,不幸的是,使用两个不同的SVG路径没有成功。我正试图通过以下链接将其缩小: