亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JS實例教程:制作圖片放大特效

2024-09-06 12:41:01
字體:
來源:轉載
供稿:網友

效果:

運行代碼框

[ctrl+a 全部選擇 提示:你可先修改部分代碼,再按運行]

以前寫過一個jquery的圖片放大效果,但是存在著一些小問題,然后最近有時間重寫了一遍,做了很詳盡的改進.改進了大部分bug,而且不采用jquery.

程序說明

主要為magnifier類,里面的主要方法有:

  • init:運行方法
  • start:則是鼠標移入div的事件處理
  • move:則是鼠標在div中移動的事件處理
  • end:鼠標移出后的事件處理

程序介紹

主要思維:當鼠標移入圖片的時候,放大層的div出現,然后根據鼠標移動狀況,改變放大層內圖像的top值和left值,使得2個地方保持一致的現實。而2個圖像跟據比例進行設置,width和height值,使之產生放大的效果,下面進行詳細的解釋:

在init方法中,主要處理瀏覽框div層的大小,放大框的大小和放大的圖像大小。
瀏覽框div的width和height跟據,原始圖片的大小/比例值可以獲得,見代碼:

css(m.cont.getelementsbytagname('div')[0],{        //m.cont.getelementsbytagname('div')[0]為瀏覽框
    'display' : 'none',                //開始設置為不可見
    'width' : m.cont.clientwidth / m.scale - borderwid + 'px',    //原始圖片的寬/比例值 - border的寬度
    'height' : m.cont.clientheight / m.scale - borderwid + 'px',    ////原始圖片的高/比例值 - border的寬度
    'opacity' : 0.5                    //設置透明度
})

放大框的大小則設置為于原始圖像相同大小,代碼如下:

css(m.mag,{
    'display' : 'none',
    'width' : m.cont.clientwidth + 'px',        //m.cont為原始圖像
    'height' : m.cont.clientheight + 'px',
    'position' : 'absolute',
    'left' : m.cont.offsetleft + m.cont.offsetwidth + 10 + 'px',    //放大框的位置為原始圖像的右方遠10px
    'top' : m.cont.offsettop + 'px'
})

放大的圖像大小為,原始圖像大小*比例值,代碼如下:

css(m.img,{
    'position' : 'absolute',
    'width' : (m.cont.clientwidth * m.scale) + 'px',    //原始圖像的寬*比例值
    'height' : (m.cont.clientheight * m.scale) + 'px'    //原始圖像的高*比例值
})

由于放大是根據比例進行放大,所以在瀏覽框上和放大圖像上需要仔細計算,這也就是該程序的主要思維之一。

|||

在第一次寫的程序里,直接省去了onmouseover,因為直接使用onmousemove就可以滿足功能。而這次使用onmouseover是為了避免在使用過程中遇到select,在ie6下,select無法設置z-index值,使得放大框的突然出現卻無法覆蓋select。詳細下面在討論,

在move方法中,最重要的就是如果做到鼠標移動過程中,瀏覽框隨著鼠標移動的同時,放大圖像也跟著運動,,使得放大圖像所顯示的范圍與瀏覽框所在原始圖像位置一致。

先說說瀏覽框跟隨鼠標移動,主要代碼如下:

top:pos.y - this.offsettop - parseint(this.getelementsbytagname('div')[0].style.height) / 2
left:pos.x - this.offsetleft - parseint(this.getelementsbytagname('div')[0].style.width) / 2

由于是,對m.cont綁定事件,所以這個時候this指向m.cont。

由圖像可以得知left=鼠標x - this.offsetleft - 瀏覽框寬/2,所以跟據該幾何思想可以得出而代碼,而top的值也是根據一樣的道理所得,這里就不做詳細解釋了。接下來就是在鼠標運動的同時,放大圖像也要跟著改變top和left值,代碼如下:

css(magnifier.m.img,{
    'top' : - (parseint(this.getelementsbytagname('div')[0].style.top) * magnifier.m.scale) + 'px',
    'left' : - (parseint(this.getelementsbytagname('div')[0].style.left) * magnifier.m.scale) + 'px'
})

代碼很清晰的可以得出,只需要在瀏覽框的top和left值上*比例就可以了。而加上負號的原因是默認坐標為(0,0),而在移動過程中,始坐標只會向負方向移動。
在該方法中有2個需要注意的地方:

1.

this.getelementsbytagname('div')[0].style.display = '';

應該放在設置this.getelementsbytagname('div')[0]的top與left之前,原因是如果display為none的話,無法獲取其寬和高。如果把display = ''放在設置top與left之后,會出現一個奇怪的現象,大家可以試下,該問題一直困擾了我很久,在多次嘗試中才發現問題再這上面。奇怪現象如下:

2.

'top' : math.min(math.max(pos.y - this.offsettop - parseint(this.getelementsbytagname('div')[0].style.height) / 2,0),this.clientheight - this.getelementsbytagname('div')[0].offsetheight) + 'px';

這么長的代碼可能讓人很困惑,我只是用math.max()和math.min()去避免了采用if語句,自己偷了點懶,就是為了實現瀏覽框不會超出原始圖像而已,仔細看看就清楚啦。

end方法很清晰,就是瀏覽框和放大框進行隱藏。

|||

[覆蓋select]

在為了在ie6下可以覆蓋select,我加入了2個放法createiframe和removeiframe。分別是在onmouseover事件里創建一個iframe和在onmouseout里銷毀iframe。

createiframe:function(elem){
    var layer = document.createelement('iframe');
    layer.tabindex = '-1';
    layer.src = 'javascript:false;';
    elem.parentnode.appendchild(layer);
       
    layer.style.width = elem.offsetwidth + 'px';
    layer.style.height = elem.offsetheight + 'px';
}

首先需要使用負的tabindex值把iframe排除在tab序列之外,否則用戶可能會使用鍵盤導航到它,這就亂了套了,所以需要將tabindex值設置為負的。另外,還要設置src,設置該值是為了避免在ssl頁面上出現問題.在ie中,沒有設置src的iframe將會自動裝載about:blank。ie將此視為不安全頁面,而且會產生一個警告對話框,內容是“該頁面包含安全和非安全的內容”。為了避免這個問題,可以將src設置為“javascript:false;”。(該段摘自<<javascript精髓>>)
而避免iframe在頁面所造成的混亂,所以在onmouseout中將iframe銷毀,而不對其進行隱藏。

使用說明

由于時間上的問題,所以沒有封裝的太好,主要是在css上,最好根據我所設置的那樣設置,感覺有些亂。希望大家能夠理解,而修改也不會太難.因為我自帶一個css()函數,只要稍加設置就可以了。使用例子:

magnifier.init({
    cont : document.getelementbyid('magnifier'),
    img : document.getelementbyid('magnifierimg'),
    mag : document.getelementbyid('mag'),
    scale : 3
});

cont為container縮寫,指的是裝載原始圖像的div;
img則是放大的圖像;
mag則為magnifier縮寫,是指放大框;
scale為比例值,設置的值越大放大越大,但是這里有個問題就是如果不可以整除時,會產生些很小的白邊,目前不知道如何解決;
至于瀏覽框和原始圖像為m.cont.getelementsbytagname('img')[0]和m.cont.getelementsbytagname('div')[0],所以建議在裝載圖像的div中最好只放一個div和img。

ps:剛剛給源碼也加了注釋了,有些沒有的,大概在下面的代碼說明會有.this指針搞的好混亂~希望大家能看的明白什么回事..越用this越覺得不太好用啊..誒.>~搞了1個下午,累,休息下先哈。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91tv亚洲精品香蕉国产一区7ujn| 久久精品国产久精国产一老狼| 在线观看精品国产视频| 91热福利电影| 91chinesevideo永久地址| 4388成人网| 欧美久久精品一级黑人c片| 日韩在线不卡视频| 亚洲精品国产福利| 亚洲国产精品电影在线观看| 国产精品综合久久久| 亚洲精品久久久久中文字幕二区| 欧美中文字幕视频| 日韩成人激情在线| 国产精品视频免费在线| 亚洲国产成人精品久久久国产成人一区| 国产精品精品视频| 懂色av中文一区二区三区天美| 97国产精品视频人人做人人爱| 正在播放亚洲1区| 亚洲人成电影网站色…| 91精品国产99久久久久久| 国产精品丝袜久久久久久高清| 精品国产区一区二区三区在线观看| 精品亚洲一区二区三区在线观看| 97色伦亚洲国产| 日韩视频免费大全中文字幕| 欧美成人免费一级人片100| 色无极影院亚洲| 精品久久久久久久久久久久| 国产精品久久网| 日韩国产欧美精品一区二区三区| 久久久久久综合网天天| 亚洲级视频在线观看免费1级| 日韩男女性生活视频| 亚洲在线免费观看| 欧美日韩国产123| 久久福利视频导航| 欧美专区在线观看| 中文字幕综合在线| 久久人体大胆视频| 日韩免费黄色av| 国产日韩在线观看av| 日韩精品福利在线| 国产欧美精品一区二区三区-老狼| 国产视频观看一区| 国产ts人妖一区二区三区| 久久久久久久久网站| 久久精品影视伊人网| 亚洲高清在线观看| 亚洲激情小视频| 精品电影在线观看| yw.139尤物在线精品视频| 亚洲国产小视频在线观看| 国产va免费精品高清在线观看| 91久久精品国产91性色| 久久久精品2019中文字幕神马| 6080yy精品一区二区三区| 国产精品最新在线观看| 色综合久久久888| 97久久超碰福利国产精品…| 精品亚洲一区二区| 久久精品91久久香蕉加勒比| 亚洲全黄一级网站| 国产+成+人+亚洲欧洲| 日韩欧美在线中文字幕| 欧美电影免费观看高清| 自拍偷拍亚洲一区| 亚洲欧美国产va在线影院| 俺也去精品视频在线观看| 麻豆国产va免费精品高清在线| 国产一区二区三区毛片| 琪琪亚洲精品午夜在线| 国产精品夜色7777狼人| 欧美黑人性猛交| 97超级碰在线看视频免费在线看| 91网站在线免费观看| 97国产精品视频人人做人人爱| 欧美大尺度在线观看| 欧美丝袜第一区| 精品国产鲁一鲁一区二区张丽| 亚洲人成在线观看| 国产日韩在线亚洲字幕中文| 精品国偷自产在线视频99| 亚洲一区二区三区视频| 成人网页在线免费观看| 国产v综合ⅴ日韩v欧美大片| 777国产偷窥盗摄精品视频| 国产精品一区二区三区免费视频| 国产精品网站大全| 九九热99久久久国产盗摄| **欧美日韩vr在线| 日韩在线视频国产| 国产精品第三页| 亚洲精品日韩丝袜精品| 国产精品夜色7777狼人| 亚洲欧洲日产国码av系列天堂| 亚洲精品99久久久久| 国产精品亚洲激情| 中文字幕亚洲欧美在线| 中文字幕日韩综合av| 欧美成人一二三| 欧美日韩在线视频首页| 国产精品精品视频| 综合国产在线视频| 久久久久久免费精品| 久久精品中文字幕| 亚洲一品av免费观看| 在线观看视频99| 国产精品手机播放| 久久久久国产精品一区| 久久99视频精品| 久久精品99久久久香蕉| 亚洲免费成人av电影| 欧美理论片在线观看| 欧美有码在线观看| 久久躁狠狠躁夜夜爽| 中日韩午夜理伦电影免费| 国产成人亚洲综合青青| 亚洲成人久久久久| 国内精品中文字幕| 久久精品国产久精国产一老狼| 日韩中文字幕视频| 国产精品久久久久久久9999| 亚洲国产小视频在线观看| 欧美电影免费在线观看| 欧美激情性做爰免费视频| 亚洲第一在线视频| 一级做a爰片久久毛片美女图片| 欧美综合一区第一页| 亚洲欧美中文在线视频| 久热99视频在线观看| 久久亚洲电影天堂| 日韩成人中文字幕| 亚洲最新在线视频| 久久综合88中文色鬼| 欧美在线观看日本一区| 欧美黑人极品猛少妇色xxxxx| 最好看的2019的中文字幕视频| 在线播放国产一区二区三区| 久久久噜久噜久久综合| 91精品国产综合久久久久久蜜臀| 国产精品aaa| 国产精品欧美久久久| 欧美电影《睫毛膏》| 一本久久综合亚洲鲁鲁| 亚洲影院高清在线| 亚洲成人在线视频播放| 国产免费成人av| 久久理论片午夜琪琪电影网| 国产区精品视频| 97香蕉超级碰碰久久免费的优势| 7777免费精品视频| 操人视频在线观看欧美| 国产精品一区二区三区在线播放| 精品少妇一区二区30p| 亚洲欧美日韩爽爽影院| 2019亚洲男人天堂| 中文在线不卡视频| 欧美一级电影在线| 亚洲欧美日韩国产成人| www.xxxx欧美| 亚洲免费高清视频| 国产91色在线免费|