js 修改Class未生效

在JavaScript开发中遇到使用classList添加类未在页面实际显示的问题,即使DOM数据中已添加。问题出现在调用play方法时,domEnd.classList.add('hide')未更新页面。解决方案是使用document.querySelector重新获取元素并添加类。原因是二次及后续进入页面时,domEnd对象为内存中对象,而非页面上的DOM元素。
摘要由CSDN通过智能技术生成

问题描述:

最近开发遇到了使用js的classList添加类时 未在页面中生效的问题,奇怪的是 使用JS查看dom数据类名是已经添加上的,但是页面上的dom对象并没有反应。部分代码如下:

 const options = { ...playPDFDefaultConfing, ...o }
    const domEnd = options.elem.querySelectorAll(".play-item-mask")[0];
    const domIframe = options.elem.querySelectorAll("iframe")[0];
    const pdfPlayObj = {
        setURL: function (fid, cId) {
            thisPlayState = ""
            domIframe.setAttribute('src', fid);
        },
        play: function () {
            if (thisPlayState !== 'play') {
                thisPlayState = 'play';
                domEnd.classList.add('hide');
                options.onPlay();
            } else {
                console.log("PDF播放器已经:play");
            }
        },
        pause: function () {
            if (thisPlayState !== 'pause') {
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值