Cannot read property 'nodeType' of null; audio元素默认样式下载按钮

本文主要探讨了在JavaScript中遇到'Cannot read property 'nodeType' of null'错误的原因和解决方法,该错误通常发生在DOM元素已被删除但仍有事件监听器引用它时。解决方案包括避免不必要的重绘或确保重绘在所有监听器执行后进行。此外,还介绍了如何定制Chrome中audio元素的默认样式,包括隐藏下载按钮和音量控制,通过调整width属性实现不同的显示效果,并提供了结合CSS隐藏音量按钮的技巧。
摘要由CSDN通过智能技术生成

1.chrome-->console抛出如下错误:

Uncaught TypeError: Cannot read property 'nodeType' of null

错误原因:从stackoverflow上查了,这个bug可能是由于dom元素未加载完而先执行了jquery代码引起的。

错误分析:我这个实例为:点击某个表单标签时(如checkbox),widget重新进行了render()操作(将dom元素remove并重新绘制),而formit插件给form表单默认增加的监听事件还作用在已经被移除dom的元素上,所以执行formit事件的时候,target元素为null,报错抛出。出错的代码是jquery里追踪事件的捕获与冒泡的一段代码。参数为null时则报此错误。

解决的方法是:查走代码,去掉不合理的重绘,或将重绘过程放到listener都执行完成后进行。


2.chrome的audio元素默认样式修改

ch

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值