【问题标题】:how to replace text inside an svg using js?如何使用 js 替换 svg 中的文本?
【发布时间】:2014-09-19 12:27:52
【问题描述】:

在这段代码中,我试图将一个 svg 文件加载到快照纸中,然后将其转换为一个组:

replacing <svg   with <g   and  </svg>  with </g>  ?

请问我该如何解决这个问题?

var s1 = Snap('#svg1');



  Snap.load( "https://dl.dropboxusercontent.com/u/140225334/bicycle.svg", function( frag ) {
var maing = s1.g();
maing.append(frag);
    maing.attr({id: 'maing' }); 
   // city_name=city_name.replace(/ /gi,'_'); 
   var maing = maing.replace("<svg", "<maing").replace("</svg>", "</maing>");   // how this can be fixed to work?!

编辑:@dystroy,你的意思是这样的吗?:

var s1 = Snap('#svg1');




  Snap.ajax("https://dl.dropboxusercontent.com/u/140225334/bike2.svg", function(request) 
            {
    var svg = Snap(request.responseXML.documentElement);
    var maing = svg.selectAll("svg>*");//you can select any elements.

    s1.append(maing);
    maing.attr({id: 'maing' });

} );

编辑:@dystroy,如果我这样做,一些 svg 样式将不会被复制:

请检查这两个有何不同:

将 svg 节点复制到 g:

http://jsbin.com/geyog/1/edit

原始 svg 文件:

https://dl.dropboxusercontent.com/u/140225334/bike2.svg

【问题讨论】:

  • 你使用 raphael 和 snap 吗?
  • 您应该进行 DOM 操作而不是文本操作:创建 g 节点并将 svg 节点的内容附加到它们。
  • 无论如何替换函数只替换第一次出现。
  • 谢谢dystroy。你能检查我的编辑,看看这是不是你的意思?
  • 谢谢 Gena,每个 svg 只会出现一次。所以如果它有效,那对我来说很好。

标签: javascript svg raphael snap.svg


【解决方案1】:

您应该将 fill-rule 属性添加到 svg 元素。
原始svg文件有fill-rule属性,值为“evenodd”,但是html中描述的svg元素没有fill-rule,所以浏览器将fill-rule属性的“nonzero”作为默认值。
因此,复制的 svg 图形看起来其样式信息丢失了。

Snap.ajax("https://dl.dropboxusercontent.com/u/140225334/bike2.svg", function(request) 
            {
    var maing = s1.g();
    var svg = Snap(request.responseXML.documentElement);
    var maing = svg.selectAll("svg>*");//you can select any elements.
    //copy fill-rule attribute.
    s1.attr("fill-rule", svg.node.getAttribute("fill-rule"));
    s1.append(maing);
    maing.attr({id: 'maing' });
    //  maing.transform('r45'); 
});

【讨论】:

  • 哇!非常感谢@defghi1974。这就是魔法。这会复制它可能具有的任何其他 svg 属性吗?以及为什么这个代码: maing.transform('r45');请问不行吗?!如果您想现场试用,这里是链接:jsbin.com/geyog/3/edit
  • 是的,但要视情况而定。而“maing”是 Snap.svg 的 instanceof Set 对象,所以它没有实现 transform 方法。您必须阅读 Snap.svg 的 SVG 1.1se 推荐和 api 参考。
  • 谢谢@defghi1974。那么,如果我想复制 svg 的所有属性,有没有办法调用所有这些属性?请问我怎样才能使maing变成可变形的?我怎样才能把它附加到一个 g 上?
  • "svg" 元素是不可变形的,所以你需要做的是用 g 元素包裹包含已加载图形的内部 svg 元素,并将 transform 属性设置为 g 元素。
  • @defghi1974。你能告诉我在这个例子中怎么做吗?:jsbin.com/geyog/3/edit
猜你喜欢
  • 2014-04-13
  • 2020-11-30
  • 2021-11-19
  • 2021-02-08
  • 1970-01-01
  • 2021-07-08
  • 2022-11-14
  • 2017-12-15
  • 2018-09-06
相关资源
最近更新 更多