微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

当 DOM 中存在时,querySelector 返回“无法执行 div 不是有效选择器”

如何解决当 DOM 中存在时,querySelector 返回“无法执行 div 不是有效选择器”

我遇到了一个问题,即当我从代码运行它时“div ID”无效。

但是,当我 document.querySelector('#div-gpt-ad\\/1594654184865-0>div') 返回正确的 div ID。 错误截图:https://gyazo.com/a7f1898f246bd84f28e85c2052ac60eb

执行代码页面上已经存在div id,renderDiv函数中的console.log返回

这是我要执行的代码

var slots = window.top.googletag.pubads().getSlots();
 
init(slots);
function init(slots) {
    for (let i = 0; i < slots.length; i++) {
        renderDiv(slots[i]);
    }
}
function getSelectors(slot) {
    var escapeCheck = slot.getSlotElementId();
    if(escapeCheck.includes('/')){
       let placeHold = escapeCheck.replace(/\//g,'\\\\/');

        return  "#" + placeHold + ">div" ;
    } else{ 
    return "#" + escapeCheck + ">div";
}
}
function renderDiv(slot) {
        let selector = getSelectors(slot);
        
        console.log("Selector:" + selector)
       document.querySelector(selector)

}

解决方法

已修复!

let placeHold = escapeCheck.replace(/\//g,'\\\\/'); 更改为

let placeHold =escapeCheck.replace(/\//g,"\\/").replace(/\./g,"\\.");

我还不太明白为什么第一个不起作用,因为通过的字符串是正确的

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。