【问题标题】:How to have cursor change with buttonclick如何通过单击按钮更改光标
【发布时间】:2022-02-09 02:21:06
【问题描述】:

我在我的网站上设置了一个切换器,用于在普通鼠标/指针和乐高手作为光标和头部作为指针之间切换。但是,我只能在单击切换器时显示光标。我怎样才能也添加这个指针

(cursor: url(https://cdn.shopify.com/s/files/1/0571/7137/8349/files/pointer.png?v=1644096049), pointer;)

它应该分配给以下类:

a,按钮,输入,输入,按钮,a,输入,.slider,.round

然后我还添加了一个 sn-p,它可以让切换器/复选框保持选中状态... (你可以在这个视频上看到[密码是12345678]:https://easyupload.io/gknxoi

但是,例如在重新加载页面后,切换器保持选中状态,但光标不显示...

var cbs = document.querySelectorAll('input[type=checkbox]');
for (var i = 0; i < cbs.length; i++) {
  cbs[i].addEventListener('change', function() {
    if (this.checked) {
      document.body.style.cursor = "url(https://cdn.shopify.com/s/files/1/0571/7137/8349/files/cursor.png?v=1644096068), auto";
    } else {
      document.body.style.cursor = "default";
    }
  });
}


$(function() {
  var test = localStorage.input === 'true' ? true : false;
  $('input').prop('checked', test || false);
});

$('input').on('change', function() {
  localStorage.input = $(this).is(':checked');
  console.log($(this).is(':checked'));
});
.switcheronheader {
  position: relative;
  display: inline-block;
  width: 30px;
  height: 17px;
  margin-bottom: 2px;
}

.mouseswitcher {
  /*   border-left: 1px solid #248751; */
  padding-left: 20px;
}

.switcheronheader input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;
}

.slider:before {
  position: absolute;
  content: "";
  height: 13px;
  width: 13px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;
}

input:checked+.slider {
  background-color: #248751;
}

input:focus+.slider {
  box-shadow: 0 0 1px #2196F3;
}

input:checked+.slider:before {
  -webkit-transform: translateX(13px);
  -ms-transform: translateX(13px);
  transform: translateX(13px);
}

.slider.round {
  border-radius: 34px;
}

.slider.round:before {
  border-radius: 50%;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="mouseswitcher">

  <label class="switcheronheader">
                     <input type="checkbox" id="overheaderswitch">
                     <span class="slider round"></span>
                </label>

</div>

【问题讨论】:

    标签: javascript html jquery css mouse-cursor


    【解决方案1】:

    这是你要找的吗?

    a, input, button, .slider, .round {
      margin: 15px;
      cursor:url(https://cdn.shopify.com/s/files/1/0571/7137/8349/files/pointer.png?v=1644096049), auto;
    }
    <input type="button" value="lego"/>
    <a href="http://google.com" target="_blank">link to google.com</a>

    【讨论】:

    • 我以前试过这个,但我希望光标在按钮更改时发生变化......所以需要一些javascript!不过谢谢你的回答:)
    • 如果你熟悉 JavaScript,我们还需要把它放到 javscript 中,所以乐高头(光标)只在 switch 处于活动状态时显示...
    【解决方案2】:

    使用document.querySelector('html') 而不是document.body 将使其工作。

    另外,使用cursor: auto 代替cursor: default

    var cbs = document.querySelectorAll('input[type=checkbox]');
    for (var i = 0; i < cbs.length; i++) {
      cbs[i].addEventListener('change', function() {
        if (this.checked) {
          document.querySelector('html').style.cursor= ' url(https://cdn.shopify.com/s/files/1/0571/7137/8349/files/cursor.png?v=1644096068), auto'
          document.querySelector('label').style.cursor = ' url(https://cdn.shopify.com/s/files/1/0571/7137/8349/files/cursor.png?v=1644096068), auto'
        } else {
           document.querySelector('html').style.cursor = "auto";
          document.querySelector('label').style.cursor = 'auto'
        }
        
      });
    }
    .switcheronheader {
      position: relative;
      display: inline-block;
      width: 30px;
      height: 17px;
      margin-bottom: 2px;
    }
    
    .mouseswitcher {
      /*   border-left: 1px solid #248751; */
      padding-left: 20px;
    }
    
    .switcheronheader input {
      opacity: 0;
      width: 0;
      height: 0;
    }
    
    .slider {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background-color: #ccc;
      -webkit-transition: .4s;
      transition: .4s;
    }
    
    .slider:before {
      position: absolute;
      content: "";
      height: 13px;
      width: 13px;
      left: 2px;
      bottom: 2px;
      background-color: white;
      -webkit-transition: .4s;
      transition: .4s;
    }
    
    input:checked+.slider {
      background-color: #248751;
    }
    
    input:focus+.slider {
      box-shadow: 0 0 1px #2196F3;
    }
    
    input:checked+.slider:before {
      -webkit-transform: translateX(13px);
      -ms-transform: translateX(13px);
      transform: translateX(13px);
    }
    
    .slider.round {
      border-radius: 34px;
    }
    
    .slider.round:before {
      border-radius: 50%;
    }
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
    <div class="mouseswitcher">
    
      <label class="switcheronheader">
                            <input type="checkbox" id="overheaderswitch">
                         <span class="slider round"></span>
                    </label>
    
    </div>
                     

    【讨论】:

    • 好的,非常感谢,我马上试试!
    • 好的,我刚试了下,基本和之前的功能一样,只是鼠标光标变了,重载按钮一直激活,但是光标不显示。。 .. 我们怎样才能改变检查开关的指针?
    • @raffaelbaer,我的问题,没注意问题,更新一下刚才的代码。它应该通过向label 添加样式来覆盖其默认光标样式
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-11-16
    • 2020-05-30
    • 2020-12-30
    • 2018-11-27
    • 1970-01-01
    • 1970-01-01
    • 2022-12-15
    相关资源
    最近更新 更多