日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ajax 请求svg,jQuery append 到AJAX加载的SVG问题

發布時間:2024/7/5 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ajax 请求svg,jQuery append 到AJAX加载的SVG问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我已成功通過AJAX從外部文件加載了一些svg:$("#svg").load(svgUrl + " svg", function() {

// do stuff

});

我的HTML看起來像這樣:

...

我可以看到圖形很好。現在,我想向已加載的svg添加一些其他svg元素。我將腳本更改為:

$("#svg").load(svgUrl + " svg", function() {

$("svg").append("");

// do stuff

});

由于某些原因,添加的元素在Firebug中顯示為隱藏,并且無論我放入其中的xml如何,都無法在網頁上看到它。

更新:

多虧了echo-flow,我能夠 append 到我的SVG中。現在,如果我嘗試從另一個xml文件加載指南針svg,它不會出現在我的DOM中。目前,我的代碼如下所示:

$("#svg").load(obj.svgUrl + " svg", function() {

var svgns = "http://www.w3.org/2000/svg";

var g = document.createElementNS(svgns,"g");

g.setAttributeNS(null,'id','compass');

$("svg").append(g);

$("#compass").load("files/svg/compass.xml");

});

如果我在Firebug的控制臺中查看,我會看到AJAX指南針標記請求的結果是成功的,但為空。

最佳答案

jQuery并不是真正為了解XML namespace 而構建的,因此很可能會解析字符串"",以使生成的DOM節點位于默認 namespace (而不是SVG namespace )中。您可以通過使用常規DOM創建節點來解決此問題。如下所示:svgns = "http://www.w3.org/2000/svg"

$("#svg").load(svgUrl + " svg", function() {

var g = document.createElementNS(svgns,"g");

g.setAttributeNS(null,'id','compass');

$("svg").append(g);

//do stuff

});

如果您需要創建更復雜的結構,則建議您查看jquery-svg庫,該庫具有用于生成SVG DOM的更簡潔的API。

更新了

我誤解了您正在嘗試加載SVG文檔并將其 append 到您的宿主HTML文檔中-相反,我認為您正在嘗試使用腳本生成SVG。為了解決您的問題,我建議您執行以下操作(未經測試,但應該可以):

//get the SVG document using XMLHTTPRequest

$.get(svgUrl + " svg",

function(svgDoc){

//import contents of the svg document into this document

var importedSVGRootElement = document.importNode(svgDoc.documentElement,true);

//append the imported SVG root element to the appropriate HTML element

$("#svg").append(importedSVGRootElement);

},

"xml");

關于jQuery append 到AJAX加載的SVG問題,我們在Stack Overflow上找到一個類似的問題:

https://stackoverflow.com/questions/6802283/

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的ajax 请求svg,jQuery append 到AJAX加载的SVG问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。