【JS】モーダルウィンドウのテンプレート(jQuery使用)
JavaScriptでモーダルウィンドウを表示させるテンプレートです。jQueryを使用しています。
javascriptでのコントロールのため、モーダル内のコンテンツは自由にコントロールができます。
DEMO
HTML
<link rel="stylesheet" href="css/modal.css" />
<!-- modal -->
<div class="modal_wrap">
<input id="modal_trigger" type="checkbox">
<div class="modal_overlay">
<label id="modal_label" for="trigger" class="modal_trigger"></label>
<div class="modal_content">
コンテンツ
</div>
</div>
</div>
<!-- end modal -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="js/modal.js"></script>
css
.modal_wrap input{
display: none;
}
.modal_overlay{
display: flex;
justify-content: center;
overflow: auto;
position: fixed;
top: 0;
left: 0;
z-index: 9999;
width: 100%;
height: 100%;
background: rgba(0,0,0,0.7);
opacity: 0;
transition: opacity 0.5s, transform 0s 0.5s;
transform: scale(0);
}
.modal_trigger{
position: absolute;
width: 100%;
height: 100%;
}
.modal_content{
align-self: flex-start;
width: 80%;
padding: 30px 30px 15px;
box-sizing: border-box;
background: #fff;
line-height: 1.4em;
transform: translateY(-100%);
transition: 0.5s;
}
.modal_wrap input:checked ~ .modal_overlay{
opacity: 1;
transform: scale(1);
transition: opacity 0.5s;
}
.modal_wrap input:checked ~ .modal_overlay .modal_content{
transform: translateY(10%);
}
@media screen and (max-width:750px){
.map_frame{
height: 800px;
max-width: 940px;
width: 100%;
margin-top:-200px;
}
.mapArea{
text-align: center;
height: 360px;
max-width: 640px;
width: 100%;
margin: auto;
overflow:hidden;
}
}
java script
$(function() {
$('#product-btn1').on('click', function() {
$("#modal_trigger").prop('checked', true);
});
$("#modal_label").on('click', function() {
$("#modal_trigger").prop('checked', false);
});
});
ディスカッション
コメント一覧
まだ、コメントがありません