guziki
Przyciski można łatwo wyłączyć, podobnie jak disabled
właściwość przycisku obsługiwana przez przeglądarkę:
<input type="submit" class="btn" value="My Input Submit" disabled/>
<input type="button" class="btn" value="My Input Button" disabled/>
<button class="btn" disabled>My Button</button>
Aby je wyłączyć za pomocą niestandardowej funkcji jQuery, wystarczy skorzystać z fn.extend()
:
// Disable function
jQuery.fn.extend({
disable: function(state) {
return this.each(function() {
this.disabled = state;
});
}
});
// Disabled with:
$('input[type="submit"], input[type="button"], button').disable(true);
// Enabled with:
$('input[type="submit"], input[type="button"], button').disable(false);
JSFiddle wyłączony przycisk i wejście demo .
W przeciwnym razie skorzystasz z prop()
metody jQuery :
$('button').prop('disabled', true);
$('button').prop('disabled', false);
Tagi kotwiczne
Warto zauważyć, że disabled
nie jest to poprawna właściwość tagów zakotwiczenia. Z tego powodu Bootstrap używa następującej stylizacji na swoich .btn
elementach:
.btn.disabled, .btn[disabled] {
cursor: default;
background-image: none;
opacity: 0.65;
filter: alpha(opacity=65);
-webkit-box-shadow: none;
-moz-box-shadow: none;
box-shadow: none;
color: #333;
background-color: #E6E6E6;
}
Zwróć uwagę, w jaki sposób [disabled]
właściwość jest kierowana, a także .disabled
klasa. .disabled
Klasa to, co jest potrzebne, aby znacznik kotwica pojawiają wyłączone.
<a href="http://example.com" class="btn">My Link</a>
Oczywiście nie uniemożliwi to działania linków po kliknięciu. Powyższy link przeniesie nas na http://example.com . Aby temu zapobiec, możemy dodać prosty fragment kodu jQuery, aby kierować tagi zakotwiczenia za pomocą disabled
klasy do wywołania event.preventDefault()
:
$('body').on('click', 'a.disabled', function(event) {
event.preventDefault();
});
Możemy przełączać disabled
klasę za pomocą toggleClass()
:
jQuery.fn.extend({
disable: function(state) {
return this.each(function() {
var $this = $(this);
$this.toggleClass('disabled', state);
});
}
});
// Disabled with:
$('a').disable(true);
// Enabled with:
$('a').disable(false);
Demo JDLiddle wyłączone łącze .
Łączny
Następnie możemy rozszerzyć poprzednią funkcję wyłączania wykonaną powyżej, aby sprawdzić typ elementu, którego próbujemy wyłączyć is()
. W ten sposób możemy toggleClass()
, jeśli nie jest to input
czy button
element lub przełączyć disabled
nieruchomości jeśli jest to:
// Extended disable function
jQuery.fn.extend({
disable: function(state) {
return this.each(function() {
var $this = $(this);
if($this.is('input, button, textarea, select'))
this.disabled = state;
else
$this.toggleClass('disabled', state);
});
}
});
// Disabled on all:
$('input, button, a').disable(true);
// Enabled on all:
$('input, button, a').disable(false);
W pełni połączone demo JSFiddle .
Warto ponadto zauważyć, że powyższa funkcja będzie działać również na wszystkich typach wejść.