How to target .style attribut with .querySelectorAll selector?

前端 未结 2 1023
一整个雨季
一整个雨季 2021-01-23 16:14

I have selected a specific class via .querySelectorAll:

var hit3 = document.querySelectorAll(\".lattern.hit-3 .circle\");

I am now

2条回答
  •  情话喂你
    2021-01-23 17:03

    querySelectorAll returns an array like structure(NodeList) which does not have the style attribute.

    But I think what you need is slightly different, I assume want to display the circle for the clicked element then

    var latternElement = document.querySelectorAll('.lattern');
    
    function toggleElement(el) {
      el.querySelector('.circle').classList.add('visible'); //also minor tweaks, use css rules
    }
    
    for (var i = 0; i < latternElement.length; i++) {
      latternElement[i].addEventListener('click', function(event) {
        if (this.classList.contains("hit-3")) { //minor tweaks - only supported in modern browsers
          toggleElement(this);
        }
      });
    }
    .lattern {
      position: relative;
      width: 100px;
      height: 50px;
      background-color: red;
      margin: 0 0 10px 0;
      cursor: pointer;
    }
    .circle {
      position: relative;
      top: 20px;
      left: 20px;
      border-radius: 50% 50%;
      width: 16px;
      height: 16px;
      background-color: green;
      visibility: hidden;
    }
    .circle.default,
    .circle.visible {
      visibility: visible;
    }
    click me

提交回复
热议问题