#javascript #reactjs #google-material-icons
#javascript #reactjs #google-материал-иконки
Вопрос:
В одном из моих приложений React я использую иконки Google Material Design. Как обычно, значки и логотипы не являются частью значков Google Material Design, которые необходимо добавлять вручную. В одном из случаев я пытаюсь реализовать значок XING в своем приложении, но он не отображается в приложении.
XING.js Компонент
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;
footer.js
Здесь я пытаюсь использовать значки дизайна Google Matral, а также значок 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;
* SVG-ДАННЫЕ XING
<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>
Ответ №1:
две проблемы:
Компонент React должен начинаться с заглавной буквы. Так что не син, а Син.
В остальном все в порядке, за исключением того, что ваш путь в svg, похоже, поврежден. Он не работает независимо от того, заключен ли он в component или просто непосредственно выделен как элемент svg. См.: https://codesandbox.io/s/frosty-paper-7nbxr?file=/src/App.js
Откуда у вас взялся этот путь?
Комментарии:
1. спасибо за ваш ответ. Я скачал логотип XING с их веб-сайта, а затем открыл его с помощью VS Code. В VS Code я мог видеть путь к SVG-файлу.
2. Пожалуйста, проверьте вашу строку пути, если вы скопировали ее полностью. Я просто скопировал строку пути svg в свой codesandbox, связанный выше, и на нем появился логотип. Эта строка была намного длиннее, чем та, что у вас есть.
3. еще раз спасибо, к сожалению, безуспешно с двумя разными путями SVG. Я пытаюсь сделать его маленьким с помощью этой ссылки: jakearchibald.github.io/svgomg
Ответ №2:
Может быть, вам нужно стилизовать svg? Например, укажите высоту или ширину в инспекторе, чтобы увидеть? Или, может быть, просто проверьте его, чтобы увидеть, какую высоту и ширину он имеет.
Я не знаю о Xing, но в большинстве случаев к ним не применяется ширина, и вы должны указать ее в своем css (например, в FontAwesome)