• 技术文章 >web前端 >js教程

    js中hover无效怎么解决

    零下一度零下一度2017-06-25 09:24:05原创1411

    这其实是css的优先级导致的。

    首先来看下不用js添加css属性,hover能正常设置背景颜色。

    <div id="add"></div>
    #add{
      width: 50px;
      height: 50px;
      background-color: greenyellow;
    }#add:hover{
      background-color: #000;
    }

    左边的图是默认情况下,右边是鼠标放上去的时候,现在hover还是能正常显示的。

    (下面的图都是左边默认,右边hover,应为截图工具不能把鼠标也截上来)

    但是如果通过js插入css样式的话,鼠标放上去的hover样式就不会生效了。

    var add = document.getElementById("add");
    add.style.backgroundColor = "red";

    现在hover里设置的#000属性已经失效了。

    但这并不是hover伪类失去的作用,如果设置不是js添加的样式,就能看出hover并没有失效,比如添加一下字体颜色试一下。

    #add:hover{
      background-color: #000;
      color: yellow;
    }

    可以看到字体颜色还是会改变的。

    原因是应为js添加css样式是直接在html标签的style上添加的,而style的优先级高于css伪类。

    从上到下style,hover,id选择器。

    可以在浏览器调试工具里看到,js是直接添加到style里的。

    那么该怎么办呢

    里边讲了选择器的优先级。但是并没有讲到css伪类和style的优先级。

    但是:hover伪类也失效了。说明style>css伪类>id>class。

    给:hover的属性后面添加!important就可以了。应为!important优先级高于一切!!

    !important>style>css伪类>id>class。

    #add:hover{
      background-color: #000 !important;
    }

    现在终于达到了想要的结果。

    以上就是js中hover无效怎么解决的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:设置cookie 函数的实例代码 下一篇:ES6学习之map-set与数组和对象的比较
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• 什么是消息队列?node中如何使用消息队列?• 18个常见angular面试题(附答案分析)• JavaScript的Symbol类型、隐藏属性及全局注册表详解• 浅析IDEA中如何开发Angular• 整理总结JavaScript常见的BOM操作
    1/1

    PHP中文网