日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JS动画-移入移出

發布時間:2024/1/8 javascript 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JS动画-移入移出 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

移入移出動畫效果的實現主要用到了定時器。定時器即 setInterval() 方法可按照指定的周期(以毫秒計)來調用函數或計算表達式。它會不停地調用函數,直到clearInterval() 被調用或窗口被關閉。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的參數。

HTML

<div id="div"><span>share</span> </div>

CSS

div{width: 250px;height: 30px;background-color: blue;position: absolute;left: -200px;top: 50px;} span{float: right;color: #fff;}

JS,移出效果就是改變該元素絕對定位的 left 的值,判斷到了0位置時候結束,清除定時器。移入效果則完全相反。

var oDiv=document.getElementById("div"); oDiv.onmouseover=function(){startMove(); }; oDiv.onmouseout=function(){startMoveOut(); } var timer=null; function startMove(){clearInterval(timer);var oDiv=document.getElementById("div");timer=setInterval(function(){if(oDiv.offsetLeft == 0){clearInterval(timer);}else{oDiv.style.left=oDiv.offsetLeft+5+"px";}},30); } function startMoveOut(){clearInterval(timer);var oDiv=document.getElementById("div");timer=setInterval(function(){if(oDiv.offsetLeft == -200){clearInterval(timer);}else{oDiv.style.left=oDiv.offsetLeft-5+"px";}},30); }

上述代碼顯然是可以優化的,實現同樣功能的函數,可以通過傳參來壓縮成一個函數。觀察兩個函數,它們的差別就在于判斷的目標位置不同,移動時改變的距離不同。

var oDiv=document.getElementById("div"); oDiv.onmouseover=function(){startMove(5,0); }; oDiv.onmouseout=function(){startMove(-5,-200); } var timer=null; function startMove(speed,iTarget){clearInterval(timer);var oDiv=document.getElementById("div");timer=setInterval(function(){if(oDiv.offsetLeft == iTarget){clearInterval(timer);}else{oDiv.style.left=oDiv.offsetLeft+speed+"px";}},30); }

為了提升性能,傳參的數量越少越好。比較參數speed和iTarget,其中更重要關鍵的參數應該是iTarget,可聯想日常生活中買火車票必須確定自己的目的地,但是速度無所謂的,因為有綠皮火車,動車,高鐵...

var oDiv=document.getElementById("div"); oDiv.onmouseover=function(){startMove(0); }; oDiv.onmouseout=function(){startMove(-200); } var timer=null; function startMove(iTarget){clearInterval(timer);var oDiv=document.getElementById("div");timer=setInterval(function(){var speed=0;if(oDiv.offsetLeft>iTarget){speed=-5;}else{speed=5;}if(oDiv.offsetLeft == iTarget){clearInterval(timer);}else{oDiv.style.left=oDiv.offsetLeft+speed+"px";} },30); }

移入移出的動畫效果實現不是最關鍵的,主要的是學會對代碼的優化是要一步一步的,最大可能精簡程序的性能。

總結

以上是生活随笔為你收集整理的JS动画-移入移出的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久精品牌麻豆国产大山 | 伊人色网 | 国产美女无遮挡免费 | 婷婷久久久久久 | 日皮视频在线观看 | 91在线导航 | 人妻少妇无码精品视频区 | 91欧美精品| 久久国产精品国语对白 | 尤物影院在线观看 | 国产99爱 | 女优一区二区三区 | 香港三日本8a三级少妇三级99 | 成人啪啪 | 草草影院国产 | 亚洲精品久久久久av无码 | 黄网在线观看免费 | 一本久道久久综合 | 在线免费观看一区二区三区 | 激情久久五月天 | 日韩av一区二区在线播放 | 国产高清视频一区 | 免费毛片在线 | 黑人黄色录像 | 一级a性色生活片久久毛片 爱爱高潮视频 | 日韩欧美大片 | 亚洲九九热 | 岛国毛片在线观看 | 制服.丝袜.亚洲.中文.综合懂色 | av在线浏览 | 一本之道久久 | www.199麻豆| 色葡萄影院 | 亚洲精品网站在线播放gif | 欧美一二 | 尹人成人| 枫可怜av | 亚洲色图美腿丝袜 | 亚洲六月丁香色婷婷综合久久 | 国产欧美在线观看 | 色秀av | 91看片在线观看 | 一区二区三区精品免费视频 | 久久人人人 | 日韩欧美视频一区二区三区 | 日韩免费网 | 一区二区三区在线免费 | 青青草原亚洲视频 | 久久久久久艹 | 丁香婷婷网 | 色一五月 | 国产精品呻吟久久 | 欧洲亚洲自拍 | 日本电影一区二区三区 | 情侣自拍av| 丁香一区二区三区 | 天天狠天天操 | 四虎永久在线精品免费网址 | 在线免费小电影 | 亚洲精品66 | 黄色高清片 | 成人手机看片 | 一区二区三区美女视频 | 欧美性理论片在线观看片免费 | 青青草原亚洲视频 | 国产系列精品av | 国产三区视频 | 亚洲m码 欧洲s码sss222 | 自拍偷拍21p | 乳色吐息在线观看 | 亚洲成人观看 | 欧美日韩在线观看免费 | 国产污视频在线 | v8888av| 天天搞夜夜 | 性插插视频 | 免费国产91 | 先锋影视av| 亚洲精品成人区在线观看 | 无码免费一区二区三区免费播放 | 男人午夜av | 日本丰满少妇一区二区三区 | 中文字幕中文字幕 | 精品一区二区三区无码视频 | 亚洲精品在线看 | 亚洲字幕成人中文在线观看 | 美女搡bbb又爽又猛又黄www | 一眉道姑 电影 | 在线欧美亚洲 | 超碰加勒比 | 日韩精品无码一本二本三本色 | 污视频软件在线观看 | 国产www精品 | jlzzjizz在线播放观看 | 午夜精品在线播放 | 热久久精品 | 伊人国产在线 | 国产精品美女一区二区三区 | 国产麻豆一区二区 |