JS實現(xiàn)圖片點擊后出現(xiàn)模態(tài)框效果
很多時候我們在瀏覽圖片時,會發(fā)現(xiàn)點擊圖片后,會彈出一個被點擊圖片的放大圖片浮在頁面上,占滿整個窗口。這就是圖片模態(tài)框效果。
這個效果可以使用某些js庫實現(xiàn),如bpopupJs。但是在這里我們使用純js實現(xiàn),能夠更好理解效果原理和實現(xiàn)方法。
一.實現(xiàn)思路
我們點擊小圖片之后,圖片模態(tài)框出現(xiàn),同時圖片模態(tài)框上有一個關(guān)閉按鈕和圖片的標(biāo)題。
因此,我們的實現(xiàn)思路就是:
圖片模態(tài)框有大圖片,關(guān)閉按鈕,圖片標(biāo)題三部分。
將圖片模態(tài)框隱藏,在點擊小圖片之后,模態(tài)框出現(xiàn)。
點擊關(guān)閉按鈕后,模態(tài)框隱藏。
二.HTML代碼
首先,我們的原始頁面上有一個圖片如下:

HTML代碼如下:
<h2>圖片點擊彈出模態(tài)框效果</h2> <p>圖片模態(tài)框很不錯,是個值得學(xué)習(xí)的效果</p> <img src="star.jpeg" id="real" alt="model test picture">
模態(tài)框的HTML代碼如下:
<div class="motai" id="mo"> <span class="close" id="close">×</span> <img class="motaiimg" id="moimg"> <div id="caption"></div> </div>
三.css代碼
我們需要通過css設(shè)置模態(tài)框中各元素的表現(xiàn)效果同時將其隱藏起來,具體有如下幾步:
1.模態(tài)框
#mo{
display: none;/*隱藏模態(tài)框*/
width: 100%;
height: 100%;
position: fixed;/*定位方式為固定定位*/
overflow: auto;/*不滾動*/
background-color: rgba(0,0,0,0.7);
top: 0px;
left: 0px;
z-index: 1;/*置于頁面圖層之上*/
}
2.關(guān)閉按鈕
.close{
font-size: 40px;
font-weight: bold;
position: absolute;
top: 20px;
right: 14%;
color:#f1f1f1;
}
.close:hover,
.close:focus{
color:#bbb;
cursor:pointer;
}
3.模態(tài)框中圖片
#moimg{
display: block;/*圖片表現(xiàn)為塊*/
margin:25px auto;/*圖片居中對齊*/
width: 60%;
max-width: 750px;/*自適應(yīng)布局*/
}
4.圖片標(biāo)題
#caption{
text-align: center;/*文本居中*/
margin: 15px auto;
width: 60%;
max-height: 750px;
font-size: 20px;
color:#ccc;
}
以上就是基本的模態(tài)框各元素的css代碼,如果想實現(xiàn)點擊后擴大的動畫效果,可以增加以下代碼:
#moimg,#caption{
-webkit-animation: first 1s;
-o-animation: first 1s;
animation: first 1s;
}
@keyframes first{
from{transform: scale(0.1);}
to{transform: scale(1);}
}
通過以上步驟,我們已經(jīng)制作好了模態(tài)框頁面。在使用js來完成交互效果就可以了。
四.js代碼
js代碼主要是圖片和關(guān)閉按鈕的點擊交互,需要注意的是js代碼須位于模態(tài)框HTML代碼之后,js具體代碼如下,:
var motai=document.getElementById('mo')
var moimg=document.getElementById("moimg")
var realimg=document.getElementById("real")
var caption=document.getElementById("caption")
realimg.onclick=function(){
motai.style.display="block"
moimg.src=this.src
caption.innerHTML=this.alt
}
var span=document.getElementById("close");
span.onclick=function(){
motai.style.display="none";
}
通過以上步驟,圖片的模態(tài)框效果就實現(xiàn)了,

最后總的代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>close</title>
<style>
#real{
/*點擊彈出模態(tài)框的圖片*/
margin: 30px;
width: 250px;
border-radius:6px;
}
#real:hover{
opacity: 0.6;
}
#mo{
display: none;/*隱藏*/
width: 100%;
height: 100%;
position: fixed;
overflow: auto;
background-color: rgba(0,0,0,0.7);
top: 0px;
left: 0px;
z-index: 1;
}
#moimg{
display: block;
margin:25px auto;
width: 60%;
max-width: 750px;
}
#caption{
text-align: center;
margin: 15px auto;
width: 60%;
max-height: 750px;
font-size: 20px;
color:#ccc;
}
#moimg,#caption{
-webkit-animation: first 1s;
-o-animation: first 1s;
animation: first 1s;
}
@keyframes first{
from{transform: scale(0.1);}
to{transform: scale(1);}
}
.close{
font-size: 40px;
font-weight: bold;
position: absolute;
top: 20px;
right: 14%;
color:#f1f1f1;
}
.close:hover,
.close:focus{
color:#bbb;
cursor:pointer;
}
@media only screen and(max-width:750px ) {
#moimg{
width: 100%;
}
}
</style>
</head>
<body>
<h2>圖片點擊彈出模態(tài)框效果</h2>
<p>圖片模態(tài)框很不錯,是個值得學(xué)習(xí)的效果</p>
<img src="star.jpeg" id="real" alt="model test picture">
<!--圖片模態(tài)框 -->
<div class="motai" id="mo">
<span class="close" id="close">×</span>
<img class="motaiimg" id="moimg">
<div id="caption"></div>
</div>
<script>
var motai=document.getElementById('mo')
var moimg=document.getElementById("moimg")
var realimg=document.getElementById("real")
var caption=document.getElementById("caption")
realimg.onclick=function(){
motai.style.display="block"
moimg.src=this.src
caption.innerHTML=this.alt
}
var span=document.getElementById("close");
span.onclick=function(){
motai.style.display="none";
}
</script>
</body>
</html>
以上所述是小編給大家介紹的JS實現(xiàn)圖片點擊后出現(xiàn)模態(tài)框效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- AngularJs 彈出模態(tài)框(model)
- js實現(xiàn)簡單模態(tài)框?qū)嵗?/a>
- Vue.js彈出模態(tài)框組件開發(fā)的示例代碼
- js利用事件的阻止冒泡實現(xiàn)點擊空白模態(tài)框的隱藏
- angularJS模態(tài)框$modal實例代碼
- AngularJS中使用ngModal模態(tài)框?qū)嵗?/a>
- bootstrap Validator 模態(tài)框、jsp、表單驗證 Ajax提交功能
- AngularJS模態(tài)框模板ngDialog的使用詳解
- 原生js實現(xiàn)簡單的模態(tài)框示例
- JavaScript+CSS實現(xiàn)模態(tài)框效果
相關(guān)文章
javascript實現(xiàn)鼠標(biāo)選取拖動或Ctrl選取拖動
javascript實現(xiàn)鼠標(biāo)選取拖動或Ctrl選取拖動...2007-06-06
微信小程序 調(diào)用微信授權(quán)窗口相關(guān)問題解決
這篇文章主要介紹了微信小程序 調(diào)用微信授權(quán)窗口相關(guān)問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-07-07
不使用JavaScript實現(xiàn)菜單的打開和關(guān)閉效果demo

