使用jQuery怎么實(shí)現(xiàn)一個(gè)點(diǎn)擊圖片居中放大縮小功能

使用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)

成都做網(wǎng)站