jQuery實(shí)現(xiàn)的點(diǎn)擊圖片居中放大縮小功能示例
本文實(shí)例講述了jQuery實(shí)現(xiàn)的點(diǎn)擊圖片居中放大縮小功能。分享給大家供大家參考,具體如下:
該功能是基于jquery實(shí)現(xiàn)的,所以
第一步則是引入jquery
jquery下載地址:https://jquery.com/download/
或者使用此時(shí)調(diào)試的版本(3版本)
jQuery3.2.1文件點(diǎn)擊此處本站下載。
第二步:準(zhǔn)備HTML文件
<div id="outerdiv" class="wrap"> <div id="innerdiv" style="position:absolute;"> <img id="bigimg" style="border:5px solid #fff;" src=""/> </div> </div>
第三步:準(zhǔn)備style
.wrap {
position: fixed;
top: 0;
left: 0;
background: rgba(0, 0, 0, 0.7);
z-index: 2;
width: 100%;
height: 100%;
display: none;
}
第四步:編寫可以放大縮小的js
$(function(){
$(".goal_img").click(function(){
var _this = $(this);//將當(dāng)前的pimg元素作為_(kāi)this傳入函數(shù)
imgShow("#outerdiv", "#innerdiv", "#bigimg", _this);
});
});
實(shí)現(xiàn)的功能
function imgShow(outerdiv, innerdiv, bigimg, _this){
var src = _this.attr("src");//獲取當(dāng)前點(diǎn)擊的pimg元素中的src屬性
$(bigimg).attr("src", src);//設(shè)置#bigimg元素的src屬性
/*獲取當(dāng)前點(diǎn)擊圖片的真實(shí)大小,并顯示彈出層及大圖*/
$("<img/>").attr("src", src).load(function(){
var windowW = $(window).width();//獲取當(dāng)前窗口寬度
var windowH = $(window).height();//獲取當(dāng)前窗口高度
var realWidth = this.width;//獲取圖片真實(shí)寬度
var realHeight = this.height;//獲取圖片真實(shí)高度
var imgWidth, imgHeight;
var scale = 0.8;//縮放尺寸,當(dāng)圖片真實(shí)寬度和高度大于窗口寬度和高度時(shí)進(jìn)行縮放
if(realHeight>windowH*scale) {//判斷圖片高度
imgHeight = windowH*scale;//如大于窗口高度,圖片高度進(jìn)行縮放
imgWidth = imgHeight/realHeight*realWidth;//等比例縮放寬度
if(imgWidth>windowW*scale) {//如寬度扔大于窗口寬度
imgWidth = windowW*scale;//再對(duì)寬度進(jìn)行縮放
}
} else if(realWidth>windowW*scale) {//如圖片高度合適,判斷圖片寬度
imgWidth = windowW*scale;//如大于窗口寬度,圖片寬度進(jìn)行縮放
imgHeight = imgWidth/realWidth*realHeight;//等比例縮放高度
} else {//如果圖片真實(shí)高度和寬度都符合要求,高寬不變
imgWidth = realWidth;
imgHeight = realHeight;
}
$(bigimg).css("width",imgWidth);//以最終的寬度對(duì)圖片縮放
var w = (windowW-imgWidth)/2;//計(jì)算圖片與窗口左邊距
var h = (windowH-imgHeight)/2;//計(jì)算圖片與窗口上邊距
$(innerdiv).css({"top":h, "left":w});//設(shè)置#innerdiv的top和left屬性
$(outerdiv).fadeIn("fast");//淡入顯示#outerdiv及.goal_img
});
$(outerdiv).click(function(){//再次點(diǎn)擊淡出消失彈出層
$(this).fadeOut("fast");
});
}
通過(guò)以上簡(jiǎn)單的基本即可實(shí)現(xiàn)jquery 實(shí)現(xiàn)點(diǎn)擊圖片居住放大縮小。
上述代碼有參考多個(gè)牛人的整理的。僅供學(xué)習(xí)記錄,備后續(xù)開(kāi)發(fā)學(xué)習(xí)使用。
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery圖片操作技巧大全》、《jQuery表格(table)操作技巧匯總》、《jQuery切換特效與技巧總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》及《jquery選擇器用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
- 基于jquery實(shí)現(xiàn)一張圖片點(diǎn)擊鼠標(biāo)放大再點(diǎn)縮小
- jquery實(shí)現(xiàn)頁(yè)面圖片等比例放大縮小功能
- 基于jquery的滾動(dòng)鼠標(biāo)放大縮小圖片效果
- jQuery實(shí)現(xiàn)滾動(dòng)鼠標(biāo)放大縮小圖片的方法(附demo源碼下載)
- 利用jQuery插件imgAreaSelect實(shí)現(xiàn)圖片上傳裁剪(放大縮小)
- jQuery實(shí)現(xiàn)的圖片點(diǎn)擊放大縮小功能案例
- jQuery實(shí)現(xiàn)等比例縮放大圖片讓大圖片自適應(yīng)頁(yè)面布局
- 用JQuery模仿淘寶的圖片放大鏡顯示效果
- jquery圖片放大鏡功能的實(shí)例代碼
- jQuery+css實(shí)現(xiàn)的點(diǎn)擊圖片放大縮小預(yù)覽功能示例【圖片預(yù)覽 查看大圖】
相關(guān)文章
基于daterangepicker日歷插件使用參數(shù)注意的問(wèn)題
下面小編就為大家?guī)?lái)一篇基于daterangepicker日歷插件使用參數(shù)注意的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08
JQuery對(duì)ASP.NET MVC數(shù)據(jù)進(jìn)行更新刪除
這篇文章主要介紹了JQuery對(duì)ASP.NET MVC數(shù)據(jù)進(jìn)行更新刪除的相關(guān)資料,需要的朋友可以參考下2016-07-07
Jquery中的offset()和position()深入剖析
jquery 中有兩個(gè)獲取元素位置的方法offset()和position(),這兩個(gè)方法之間有什么異同?使用的時(shí)候應(yīng)該注意哪些問(wèn)題?什么時(shí)候使用offset(),什么時(shí)候又使用position()呢?2009-05-05
表單類各種類型(文本框)失去焦點(diǎn)效果jquery代碼
基于jquery實(shí)現(xiàn)表單類各種類型(文本框)失去焦點(diǎn)效果,代碼簡(jiǎn)單實(shí)用,感興趣的朋友可以參考下,希望對(duì)你有所幫助2013-04-04
基于jQuery實(shí)現(xiàn)的當(dāng)離開(kāi)頁(yè)面時(shí)出現(xiàn)提示的實(shí)現(xiàn)代碼
基于jQuery實(shí)現(xiàn)的當(dāng)離開(kāi)頁(yè)面時(shí)出現(xiàn)提示的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-06-06
jQuery實(shí)現(xiàn)簡(jiǎn)單隔行變色的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)簡(jiǎn)單隔行變色的方法,涉及jQuery針對(duì)頁(yè)面元素樣式的相關(guān)操作技巧,需要的朋友可以參考下2016-02-02

