使用jQuery怎么實(shí)現(xiàn)一個(gè)點(diǎn)擊圖片居中放大縮小功能?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
成都創(chuàng)新互聯(lián)專注于企業(yè)營(yíng)銷型網(wǎng)站、網(wǎng)站重做改版、長(zhǎng)白網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計(jì)、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為長(zhǎng)白等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
第一步則是引入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" > <img id="bigimg" 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元素作為_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"); }); }
看完上述內(nèi)容,你們掌握使用jQuery怎么實(shí)現(xiàn)一個(gè)點(diǎn)擊圖片居中放大縮小功能的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
新聞標(biāo)題:使用jQuery怎么實(shí)現(xiàn)一個(gè)點(diǎn)擊圖片居中放大縮小功能
瀏覽地址:http://bm7419.com/article2/jcscoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、微信公眾號(hào)、外貿(mào)建站、搜索引擎優(yōu)化、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)