html zaznacz tylko jedno pole wyboru w grupie

126

Jak więc pozwolić użytkownikowi tylko na zaznaczenie tylko jednego pola wyboru?

Wiem, że przyciski radiowe są „idealne”, ale dla moich celów ... tak nie jest.

Mam pole, w którym użytkownicy muszą wybrać jedną lub dwie opcje, ale nie obie. Problem polega na tym, że potrzebuję, aby moi użytkownicy również mogli odznaczyć swoją opcję, a tutaj przyciski radiowe zawodzą, ponieważ po wybraniu grupy musisz wybrać opcję.

Będę sprawdzać informacje przez php, ale nadal chciałbym ograniczyć użytkowników do jednej odpowiedzi, jeśli chcą jej udzielić.

user962449
źródło
1
Nie można tego zrobić tylko w przypadku HTML. Będziesz potrzebował JavaScript. Jeśli jesteś otwarty na jQuery, mogę szybko rozwiązać problem.
Surreal Dreams,
12
A co z dodatkowym przyciskiem opcji oznaczonym „brak”?
FelipeAls,
2
trzecia opcja nie
pasuje do
2
Pole wyboru z pojedynczym wyborem to w rzeczywistości przycisk opcji. Czy to nie zaskoczy użytkowników?
Gherman,
@Surreal Dreams Można to zrobić w HTML, zobacz moją odpowiedź. Jednak w większości przypadków ten JS jest prostszy i nie ma potrzeby hackowania.
SamGoody

Odpowiedzi:

179

Ten fragment kodu:

  • Zezwalaj na grupowanie, takie jak przyciski radiowe
  • Zachowuj się jak radio
  • Zezwalaj na odznaczanie wszystkich

// the selector will match all input controls of type :checkbox
// and attach a click event handler 
$("input:checkbox").on('click', function() {
  // in the handler, 'this' refers to the box clicked on
  var $box = $(this);
  if ($box.is(":checked")) {
    // the name of the box is retrieved using the .attr() method
    // as it is assumed and expected to be immutable
    var group = "input:checkbox[name='" + $box.attr("name") + "']";
    // the checked state of the group/box on the other hand will change
    // and the current value is retrieved using .prop() method
    $(group).prop("checked", false);
    $box.prop("checked", true);
  } else {
    $box.prop("checked", false);
  }
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>


<div>
  <h3>Fruits</h3>
  <label>
    <input type="checkbox" class="radio" value="1" name="fooby[1][]" />Kiwi</label>
  <label>
    <input type="checkbox" class="radio" value="1" name="fooby[1][]" />Jackfruit</label>
  <label>
    <input type="checkbox" class="radio" value="1" name="fooby[1][]" />Mango</label>
</div>
<div>
  <h3>Animals</h3>
  <label>
    <input type="checkbox" class="radio" value="1" name="fooby[2][]" />Tiger</label>
  <label>
    <input type="checkbox" class="radio" value="1" name="fooby[2][]" />Sloth</label>
  <label>
    <input type="checkbox" class="radio" value="1" name="fooby[2][]" />Cheetah</label>
</div>

bPratik
źródło
3
Prawidłowym użyciem byłoby użycie $ (this) .is (": zaznaczone") the "is", aby sprawdzić, czy pole wyboru było zaznaczone w if {...} else {...} tutaj ... jsfiddle .net / zGEaa / 31
sergioadh
2
Zauważ, że .attr już nie działa. Zamiast tego użyj .prop („zaznaczone”) dla nowszych wersji jQuery
user871784
@ user871784 - Dzięki za ostrzeżenie ... Zaktualizowałem skrzypce!
bPratik
3
Przegapiłeś selektor radia: $ ("input: checkbox.radio")
Sven
@Sven - w tym przykładzie byłby to zbyt szczegółowy selektor. Powiedziawszy, że jeśli strona zawiera inny zestaw pól wyboru, które nie powinny mieć takiego zachowania, .radiopomocne byłoby użycie selektora. Dzięki za zwrócenie uwagi :)
bPratik
101

Chciałbyś powiązać change()procedurę obsługi, aby zdarzenie było uruchamiane, gdy zmieni się stan pola wyboru. Następnie odznacz wszystkie pola wyboru oprócz tego, który uruchomił handler:

$('input[type="checkbox"]').on('change', function() {
   $('input[type="checkbox"]').not(this).prop('checked', false);
});

Oto skrzypce


Jeśli chodzi o grupowanie, jeśli wszystkie pola wyboru „grupy” były rodzeństwem:

<div>
    <input type="checkbox" />
    <input type="checkbox" />
    <input type="checkbox" />
</div>  
<div>
    <input type="checkbox" />
    <input type="checkbox" />
    <input type="checkbox" />
</div>   
<div>
    <input type="checkbox" />
    <input type="checkbox" />
    <input type="checkbox" />
</div>

Możesz to zrobić:

$('input[type="checkbox"]').on('change', function() {
   $(this).siblings('input[type="checkbox"]').prop('checked', false);
});

Oto kolejne skrzypce


Jeśli pola wyboru są zgrupowane według innego atrybutu, takiego jak name:

<input type="checkbox" name="group1[]" />
<input type="checkbox" name="group1[]" />
<input type="checkbox" name="group1[]" />

<input type="checkbox" name="group2[]" />
<input type="checkbox" name="group2[]" />
<input type="checkbox" name="group2[]" />

<input type="checkbox" name="group3[]" />
<input type="checkbox" name="group3[]" />
<input type="checkbox" name="group3[]" />

Możesz to zrobić:

$('input[type="checkbox"]').on('change', function() {
    $('input[name="' + this.name + '"]').not(this).prop('checked', false);
});

Oto kolejne skrzypce

billyonecan
źródło
Podoba mi się twój (ostatni) kod. Bardzo krótkie i nadal wyraźne. Nie byłem pewien, czy „zmiana” włączy się, gdy zmienisz inne pola wyboru, ale tak się nie stało, gdy spróbowałem. Więc wolę twój kod. Dzięki! :)
Frank Fajardo
Bardzo mi się to podoba, muszę zrobić drobną poprawkę dla moich potrzeb. Mam dwa elementy, więc pierwszy element jest domyślnie zaznaczony, a jeśli nie jest zaznaczony, drugi element zostaje zaznaczony. To pomogło mi zacząć.
john.weland
Cześć @ john.weland - masz na myśli coś jak to ?
billyonecan
@billyonecan prawie dokładnie, ale z możliwością kierowania na daną grupę. w ten sposób . Dzięki
john.weland
2
plus jeden za prostotę
Czad
26

Przyciski radiowe są idealne. Potrzebujesz tylko trzeciej opcji „żadne”, która jest zaznaczona domyślnie.

Quentin
źródło
1
To dobre rozwiązanie, ale wolę trzymać się pól wyboru, ponieważ mój projekt nie jest idealny dla trzeciej opcji.
user962449
6
Zdecydowanie sugerowałbym zmianę projektu. Zaznacz 0 lub 1 z tych 2 opcji nie jest powszechnym wzorcem i nie będzie tak intuicyjne dla użytkowników, jak zaznaczenie 1 z tych 3 opcji
Quentin
4
dlaczego miałbym zmieniać cały projekt na 2 pola wyboru?
user962449,
9
Jeśli taka zmiana wymagałaby zmiany „całego projektu”, to sugeruje, że projekt jest zdecydowanie zbyt nieelastyczny.
Quentin,
10
Nie jest nieelastyczny, po prostu nie wygląda dobrze ... Może wyglądać dobrze na formularzach i takich aplikacjach, ale mamy różne zastosowania dla naszych pól wyboru.
user962449
13

Istnieje już kilka odpowiedzi na to pytanie opartych na czystym JS, ale żadna z nich nie jest tak zwięzła, jak bym chciał.

Oto moje rozwiązanie oparte na użyciu tagów nazw (podobnie jak w przypadku przycisków opcji) i kilku wierszach kodu JavaScript.

function onlyOne(checkbox) {
    var checkboxes = document.getElementsByName('check')
    checkboxes.forEach((item) => {
        if (item !== checkbox) item.checked = false
    })
}
<input type="checkbox" name="check" onclick="onlyOne(this)">
<input type="checkbox" name="check" onclick="onlyOne(this)">
<input type="checkbox" name="check" onclick="onlyOne(this)">
<input type="checkbox" name="check" onclick="onlyOne(this)">

Evertvdw
źródło
Dziękuję, ten zrobił to dla mnie od wszystkich innych =)
kaya
6
$("#myform input:checkbox").change(function() {
    $("#myform input:checkbox").attr("checked", false);
    $(this).attr("checked", true);
});

Powinno to działać dla dowolnej liczby pól wyboru w formularzu. Jeśli masz inne osoby, które nie są częścią grupy, skonfiguruj selektory odpowiednie wejścia.

Surreal Dreams
źródło
tak proszę pana :) W porządku, znalazłem coś, co działa dla mnie, chociaż twoje rozwiązanie wygląda dość prosto. Prawdopodobnie zrobiłem coś złego ze swojej strony. W każdym razie dzięki.
user962449,
5

Oto proste rozwiązanie HTML i JavaScript, które preferuję:

// funkcja js, aby umożliwić sprawdzanie tylko jednego pola wyboru dnia tygodnia na raz:

function checkOnlyOne(b){

var x = document.getElementsByClassName('daychecks');
var i;

for (i = 0; i < x.length; i++) {
  if(x[i].value != b) x[i].checked = false;
}
}


Day of the week:
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Monday" />Mon&nbsp;&nbsp;&nbsp;
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Tuesday" />Tue&nbsp;&nbsp;&nbsp;
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Wednesday" />Wed&nbsp;&nbsp;&nbsp;
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Thursday" />Thu&nbsp;&nbsp;&nbsp;
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Friday" />Fri&nbsp;&nbsp;&nbsp;
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Saturday" />Sat&nbsp;&nbsp;&nbsp;
<input class="daychecks" onclick="checkOnlyOne(this.value);" type="checkbox" name="reoccur_weekday" value="Sunday" />Sun&nbsp;&nbsp;&nbsp;<br /><br />
Ian z Jafty.com
źródło
4

Niech ten kod ci pomoże.

$(document).ready(function(){
$('.slectOne').on('change', function() {
   $('.slectOne').not(this).prop('checked', false);
   $('#result').html($(this).data( "id" ));
   if($(this).is(":checked"))
   	$('#result').html($(this).data( "id" ));
   else
   	$('#result').html('Empty...!');
});
});
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>

</head>
<body>
<input type="checkbox" class="slectOne" data-id="1 selected"/>
<input type="checkbox" class="slectOne" data-id="2 selected"/>
<input type="checkbox" class="slectOne" data-id="3 selected"/>
<input type="checkbox" class="slectOne" data-id="4 selected"/>
<input type="checkbox" class="slectOne" data-id="5 selected"/>
<input type="checkbox" class="slectOne" data-id="6 selected"/>
<input type="checkbox" class="slectOne" data-id="7 selected"/>
<input type="checkbox" class="slectOne" data-id="8 selected"/>
<input type="checkbox" class="slectOne" data-id="9 selected"/>
<input type="checkbox" class="slectOne" data-id="10 selected"/>
<span id="result"></span>
</body>
</html>

Link roboczy Kliknij tutaj

Om Shankar
źródło
3

Opierając się na odpowiedzi Billyonecana , możesz użyć następującego kodu, jeśli potrzebujesz tego fragmentu dla więcej niż jednego pola wyboru (zakładając, że mają one różne nazwy).

    $('input.one').on('change', function() {
        var name = $(this).attr('name');
        $('input[name='+name+'].one').not(this).prop('checked', false);
    }); 
tcastrog10
źródło
3

Chociaż prawdopodobnie najlepszym rozwiązaniem jest JS, można to zrobić tylko za pomocą HTML i CSS.

Tutaj masz fałszywy przycisk opcji, który jest tak naprawdę etykietą prawdziwego ukrytego przycisku opcji. W ten sposób uzyskasz dokładnie taki efekt, jakiego potrzebujesz.

<style>
   #uncheck>input { display: none }
   input:checked + label { display: none }
   input:not(:checked) + label + label{ display: none } 
</style>

<div id='uncheck'>
  <input type="radio" name='food' id="box1" /> 
  Pizza 
    <label for='box1'>&#9678;</label> 
    <label for='box0'>&#9673;</label>
  <input type="radio" name='food' id="box2" /> 
  Ice cream 
    <label for='box2'>&#9678;</label> 
    <label for='box0'>&#9673;</label>
  <input type="radio" name='food' id="box0" checked />
</div>

Zobacz to tutaj: https://jsfiddle.net/tn70yxL8/2/

To zakłada, że ​​potrzebujesz etykiet, których nie można wybrać.

Jeśli chcesz dołączyć etykiety, możesz technicznie uniknąć powtarzania etykiety „odznacz”, zmieniając jej tekst w CSS, zobacz tutaj: https://jsfiddle.net/7tdb6quy/2/

SamGoody
źródło
1

Przykład z AngularJs

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<!DOCTYPE html>
<html>

<head>
  <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
  <script>
    angular.module('app', []).controller('appc', ['$scope',
      function($scope) {
        $scope.selected = 'other';
      }
    ]);
  </script>
</head>

<body ng-app="app" ng-controller="appc">
  <label>SELECTED: {{selected}}</label>
  <div>
    <input type="checkbox" ng-checked="selected=='male'" ng-true-value="'male'" ng-model="selected">Male
    <br>
    <input type="checkbox" ng-checked="selected=='female'" ng-true-value="'female'" ng-model="selected">Female
    <br>
    <input type="checkbox" ng-checked="selected=='other'" ng-true-value="'other'" ng-model="selected">Other
  </div>



</body>

</html>

DAS
źródło
1

Za pomocą zwykłego, starego javascript.

<html>
<head>
</head>
<body>
<input type="checkbox" name="group1[]" id="groupname1" onClick="toggle(1,'groupname')"/>
<input type="checkbox" name="group1[]" id="groupname2" onClick="toggle(2,'groupname')"  />
<input type="checkbox" name="group1[]" id="groupname3" onClick="toggle(3,'groupname')" />

<input type="checkbox" name="group2[]" id="diffGroupname1" onClick="toggle(1,'diffGroupname')"/>
<input type="checkbox" name="group2[]" id="diffGroupname2" onClick="toggle(2,'diffGroupname')"  />
<input type="checkbox" name="group2[]" id="diffGroupname3" onClick="toggle(3,'diffGroupname')" />
<script>
function toggle(which,group){
var counter=1;
var checkbox=document.getElementById(group+counter);
while(checkbox){
if(counter==which){

}else{
checkbox.checked=false;
}
counter++;
checkbox=document.getElementById(group+counter);
}
}
</script>
</body>
</html>

edycja: również możliwa

<html>
<head>
</head>
<body>
<input type="checkbox" name="group1[]" class="groupname" onClick="toggle(this,'groupname')"/>
<input type="checkbox" name="group1[]" class="groupname" onClick="toggle(this,'groupname')"  />
<input type="checkbox" name="group1[]" class="groupname" onClick="toggle(this,'groupname')" />

<input type="checkbox" name="group2[]" class="diffGroupname" onClick="toggle(this,'diffGroupname')"/>
<input type="checkbox" name="group2[]" class="diffGroupname" onClick="toggle(this,'diffGroupname')"  />
<input type="checkbox" name="group2[]" class="diffGroupname" onClick="toggle(this,'diffGroupname')" />
<script>
function toggle(which,theClass){
var checkbox=document.getElementsByClassName(theClass);
for(var i=0;i<checkbox.length;i++){
if(checkbox[i]==which){

}else{
checkbox[i].checked=false;
}
}
}
</script>
</body>
</html>
Solomon P. Byer
źródło
0

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<!DOCTYPE html>
<html>

<head>
  <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
  <script>
    angular.module('app', []).controller('appc', ['$scope',
      function($scope) {
        $scope.selected = 'male';
      }
    ]);
  </script>
</head>

<body ng-app="app" ng-controller="appc">
  <label>SELECTED: {{selected}}</label>
  <div>
    <input type="checkbox" ng-checked="selected=='male'" ng-true-value="'male'" ng-model="selected">Male
    <br>
    <input type="checkbox" ng-checked="selected=='female'" ng-true-value="'female'" ng-model="selected">Female
    <br>
    <input type="checkbox" ng-checked="selected=='other'" ng-true-value="'other'" ng-model="selected">Other
  </div>
</body>
</html>

Mahesh
źródło
0

Jeśli ktoś potrzebuje rozwiązania bez zewnętrznych bibliotek javascript, może skorzystać z tego przykładu. Grupa pól wyboru umożliwiających wartości 0..1. Możesz kliknąć komponent pola wyboru lub powiązany tekst etykiety.

    <input id="mygroup1" name="mygroup" type="checkbox" value="1" onclick="toggleRadioCheckbox(this)" /> <label for="mygroup1">Yes</label>
    <input id="mygroup0" name="mygroup" type="checkbox" value="0" onclick="toggleRadioCheckbox(this)" /> <label for="mygroup0">No</label>

- - - - - - - - 

    function toggleRadioCheckbox(sender) {
        // RadioCheckbox: 0..1 enabled in a group 
        if (!sender.checked) return;
        var fields = document.getElementsByName(sender.name);
        for(var idx=0; idx<fields.length; idx++) {
            var field = fields[idx];
            if (field.checked && field!=sender)
                field.checked=false;
        }
    }
Kto ja
źródło
0

Moja wersja: użyj atrybutów danych i Vanilla JavaScript

<div class="test-checkbox">
    Group One: <label>
        <input type="checkbox" data-limit="only-one-in-a-group" name="groupOne" value="Eat" />Eat</label>
    <label>
        <input type="checkbox" data-limit="only-one-in-a-group" name="groupOne" value="Sleep" />Sleep</label>
    <label>
        <input type="checkbox" data-limit="only-one-in-a-group" name="groupOne" value="Play" />Play</label>
    <br />
    Group Two: <label>
        <input type="checkbox" data-limit="only-one-in-a-group" name="groupTwo" value="Fat" />Fat</label>
    <label>
        <input type="checkbox" data-limit="only-one-in-a-group" name="groupTwo" value="Comfort" />Comfort</label>
    <label>
        <input type="checkbox" data-limit="only-one-in-a-group" name="groupTwo" value="Happy" />Happy</label>
</div>
<script>
    let cbxes = document.querySelectorAll('input[type="checkbox"][data-limit="only-one-in-a-group"]');
    [...cbxes].forEach((cbx) => {
        cbx.addEventListener('change', (e) => {
            if (e.target.checked)
                uncheckOthers(e.target);
        });
    });
    function uncheckOthers (clicked) {
        let name = clicked.getAttribute('name');
        // find others in same group, uncheck them
        [...cbxes].forEach((other) => {
            if (other != clicked && other.getAttribute('name') == name)
                other.checked = false;
        });
    }
</script>
benbai123
źródło
-1

Nekromancja:
I bez jQuery, dla takiej struktury pola wyboru:

<label>
<input type="checkbox" id="mytrackers_1" name="blubb_1" value="">--- Bitte ausw&#228;hlen ---
</label>
<label>
<input type="checkbox" id="mytrackers_2" name="blubb_2" value="7">Testtracker
</label>
<label>
<input type="checkbox" id="mytrackers_3" name="blubb_3" value="3">Kundenanfrage
</label>
<label>
<input type="checkbox" id="mytrackers_4" name="blubb_4" value="2">Anpassung
</label>
<label>
<input type="checkbox" id="mytrackers_5" name="blubb_5" value="1" checked="checked" >Fehler
</label>
<label>
<input type="checkbox" id="mytrackers_6" name="blubb_6" value="4">Bedienung
</label>
<label>
<input type="checkbox" id="mytrackers_7" name="blubb_7" value="5">Internes
</label>
<label>
<input type="checkbox" id="mytrackers_8" name="blubb_8" value="6">&#196;nderungswunsch
</label>

zrobiłbyś to tak:

    /// attach an event handler, now or in the future, 
    /// for all elements which match childselector,
    /// within the child tree of the element maching parentSelector.
    function subscribeEvent(parentSelector, eventName, childSelector, eventCallback) {
        if (parentSelector == null)
            throw new ReferenceError("Parameter parentSelector is NULL");
        if (childSelector == null)
            throw new ReferenceError("Parameter childSelector is NULL");
        // nodeToObserve: the node that will be observed for mutations
        var nodeToObserve = parentSelector;
        if (typeof (parentSelector) === 'string')
            nodeToObserve = document.querySelector(parentSelector);
        var eligibleChildren = nodeToObserve.querySelectorAll(childSelector);
        for (var i = 0; i < eligibleChildren.length; ++i) {
            eligibleChildren[i].addEventListener(eventName, eventCallback, false);
        } // Next i 
        // /programming/2712136/how-do-i-make-this-loop-all-children-recursively
        function allDescendants(node) {
            if (node == null)
                return;
            for (var i = 0; i < node.childNodes.length; i++) {
                var child = node.childNodes[i];
                allDescendants(child);
            } // Next i 
            // IE 11 Polyfill 
            if (!Element.prototype.matches)
                Element.prototype.matches = Element.prototype.msMatchesSelector;
            if (node.matches) {
                if (node.matches(childSelector)) {
                    // console.log("match");
                    node.addEventListener(eventName, eventCallback, false);
                } // End if ((<Element>node).matches(childSelector))
                // else console.log("no match");
            } // End if ((<Element>node).matches) 
            // else console.log("no matchfunction");
        } // End Function allDescendants 
        // Callback function to execute when mutations are observed
        var callback = function (mutationsList, observer) {
            for (var _i = 0, mutationsList_1 = mutationsList; _i < mutationsList_1.length; _i++) {
                var mutation = mutationsList_1[_i];
                // console.log("mutation.type", mutation.type);
                // console.log("mutation", mutation);
                if (mutation.type == 'childList') {
                    for (var i = 0; i < mutation.addedNodes.length; ++i) {
                        var thisNode = mutation.addedNodes[i];
                        allDescendants(thisNode);
                    } // Next i 
                } // End if (mutation.type == 'childList') 
                // else if (mutation.type == 'attributes') { console.log('The ' + mutation.attributeName + ' attribute was modified.');
            } // Next mutation 
        }; // End Function callback 
        // Options for the observer (which mutations to observe)
        var config = { attributes: false, childList: true, subtree: true };
        // Create an observer instance linked to the callback function
        var observer = new MutationObserver(callback);
        // Start observing the target node for configured mutations
        observer.observe(nodeToObserve, config);
    } // End Function subscribeEvent 


    function radioCheckbox_onClick() 
    { 
        // console.log("click", this);
        let box = this;
        if (box.checked) 
        {
            let name = box.getAttribute("name");
            let pos = name.lastIndexOf("_");
            if (pos !== -1) name = name.substr(0, pos);

            let group = 'input[type="checkbox"][name^="' + name + '"]';
            // console.log(group);
            let eles = document.querySelectorAll(group);
            // console.log(eles);
            for (let j = 0; j < eles.length; ++j) 
            {
                eles[j].checked = false;
            }
            box.checked = true;
        }
        else
            box.checked = false;
    }


    // /programming/9709209/html-select-only-one-checkbox-in-a-group
    function radioCheckbox()
    { 
        // on instead of document...
        let elements = document.querySelectorAll('input[type="checkbox"]')

        for (let i = 0; i < elements.length; ++i)
        {
            // console.log(elements[i]);
            elements[i].addEventListener("click", radioCheckbox_onClick, false);

        } // Next i 

    } // End Function radioCheckbox 


    function onDomReady()
    {
        console.log("dom ready");
        subscribeEvent(document, "click", 
            'input[type="checkbox"]', 
            radioCheckbox_onClick
        ); 

        // radioCheckbox();
    }

    if (document.addEventListener) document.addEventListener("DOMContentLoaded", onDomReady, false);
    else if (document.attachEvent) document.attachEvent("onreadystatechange", onDomReady);
    else window.onload = onDomReady;

    function onPageLoaded() {
        console.log("page loaded");
    }

    if (window.addEventListener) window.addEventListener("load", onPageLoaded, false);
    else if (window.attachEvent) window.attachEvent("onload", onPageLoaded);
    else window.onload = onPageLoaded;
Stefan Steiger
źródło
-1
//Here is a solution using JQuery    
<input type = "checkbox" class="a"/>one
    <input type = "checkbox" class="a"/>two
    <input type = "checkbox" class="a"/>three
    <script>
       $('.a').on('change', function() {
            $('.a').not(this).prop('checked',false);
    });
    </script>
Tabish Zaman
źródło