как изменить атрибут проверки ввода

пока я нажимаю username1 в dropdown, переключатель sepc view на правой карточке будет отключен. Но код не работает. html-код:

<div class="container">
  <div class="row row-cols-2">
    <div class="col">
      <div class="card">
        <div class="card-body">
          <div class="dropdown">

            <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown"  aria-haspopup="true" aria-expanded="false">
              Dropdown button
            </button>
            
            <div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
              <a class="dropdown-item" href="#" id="username1">Username1</a>
              <a class="dropdown-item" href="#" id="username2">Username2</a>
              <a class="dropdown-item" href="#" id="username3">Username3</a>
            </div>

          </div>
        </div>
      </div>

    </div>
    <div class="col">
      <div class="card">
        <div class="card-body">
          <div id="switch">

            <label for="fname">Spec View</label>&nbsp&nbsp<input id="specview" type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>

            <label for="fname">Spec Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Attribute Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Operation Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Section Design</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Cat-Template</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Template Design</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Enumeration</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">User Role</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Formula</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Data Mapping</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Operating Log</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
          </div>
        </div>
      </div>
    </div>

  </div>
</div>

js-код:

$(document).ready(function(){
  $("#username1").click(function(){
  var elmnt = document.getElementById("specview");
  var attr = elmnt.getAttributeNode("checked");
  elmnt.removeAttributeNode(attr);
     
  });
});

Переключатель Bootstrap, который я использую:https://www.bootstraptoggle.com/ Ссылка на мой проект:https://codepen.io/nutkin/pen/KKgJNMd


person juexu    schedule 19.01.2021    source источник
comment
Checked — это свойство, установите для него значение false elmnt.checked = false;   -  person epascarello    schedule 19.01.2021


Ответы (3)


Вы смешали javascript с jquery. На самом деле вам нужно использовать класс переключения, чтобы включить выключение примера проекта здесь https://codepen.io/exclutips/pen/qBavRWM

$(document).ready(function(){
  $("#username1").click(function(){
    $('#specview').parent('.toggle').toggleClass('on off');
    $('#specview').removeAttr('checked');
  });
});

$(document).ready(function(){
  $("#username1").click(function(){
    $('#specview').parent('.toggle').toggleClass('on off');
    $('#specview').removeAttr('checked');
  });
});
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://cdn.jsdelivr.net/gh/gitbrent/[email protected]/css/bootstrap4-toggle.min.css" rel="stylesheet"/>

<script src="https://code.jquery.com/jquery-3.5.1.slim.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/umd/popper.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.min.js"></script>
<script src="https://gitcdn.github.io/bootstrap-toggle/2.2.2/js/bootstrap-toggle.min.js"></script>

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/umd/popper.min.js"></script>

<div class="container">
  <div class="row row-cols-2">
    <div class="col">
      <div class="card">
        <div class="card-body">
          <div class="dropdown">

            <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown"  aria-haspopup="true" aria-expanded="false">
              Dropdown button
            </button>
            
            <div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
              <a class="dropdown-item" href="#" id="username1">Username1</a>
              <a class="dropdown-item" href="#" id="username2">Username2</a>
              <a class="dropdown-item" href="#" id="username3">Username3</a>
            </div>

          </div>
        </div>
      </div>

    </div>
    <div class="col">
      <div class="card">
        <div class="card-body">
          <div id="switch">

            <label for="fname">Spec View</label>&nbsp&nbsp<input id="specview" type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>

            <label for="fname">Spec Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Attribute Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Operation Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Section Design</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Cat-Template</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Template Design</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Enumeration</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">User Role</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Formula</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Data Mapping</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Operating Log</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
          </div>
        </div>
      </div>
    </div>

  </div>
</div>

person Firefog    schedule 19.01.2021

Согласно документации:

$('#toggle-demo').bootstrapToggle('on') // Sets the toggle to 'On' state

Следовательно, вам нужно изменить обработчик события click на:

$("#username1").on('click', function(e) {
    $('#specview').bootstrapToggle('on');
});

Фрагмент:

$("#username1").on('click', function(e) {
    $('#specview').bootstrapToggle('on');
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.5.3/css/bootstrap.min.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.5.3/js/bootstrap.bundle.min.js"></script>
<link href="https://gitcdn.github.io/bootstrap-toggle/2.2.2/css/bootstrap-toggle.min.css" rel="stylesheet">
<script src="https://gitcdn.github.io/bootstrap-toggle/2.2.2/js/bootstrap-toggle.min.js"></script>

<div class="container">
  <div class="row row-cols-2">
    <div class="col">
      <div class="card">
        <div class="card-body">
          <div class="dropdown">

            <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown"  aria-haspopup="true" aria-expanded="false">
              Dropdown button
            </button>
            
            <div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
              <a class="dropdown-item" href="#" id="username1">Username1</a>
              <a class="dropdown-item" href="#" id="username2">Username2</a>
              <a class="dropdown-item" href="#" id="username3">Username3</a>
            </div>

          </div>
        </div>
      </div>

    </div>
    <div class="col">
      <div class="card">
        <div class="card-body">
          <div id="switch">

            <label for="fname">Spec View</label>&nbsp&nbsp<input id="specview" type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>

            <label for="fname">Spec Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Attribute Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Operation Edit</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Section Design</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Cat-Template</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Template Design</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Enumeration</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">User Role</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Formula</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Data Mapping</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
            <label for="fname">Operating Log</label>&nbsp&nbsp<input type="checkbox" checked data-toggle="toggle" data-onstyle="info" data-offstyle="light"></br>
          </div>
        </div>
      </div>
    </div>
  </div>
</div>

person gaetanoM    schedule 19.01.2021

Пожалуйста, выполните следующий пример кода:

Проверить

document.getElementById("checkbox").checked = true;

Снять галочку

document.getElementById("checkbox").checked = false;
person Nauman Tariq    schedule 19.01.2021
comment
привет, chechboxэто не идентификатор, getElementById не будет работать, спасибо. - person juexu; 20.01.2021