[解決済み] ボタンやリンクを無効化・有効化する最も簡単な方法とは(jQuery + Bootstrap)
質問
私はボタンのようにスタイルされたアンカーを使うこともあれば、ボタンだけを使うこともあります。特定のクリックを無効にしたいのですが、どうすればいいですか?
- 無効になっているように見える
- クリックされなくなる
どうすればいいのでしょうか?
どのように解決するのですか?
ボタン
ボタンは、以下のように簡単に無効にすることができます。
disabled
はボタンのプロパティで、ブラウザで処理されます。
<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>
jQueryのカスタム関数でこれらを無効化するには、単に
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);
そうでない場合は、jQueryの
prop()
メソッドを使用します。
$('button').prop('disabled', true);
$('button').prop('disabled', false);
アンカータグ
注目すべきは
disabled
は
有効なプロパティ
をアンカータグに使用することができます。このため、Bootstrapはその
.btn
要素を使用します。
.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;
}
このように
[disabled]
プロパティが対象となり、さらに
.disabled
クラスがあります。また
.disabled
クラスは、アンカータグを無効に表示するために必要なものです。
<a href="http://example.com" class="btn">My Link</a>
もちろん、クリックしたときにリンクが機能するのを妨げるものではありません。上記のリンクは
http://example.com
. これを防ぐには、jQuery の簡単なコードを追加して、アンカータグのターゲットを
disabled
クラスを呼び出して
event.preventDefault()
:
$('body').on('click', 'a.disabled', function(event) {
event.preventDefault();
});
をトグルすることができます。
disabled
クラスを使用することで
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);
組み合わせ
次に、上で作成した無効化関数を拡張して、無効化しようとしている要素の種類をチェックするために
is()
. この方法では
toggleClass()
でない場合は
input
または
button
要素を使用するか、または
disabled
プロパティがある場合は
// 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);
さらに注目すべきは、上記の関数がすべての入力タイプで動作することです。
関連
-
[解決済み] ChromeでCSSカスタムスタイルのボタンから青枠を削除する
-
[解決済み] textareaのresizableプロパティを無効にするにはどうしたらよいですか?
-
[解決済み] どのラジオボタンが選択されているかをjQueryで知るにはどうしたらよいですか?
-
[解決済み] HTML5のlocalStorageにオブジェクトを格納する方法は?
-
[解決済み] jQueryで入力を無効化/有効化する?
-
[解決済み] リンクのように動作するHTMLボタンを作成する方法
-
[解決済み] セレクトボックスのプレースホルダーを作成するにはどうすればよいですか?
-
[解決済み] スクロールバーを隠すが、スクロールはできる状態
-
[解決済み] CSSだけでリンクを無効化する方法
-
[解決済み] WebKit の event.layerX と event.layerY に関する問題
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] jQueryでリンクを無効化する
-
[解決済み] クラスメソッド内の "this "をタイプスクリプトで記述する
-
[解決済み] jQueryでdata属性で要素を選択する
-
[解決済み] jQueryの複数要素の同一クリックイベント
-
[解決済み] val()を使ってselectの値を設定しても、jqueryのchangeイベントが発生しないのはなぜですか?
-
[解決済み] jQueryでval()がchange()をトリガーしない
-
[解決済み] jQuery OR Selector?
-
[解決済み] Electron: jQueryが定義されていない
-
[解決済み】jQueryでRSSをパースする。
-
[解決済み】TwitterのBootstrapでボタンを無効化するベストな方法【重複あり