この目的のためだけに jquery ui ライブラリ全体を追加したくない場合があります。私が正しければ、あなたならどうするか。
したがって、その入力に「フォーカス」すると、それを「opensModal」と呼びましょう - モーダルを開く必要があります。「長い」コードにもかかわらず、それは非常に単純で、一目瞭然です。実際、そのほとんどは、モーダル/モーダルの外観をよりきれいにするためのものです。どうぞ:
HTML:
<!-- the input -->
<input class="opensModal" type="text" />
<!-- the modal and its overlay -->
<div class="modalOverlay is-inactive">
<div class="modal">
<input type="checkbox" />
<input type="checkbox" />
<button>Ok</button>
<button>Cancel</button>
</div>
</div>
CSS:
.modalOverlay {
position: fixed;
top: 0;
bottom: 0;
left: 0;
right: 0;
-webkit-transition: 0.6s;
}
.modalOverlay.is-inactive {
visibility: hidden;
background: rgba(0, 0, 0, 0);
}
.modalOverlay.is-active {
visibility: visible;
background: rgba(0, 0, 0, 0.4);
}
.modal {
margin: 100px auto;
background: #fff;
width: 100px;
padding: 20px;
-webkit-transition: 0.4s 0.6s;
}
.modalOverlay.is-inactive .modal {
visibility: hidden;
opacity: 0;
-webkit-transform: scale(0.1);
}
.modalOverlay.is-active .modal {
visibility: visible;
opacity: 1;
-webkit-transform: scale(1);
}
JQUERY(ジャバスクリプト)
(function () {
var $modal = $('.modalOverlay'),
openModal = function () {
$modal
.removeClass('is-inactive')
.addClass('is-active');
},
closeModal = function () { //use it wherever you want
$modal
.removeClass('is-active')
.addClass('is-inactive');
},
onDocReady = function () {
$('.opensModal').on('focus', openModal);
};
$(onDocReady);
})();
ここにフィドルがあります:http://jsfiddle.net/2edPZ/3/