gpt4 book ai didi

javascript - 未捕获的类型错误 : Cannot read property 'firstElementChild' of undefined when expanding posts in a certain order

转载 作者:行者123 更新时间:2023-11-29 18:27:16 25 4
gpt4 key购买 nike

你们中的任何人都可以帮我解决 Javascript 问题吗?我正在尝试为我的网站编写一个帖子扩展功能,出于某种原因,每当我扩展第一篇文章时,第二篇文章将不再扩展,而是重定向到线程页面上的完整文章。如果我展开第二个帖子然后展开第一个帖子,我就没有问题。

这是加载页面时运行的代码:

function postExpansionPrep(){
if(!document.body.className){
var links = document.getElementsByClassName("abbrev");
for (var i = 0; i < links.length; i++ ){
(function(e) {
links[e].firstElementChild.addEventListener("click", function(a){ expandPost(links[e].firstElementChild); a.preventDefault(); }, true);
console.log(links[e].firstElementChild.href);
})(i);
}
}
}

下面是当您点击链接展开帖子时运行的代码。

function expandPost(link){
if(link.hash){
$.get(link, function(data) {
var loadedPost = $(data).find("#reply" + link.hash.replace("#",""));
document.getElementById("reply" + link.hash.replace("#","")).lastElementChild.innerHTML = $(loadedPost).find("blockquote").last().html();
});
}
else{
$.get(link, function(data) {
var loadedPost = $(data).find("#parent" + link.pathname.substring(link.pathname.lastIndexOf("/")+1));
document.getElementById("parent" + link.pathname.substring(link.pathname.lastIndexOf("/")+1)).lastElementChild.innerHTML = $(loadedPost).find("blockquote").last().html();
});
}
}

您可以在此处查看实际问题:http://www.glauchan.org/test/

顺便说一下,该功能是可选的,因此您需要在 Board Options 菜单中启用 Post Expansion。

最佳答案

document.getElementsByClassName method返回一个事件的节点列表。因此,links 将发生变化,并且当处理程序被触发时,e 位置可能不再有项目 - 导致 undefined 值在访问其 firstElementChild 属性时抛出错误。

您不需要从 links 列表中获取当前元素。通过 a.target 或仅通过 this 动态获取它:

function postExpansionPrep() {
if (document.body.className)
return;
var links = document.getElementsByClassName("abbrev");
for (var i = 0; i < links.length; i++ ) {
var child = links[i].firstElementChild;
if (!child) // could be null as well
continue;
child.addEventListener("click", function(e) {
expandPost(this);
e.preventDefault();
}, true);
console.log(child.href);
}
}

顺便说一句,因为你有可用的 jQuery,所以你应该使用它,尤其是对于附加的事件处理程序:

if (!document.body.className)
$(".abbrev > :first-child").click(function(e) {
expandPost(this);
e.preventDefault();
});

关于javascript - 未捕获的类型错误 : Cannot read property 'firstElementChild' of undefined when expanding posts in a certain order,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11799759/

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