首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >svg在转换为元件时发生更改

svg在转换为元件时发生更改
EN

Stack Overflow用户
提问于 2017-02-02 01:28:20
回答 2查看 399关注 0票数 0

我有这个虚拟svg,里面有一个圆圈,里面有一些灰色的图形

代码语言:javascript
复制
<svg viewBox="0 0 86 86" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<defs>
    <circle id="path-1" cx="43" cy="43" r="43"></circle>
</defs>
<g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
    <g transform="translate(-585.000000, -391.000000)">
        <g transform="translate(585.000000, 391.000000)">
            <mask id="mask-2" fill="white">
                <use xlink:href="#path-1"></use>
            </mask>
            <use id="Oval" fill="currentcolor" xlink:href="#path-1"></use>
            <g id="Group" mask="url(#mask-2)" fill="#b8b8b8">
                <g transform="translate(21.500000, 27.823529)" id="Page-1">
                    <path d="M0.5,0.176470588 L0.5,58.1764706 L15.5,58.1764706 L15.5,49.1764706 L29.5,49.1764706 L29.5,31.1764706 L7.5,31.1764706 L7.5,37.1764706 Z"></path>
                </g>
            </g>
        </g>
    </g>
</g>

当我使用gulp svg- sprite with mode symbol将其转换为sprite时,会得到以下结果

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8" ?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><symbol viewBox="0 0 86 86" id="company"><defs><circle id="aa" cx="43" cy="43" r="43"/></defs><g fill="none" fill-rule="evenodd"><mask id="ab" fill="#fff"><use xlink:href="#aa"/></mask><use fill="currentcolor" xlink:href="#aa"/><g mask="url(#ab)" fill="#b8b8b8"><path d="M22 28v58h15v-9h14V59H29v6z"/></g></g></symbol></svg>

现在,灰色的图形打破了圆圈,这甚至发生在我将根、defs和g-tag从我的原始svg直接复制到symbol-tag中。我也尝试过在symbol版本中插入clipPath,但没有成功。

这里我漏掉了什么?

EN

回答 2

Stack Overflow用户

发布于 2017-02-02 02:10:04

更新:简化您的svg可能会起作用...尝试下面的例子,一个使用符号,一个不使用(以防吞咽精灵代码不能有嵌套的符号)……这可能是defs区域的一个问题。

代码语言:javascript
复制
svg {
  width: 100px;
}
代码语言:javascript
复制
<svg viewBox="0 0 86 86" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
  <defs>
    <symbol id="c">
      <circle cx="43" cy="43" r="43" fill="currentColor" />    
    </symbol>
    <mask id="mask" color="#fff">
      <use xlink:href="#c" />
    </mask>
  </defs>
  <use xlink:href="#c" color="#666" />
  <path fill="#999" mask="url(#mask)" d="M10 0v60h30v-10h20v-20h-30v9z" />
</svg>

<svg viewBox="0 0 86 86" xmlns="http://www.w3.org/2000/svg">
  <defs>
    <mask id="mask2" color="#fff">
      <circle cx="43" cy="43" r="43" fill="#FFF" />
    </mask>
  </defs>
  <circle cx="43" cy="43" r="43" fill="currentColor" />
  <path fill="#999" mask="url(#mask2)" d="M10 0v60h30v-10h20v-20h-30v9z" />
</svg>

票数 0
EN

Stack Overflow用户

发布于 2017-02-06 20:52:26

这可能不是一个完整的答案,但我设法让它工作;

首先,我使用我的圈子扩展了我的defs和一个clipPath

代码语言:javascript
复制
<defs>
    <circle id="circle" cx="43" cy="43" r="43"></circle>
    <clipPath id="clippath"><use overflow="visible" xlink:href="#circle" /></clipPath>
</defs>

然后,在我的第一个组中使用clipPath,并从gulp- svg -sprite切换到gulp-svgstore (它将defs移到顶部,符号上方),这给了我作为单一svg和svg符号精灵的期望。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41985955

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档