从客户端DOM序列化SVG的最佳方式是什么
What is the best way to serialize SVG from the client DOM?
我正在开发交互式SVG/AJAX接口,用户可以在该接口中动态创建和重新定位元素。我希望支持用户将当前视图导出为PNG图像和/或SVG文档的功能。我真的希望SVG文档尽可能简单(没有很多嵌套的转换)。有没有任何框架已经支持这一点?
我目前要求我的用户使用Ctrl+Alt+PrntScrn技术,我不想要求他们安装任何软件/插件。
如果有帮助的话,服务器端代码现在是用PHP实现的。我已经实现了使用ImageMagick从"原始"文档(在客户端进行任何修改之前)生成PNG图像的能力。
我假设您只需要在支持SVG的浏览器中使用它。
Firefox、Safari和Opera提供了非标准的XMLSerializer
API,因此您可以这样做:
var svg = document.getElementById('svg_root'); // or whatever you call it
var serializer = new XMLSerializer();
var str = serializer.serializeToString(svg);
从那里,您可以将它发送到服务器,并收到一个PNG作为回报。
以下是Mozilla关于从DOM序列化XML的开发人员页面。
innerHTML
在Gecko中返回格式良好的XML。
HTML5 <canvas>
可以使用toDataURL()
将其内容导出为PNG文件,并且可以使用drawImage()
在画布上绘制任何<img>
元素,因此应该可以创建<img src="data:application/svg+xml,…">
,在画布上进行绘制并导出为data:
URL。
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式