gpt4 book ai didi

jquery - 我的 HTML 出了什么问题,jQuery 无法解析它?

转载 作者:行者123 更新时间:2023-12-01 01:13:31 25 4
gpt4 key购买 nike

我一直在尝试获取 HTML 文件并将其作为 jQuery 对象分配给变量。无济于事。我不确定 Stack Snippets 是否允许 GET 请求,所以这里是 JSFiddle link也是如此。

    var html = '<!DOCTYPE html><html lang="en"><head><title>Template</title></head><body itemscope itemtype="http://schema.org/WebPage"><main><header itemscope itemtype="http://schema.org/Country" itemprop="about"><h1 itemprop="name">Dummy heading</h1><p><span class="capital" title="Capital" itemprop="containsPlace"></span><span title="Dummy title" itemprop="additionalProperty" itemscope itemtype="http://schema.org/PropertyValue"><meta itemprop="name" content="Member of the EU since"><span itemprop="value" class="member-since">Dummy year</span></span></p></header><div itemprop="mainEntity" itemscope itemtype="http://schema.org/ItemList"><meta itemprop="description" content=""><article class="recipe loading" itemprop="itemListElement" itemscope itemtype="http://schema.org/Recipe"><meta itemprop="position" content=""><aside class="media"><div class="img-gallery" itemscope itemtype="http://schema.org/ImageGallery"></div><div itemscope itemtype="http://schema.org/VideoObject" class="youtube"><a itemprop="contentUrl" href="#" title=""><meta itemprop="name" content=""><meta itemprop="uploadDate" content=""><meta itemprop="description" content=""><img itemprop="thumbnailUrl" src="#" alt=""></a><div class="youtube-player"></div></div></aside><div class="text"><div class="wiki-text"><h1 itemprop="name">Dummy heading</h1><p itemprop="description"></p><p class="read-more">For more information about <span class="recipe-name"></span>, read the <a href="#" title="" itemprop="sameAs">Wiki</a>.</p></div><div class="rating" itemprop="aggregateRating" itemscope itemtype="http://schema.org/AggregateRating">Rated <span itemprop="ratingValue">3.5</span>/5 based on <span itemprop="reviewCount">11</span> customer reviews</div><div class="cooking"><h2>Bake it yourself!</h2><div><meta itemprop="cookTime" content=""><span>Bake time: <span class="bake-time"></span></span></div><div class="ingredients-wrapper"><h3>Ingredients <small>for <span itemprop="recipeYield"></span></small></h3><div class="ingredients"><h4>Dummy heading</h4><ul></ul></div></div><div class="how-to"><h3>Steps</h3><ol></ol></div></div></div></article></div></main></body></html>';

$.ajax({
type: 'post',
url: "/echo/html/",
dataType: "html",
data: {
html: html,
delay: 1
}
}).done(function(data) {
// string
console.log(data);
// array
console.log($(data));
// array
console.log($.parseHTML(data));
// array
console.log($($.parseHTML(data)));
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

HTML 有效。但是,我无法将其放入对象中。正如预期的那样,返回的数据是一个字符串。但是,当我尝试使用 $.parseHTML() 将该字符串解析为 HTML 或将其放入 jQuery 选择器 $() 中,甚至尝试两者时,我总是得到相同的结果:包含标题和主要元素的数组。

因此,jQuery 仍然以某种方式解析它,并创建一个由 head 中的元素和 body 中的一个元素组成的数组。但是为什么?我该如何解决这个问题,并将其转换为 jQuery 对象?我只对正文的内容感兴趣。

a similar question ,但是接受的解决方案并没有帮助,因为它进入了 JSFiddle,而且我在本地使用 XAMPP 时也遇到了这个问题。

最佳答案

document.querySelector("body").innerHTML = + 
'<object type="text/html" data="'+html+'" ></object>';

...正常工作。所以我预计:

let parsedHtml = $('<object />', {
type:'text/html',
data:html
}).html()

也可以正常工作,但我猜当人们实际将其添加到 DOM 时,会发生一些神奇的事情。它解析它,为其构建 CSSOM 和 DOM 并加载所有依赖项,基本上就是您期望浏览器使用 .html 执行的操作。资源。

所以这是一种方法:

  1. 创建一个虚拟占位符,
  2. 放置<object>里面,
  3. 将虚拟对象附加到 DOM,
  4. 获取.contents()<object> (关于 onload 事件),
  5. 并删除虚拟对象。
let html = '// your valid html...',
dummyDiv = $('<div />',{
html: '<object type="text/html" data="'+html+'" ></object>',
style:"height:0;overflow:hidden;"
});

$('html').append(dummyDiv);
console.log(dummyDiv.find('object').contents());

注意 Chrome 已经足够智能,可以检测 display:none在父级上并且不加载 <object> 。这就是为什么我使用 height:0;overflow:hidden; 。您会注意到该元素的内容不具有 jQuery 对象的典型结构,因为它是一个文档。你会在

中找到果汁
dummyDiv.find('object').contents()[1].innerHTML

当 html 字符串已经在变量中时,它会立即加载,但实际上您需要放置一个 onload <object> 上的监听者并且仅在监听器触发时运行 4.5.

关于jquery - 我的 HTML 出了什么问题,jQuery 无法解析它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43898447/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com