精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

淺析Javascript透明特效的可控式實(shí)現(xiàn)

開發(fā) 前端
這里將介紹Javascript透明特效的可控式實(shí)現(xiàn),也就是特效可以被控制,希望本文能對(duì)大家有所幫助。

可控式Javascript透明特效也就是透明度可以自行設(shè)置,但是這種方法在IE7下極有可能失效,不過(guò)這些東西對(duì)大家了解Javascript透明特效還是有所幫助的。

Javascript透明特效是script.aculo.us提到的特效中最簡(jiǎn)單的特效之一。既然是特效,必須涉及時(shí)間與空間的概念。時(shí)間我們可以用setTimeout與setInterval,個(gè)人比較喜歡setTimeout,雖然它每次調(diào)用都重復(fù)注冊(cè),但可控性比較好。空間就全憑CSS的絕對(duì)定位實(shí)現(xiàn)位移了。在開始之前,我們練習(xí)一下setTimeout的遞歸用法(用來(lái)模擬setInterval)。

01.function text(el){
02.  var node  = (typeof el == "string")? document.getElementById(el) : el;
03.  var i = 0;
04.  var repeat = function(){
05.    setTimeout(function(){
06.      node.innerHTML = "<h1>"+i+"</h1>";
07.      i++;
08.      if(i <= 100){
09.        setTimeout(arguments.callee, 100);
10.      }
11.    },100)
12.  }
13.  repeat();
14.}

我們來(lái)試一下最簡(jiǎn)單的淡入特效,就是把node.innerHTML那一行改成透明度的設(shè)置。

01.function fadeIn(el){
02.  var node  = (typeof el == "string")? document.getElementById(el) : el;
03.  var i = 0;
04.  var fade = function(){
05.    setTimeout(function(){     
06.        !+"\v1"? (node.style.filter="alpha(opacity="+i+")"): (node.style.opacity = i / 100);
07.      i++;
08.      if(i <= 100){
09.        setTimeout(arguments.callee, 100);
10.      }
11.    },100)
12.  }
13.  fade();
14.}

但是這樣并不完美,因?yàn)镮E的濾鏡可能會(huì)在IE7中失效,我們必須要用zoom=1來(lái)激活hasLayout。我們?cè)偬砑右恍┛芍贫▍?shù)擴(kuò)充它。注釋已經(jīng)非常詳細(xì),不明白在留言里再問(wèn)我吧。

01.function opacity(el){
02.  //必選參數(shù)
03.  var node  = (typeof el == "string")? document.getElementById(el) : el,
04.  //可選參數(shù)
05.  options = arguments[1] || {},
06.  //變化的持續(xù)時(shí)間
07.  duration = options.duration || 1.0,
08.  //開始時(shí)透明度
09.  from = options.from || 0.0 ,
10.  //結(jié)束時(shí)透明度
11.  to = options.to || 0.5,
12.  operation = 1,
13.  init = 0;
14.  if(to - from < 0){
15.    operation = -1,
16.    init = 1;
17.  }
18.  //內(nèi)部參數(shù)
19.  //setTimeout執(zhí)行的間隔時(shí)間,單位毫秒
20.  var frequency = 100,
21.  //設(shè)算重復(fù)調(diào)用的次數(shù)
22.  count = duration * 1000 / frequency,
23.  // 設(shè)算每次透明度的遞增量
24.  detal = Math.abs(to - from)  /count,
25.  // 正在進(jìn)行的次數(shù)
26.  i = 0;
27.  var main = function(){
28.    setTimeout(function(){
29.      if(!+"\v1"){
30.        if(node.currentStyle.hasLayout)  node.style.zoom = 1;//防止濾鏡失效
31.        node.style.filter="alpha(opacity="+ (init * 100 + operation * detal * i * 100).toFixed(1) +")"
32.      }else{
33.        node.style.opacity =  (init + operation * detal * i).toFixed(3)
34.      }
35.      node.innerHTML =  (init + operation * detal * i).toFixed(3)
36.      i++;
37.      if(i <= count){
38.        setTimeout(arguments.callee, frequency);
39.      }
40.    },frequency)
41.  }
42.  main();
43.}
100.0
50.0
1.<div class="text" onclick="opacity(this,{duration:4.0,from:0.0,to:1})"></div>
2.<div class="text" onclick="opacity(this,{duration:4.0,from:1.0,to:0})"></div>

但上面并不盡善盡美,有一個(gè)Bug。我們是通過(guò)短路運(yùn)算符來(lái)決定是否使用默認(rèn)參數(shù)還是我們傳入的參數(shù),但在Javascript中,數(shù)字0甚至0.0都會(huì)自動(dòng)轉(zhuǎn)換為false。因此在第個(gè)例子,如果我們?cè)趖o中傳入0,它永遠(yuǎn)不會(huì)用到這個(gè)0,而是默認(rèn)的0.5。解決方法讓它變成字符串“0”。另,參數(shù)i也不是必須的,我們可以省去它,用count負(fù)責(zé)所有的循環(huán),但這樣一來(lái),我們的思維就要逆過(guò)來(lái)想了。原來(lái)是加的,我們要變成減的。

01.function opacity(el){
02.  //必選參數(shù)
03.  var node  = (typeof el == "string")? document.getElementById(el) : el,
04.  //可選參數(shù)
05.  options = arguments[1] || {},
06.  //變化的持續(xù)時(shí)間
07.  duration = options.duration || 1.0,
08.  //開始時(shí)透明度
09.  from = options.from || 0.0 ,
10.  //結(jié)束時(shí)透明度
11.  to = (options.to && options.to + "") || 0.5,
12.  operation = -1,
13.  init = 1;
14.  if(to - from < 0){
15.    operation = 1,
16.    init = 0;
17.  }
18.  //內(nèi)部參數(shù)
19.  //setTimeout執(zhí)行的時(shí)間,單位
20.  var frequency = 100,
21.  //設(shè)算重復(fù)調(diào)用的次數(shù)
22.  count = duration * 1000 / frequency,
23.  // 設(shè)算每次透明度的遞增量
24.  detal = operation * Math.abs(to - from) /count;
25.  var main = function(){
26.    setTimeout(function(){
27.      if(!+"\v1"){
28.        if(node.currentStyle.hasLayout)  node.style.zoom = 1;//防止濾鏡失效
29.        node.style.filter="alpha(opacity="+ (init * 100 +  detal * count * 100).toFixed(1) +")"
30.      }else{
31.        node.style.opacity =  (init +  detal * count).toFixed(3)
32.      }
33.      count--;
34.      if(count + 1){
35.        setTimeout(arguments.callee, frequency);
36.      }
37.    },frequency)
38.  }
39.  main();
40.}

進(jìn)一步優(yōu)化,利用原型共享方法。

01.function Opacity(el){
02.  var node  = (typeof el == "string")? document.getElementById(el) : el,
03.  options = arguments[1] || {},
04.  duration = options.duration || 1.0,
05.  from = options.from || 0.0 ,
06.  to = (options.to && options.to + "") || 0.5,
07.  operation = -1,
08.  init = 1;
09.  if(to - from < 0){
10.    operation = 1,
11.    init = 0;
12.  }
13.  var frequency = 100,
14.  count = duration * 1000 / frequency,
15.  detal = operation * Math.abs(to - from) /count;
16.  this.main(node,init,detal,count,frequency);
17.}
18.Opacity.prototype = {
19.  main : function(node,init,detal,count,frequency){
20.    setTimeout(function(){
21.      if(!+"\v1"){
22.        if(node.currentStyle.hasLayout)  node.style.zoom = 1;//防止濾鏡失效
23.        node.style.filter="alpha(opacity="+ (init * 100 +  detal * count * 100).toFixed(1) +")"
24.      }else{
25.        node.style.opacity =  (init +  detal * count).toFixed(3)
26.      }
27.      node.innerHTML =  (init +  detal * count).toFixed(3)
28.      count--;
29.      if(count + 1){
30.        setTimeout(arguments.callee, frequency);
31.      }
32.    },frequency)
33.  }
34.}
1.000
0.000
1.<div class="text" onclick="new Opacity(this,{duration:4.0,from:0.0,to:1})"></div>
2.<div class="text" onclick="new Opacity(this,{duration:4.0,from:1.0,to:0})"></div>

原文標(biāo)題:javascript的可控式透明特效

鏈接:http://www.cnblogs.com/rubylouvre/archive/2009/09/14/1566532.html

【編輯推薦】

  1. JSON是什么?為JavaScript準(zhǔn)備的數(shù)據(jù)格式
  2. 十個(gè)最常用的JavaScript自定義函數(shù)
  3. 有關(guān)JavaScript事件加載的一些延伸思考
  4. JavaScript使用心得匯總:從BOM和DOM談起
  5. ExtJS在Android模擬器上的運(yùn)行效果
責(zé)任編輯:彭凡 來(lái)源: 博客園
相關(guān)推薦

2016-10-19 14:35:20

JavaScript函數(shù)式編程

2009-08-20 10:10:55

C#透明窗體

2009-10-12 10:33:11

Javascript替

2009-09-11 10:44:07

JavaScript實(shí)

2021-07-27 22:56:00

JavaScript編程開發(fā)

2009-08-27 14:29:28

顯式實(shí)現(xiàn)接口

2020-03-31 08:05:23

分布式開發(fā)技術(shù)

2011-08-29 16:16:22

Lua函數(shù)多線程

2009-09-07 06:56:46

C#透明窗體

2021-02-07 22:59:55

JavaScript編程方法鏈

2009-07-24 17:30:37

Javascript閉

2011-03-07 09:41:10

JavaScript

2016-09-06 21:37:41

2011-03-10 14:19:56

JavaScript

2010-09-28 14:12:50

Javascript

2013-03-22 09:51:36

IP網(wǎng)關(guān)網(wǎng)絡(luò)遷移VoIP

2016-09-14 21:28:25

JavaScript事件代理委托

2011-03-08 09:15:04

JavaScript

2022-01-17 21:37:24

JavaScriptHTMLCSS

2009-07-14 11:34:42

MyEclipse斷點(diǎn)JavaScript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产尤物99| 欧美精品精品精品精品免费| 亚洲色图 在线视频| 激情在线小视频| 成人高清视频在线| 国产精品久久一区主播| 免费在线黄色片| 国产乱码精品一区二区三区四区| 欧美高清视频在线高清观看mv色露露十八 | 99精品一区二区| 日本欧美精品在线| 色欲人妻综合网| 亚洲人和日本人hd| 欧美一区二区三区影视| 久久久免费视频网站| 激情视频在线观看| 国产亚洲欧美一区在线观看| 亚洲综合av影视| www.com亚洲| 国产精品99一区二区三区| 亚洲国模精品私拍| 在线观看视频在线观看| 精品国模一区二区三区| 亚洲国产成人91porn| 亚洲精品视频一区二区三区| 性xxxx视频| 国产一区二区不卡在线| 国产aⅴ夜夜欢一区二区三区 | 亚洲天天影视网| 亚洲视频在线观看视频| 日本人添下边视频免费| 免费观看亚洲天堂| 欧美人妇做爰xxxⅹ性高电影| 日韩avxxx| 91超碰国产在线| 亚洲制服丝袜在线| 佐佐木明希av| 天堂аⅴ在线地址8| 国产欧美精品一区二区色综合| 久久av一区二区三区漫画| 亚洲第一成年人网站| 国内欧美视频一区二区| 国产日韩欧美另类| 中文字幕天堂在线| 视频在线观看一区| 国产做受69高潮| 国产精品a成v人在线播放| 中出一区二区| 欧美大码xxxx| 看片网站在线观看| 欧美一区高清| 九九九久久久久久| 四虎永久免费在线| 艳女tv在线观看国产一区| 久久久av亚洲男天堂| 黄色录像免费观看| 91精品蜜臀一区二区三区在线| 深夜福利亚洲导航| 人人艹在线视频| 天天影视欧美综合在线观看| 久久久91精品国产| 国产人妻精品一区二区三区不卡| 香蕉综合视频| 色与欲影视天天看综合网| 免费人成年激情视频在线观看| 欧美在线二区| 久久久久久有精品国产| 日韩精品久久久久久久| 国产精品久久久亚洲一区| 日本道色综合久久影院| 亚洲精品毛片一区二区三区| 日韩av一区二区三区| 国产精品久久久久99| 亚洲在线免费观看视频| 国产伦精品一区二区三区免费 | 少妇人妻互换不带套| 国产精品迅雷| 欧美日韩在线不卡| 午夜诱惑痒痒网| 成人精品毛片| 一区二区亚洲欧洲国产日韩| 在线观看亚洲网站| 在线日韩电影| 国产精品r级在线| 91高潮大合集爽到抽搐| 国产成人三级在线观看| 精品免费视频123区| 黄色av免费在线看| 亚洲激情校园春色| 男人日女人下面视频| 日韩欧美少妇| 精品日韩99亚洲| 国产精品20p| 欧美精品不卡| 国产精品成人久久久久| 国产视频在线观看免费| 92国产精品观看| 亚洲欧美日韩另类精品一区二区三区| 国内老司机av在线| 欧美视频在线观看一区| 亚洲黄色小说在线观看| 国精一区二区| 国内精品久久久久久影视8| 香蕉污视频在线观看| 国产精品自拍三区| 神马影院一区二区三区| heyzo中文字幕在线| 欧美人xxxx| 性久久久久久久久久| 中文字幕一区二区三区久久网站 | 亚洲欧美制服丝袜| 成人免费视频网站入口::| 日日夜夜精品视频免费| 国产传媒欧美日韩| 毛片在线看网站| 一本大道久久a久久综合| 五月六月丁香婷婷| 不卡av一区二区| 午夜欧美大片免费观看| 国产女人18毛片18精品| 国产欧美精品日韩区二区麻豆天美| 国产真人做爰毛片视频直播| 中文成人激情娱乐网| 亚洲视频欧美视频| 日韩不卡视频在线| 岛国精品在线播放| 路边理发店露脸熟妇泻火| 99热播精品免费| 亚洲网址你懂得| 97久久久久久久| eeuss影院一区二区三区| 国产精品88久久久久久妇女| 国产毛片精品久久| 亚洲人成在线电影| 色一情一乱一伦| av电影天堂一区二区在线| 黄色三级中文字幕| 中文无码日韩欧| 欧美夫妻性生活视频| 国产乱色精品成人免费视频| 国产精品电影一区二区三区| 亚洲人成无码www久久久| 久久99高清| 日本一欧美一欧美一亚洲视频| 无码精品黑人一区二区三区| 亚洲一区二区三区视频在线播放 | 日韩一区av在线| 特级西西444www高清大视频| 中文字幕精品在线不卡| 老司机午夜av| 成人中文视频| 国产日韩精品在线| 老司机在线看片网av| 91精品国产福利| 麻豆明星ai换脸视频| 国产在线播精品第三| 一本大道东京热无码aⅴ| 清纯唯美激情亚洲| 久久久亚洲影院| 天天摸天天碰天天爽天天弄| 欧美日韩国产一区二区三区| 国产男女猛烈无遮挡a片漫画| 美女精品在线观看| 婷婷亚洲婷婷综合色香五月| 久久国产三级| 久久成人亚洲精品| 欧美77777| 欧美特黄级在线| 法国空姐电影在线观看| 日本aⅴ亚洲精品中文乱码| 一区二区视频在线观看| 久久精品一级| 777777777亚洲妇女| 黄色影院在线播放| 欧美日韩国产精选| 青娱乐国产在线| 91色乱码一区二区三区| 国产天堂在线播放| 欧美日韩视频| 久久艳妇乳肉豪妇荡乳av| 亚洲成人一区在线观看| 久久久久www| 姝姝窝人体www聚色窝| 日本高清不卡一区| 裸体武打性艳史| 91伊人久久大香线蕉| 向日葵污视频在线观看| 欧美精品91| 日产精品高清视频免费| 国内不卡的一区二区三区中文字幕 | 国产成人免费看一级大黄| 一区二区三区毛片| 国产精品久久AV无码| 日本不卡的三区四区五区| 伊人再见免费在线观看高清版 | 欧美三级午夜理伦| 日本一区二区免费在线| 亚洲成人激情小说| 老司机亚洲精品| www.一区二区.com| 精品国产一区二区三区四区| 99re在线国产| 四虎4545www国产精品| 欧美日本国产在线| 日韩在线观看www| 亚洲精品久久久久久久久久久久久| 五月婷婷色丁香| 亚洲欧美日本韩国| 无码 人妻 在线 视频| 成人av第一页| 午夜免费福利网站| 日本最新不卡在线| 日韩小视频在线播放| 欧美+亚洲+精品+三区| 日韩视频在线播放| 日韩欧美中文字幕电影| 91沈先生播放一区二区| 欧美风情在线视频| 日韩免费观看av| 9999精品成人免费毛片在线看| 久久精品免费播放| youjizz在线播放| 日韩精品免费综合视频在线播放| 国产日韩一级片| 欧美日韩精品欧美日韩精品一综合| 成人免费区一区二区三区| 亚洲欧美日韩国产综合| 91狠狠综合久久久久久| 久久久久久免费毛片精品| 国产精品伦子伦| 成人一区二区三区视频| 污视频在线观看免费网站| 美女精品自拍一二三四| 免费大片在线观看| 欧美亚洲免费| 成人在线免费播放视频| 午夜一区不卡| 无码人妻丰满熟妇区毛片18| 亚洲一区久久| 青青草原成人网| 亚洲免费综合| 亚洲精品无码久久久久久| 99精品国产在热久久婷婷| 人妻夜夜添夜夜无码av| 亚洲伦理精品| 国产精品秘入口18禁麻豆免会员| 亚洲激情成人| 欧美 日韩精品| 久久综合影视| 亚洲第一中文av| 美国十次了思思久久精品导航| 五月激情婷婷在线| 久久99国产精品麻豆| 中文字幕1234区| 国产精品888| 亚洲精品第二页| 91在线云播放| youjizz亚洲女人| 日韩一区在线免费观看| 欧美精品videos极品| 亚洲国产你懂的| 日本中文在线播放| 91传媒视频在线播放| 中文字幕av资源| 欧美一级二级三级乱码| 人妻一区二区三区免费| 亚洲精品视频播放| eeuss影院在线观看| 精品国偷自产在线| 日本在线视频中文有码| 2019中文在线观看| 韩国成人在线| 2014亚洲精品| 久久超级碰碰| 人偷久久久久久久偷女厕| 99久久婷婷这里只有精品| 特级西西444| 老鸭窝亚洲一区二区三区| 最新天堂在线视频| 成人网在线免费视频| 扒开jk护士狂揉免费| 国产精品第四页| 日本在线免费观看| 欧美日韩成人综合天天影院| 亚洲精品一区二区三区不卡| 亚洲美女激情视频| 黄色av网站在线播放| 性色av一区二区三区| 777午夜精品电影免费看| 99国精产品一二二线| 国产成人精品一区二区免费看京 | 国产高清一区视频| 欧美猛男男男激情videos| 黄色免费高清视频| 国产精品日本| 亚洲男人天堂2021| 久久婷婷久久一区二区三区| 欧美爱爱免费视频| 一本大道综合伊人精品热热| 精品人妻伦一区二区三区久久| 亚洲无线码在线一区观看| 欧美aaaaaaa| 国产精品免费福利| 任你弄精品视频免费观看| 中文字幕成人一区| 久久精品成人| 妖精视频一区二区| 亚洲丝袜美腿综合| 天天射天天干天天| 亚洲精品不卡在线| 影音先锋男人资源在线| 国产精品视频地址| 性欧美xxxx免费岛国不卡电影| 黑人巨茎大战欧美白妇| 石原莉奈一区二区三区在线观看| 欧美激情 亚洲| 亚洲免费看黄网站| 在线视频 中文字幕| 亚洲欧美色婷婷| 久草在线资源站手机版| 99在线观看| 综合久久一区| 午夜两性免费视频| 日本一区二区三区dvd视频在线| 亚洲日本韩国在线| 亚洲福利视频二区| 欧美aaaxxxx做受视频| 亚洲一区二区久久久久久| 日本在线电影一区二区三区| 国产裸体舞一区二区三区 | 中文字幕免费在线看线人动作大片| 亚洲午夜久久久久久久久电影网 | 天堂а√在线中文在线新版 | 色94色欧美sute亚洲13| 天堂国产一区二区三区| 久久久久中文字幕| 91成人福利| 日韩精品综合在线| 国产69精品久久99不卡| 欧美成人黄色网| 精品少妇一区二区三区日产乱码 | 亚洲黄色录像片| 精品国产av一区二区三区| 欧美大尺度在线观看| 日韩欧美一级| 国产一区二区四区| jlzzjlzz亚洲日本少妇| 一级免费在线观看| 亚洲免费人成在线视频观看| 伊人久久av| 欧美中日韩免费视频| 久久久久.com| 丁香激情五月少妇| 欧美日韩精品欧美日韩精品| 欧美激情办公室videoshd| 成人黄色激情网| 亚洲色图网站| 娇妻高潮浓精白浆xxⅹ| 精品国产精品自拍| 国产精品久久一区二区三区不卡| 国产精品久久久久久亚洲影视| 日韩毛片视频| 国产精品久久久久久久99| 亚洲成人黄色影院| 能在线看的av| 国产精自产拍久久久久久| 一本一道久久a久久精品蜜桃| 欧美久久久久久久久久久| 一本色道久久综合亚洲aⅴ蜜桃| 国产精品视频一区二区久久| 91久久国产婷婷一区二区| 韩国一区二区三区在线观看| 国产 中文 字幕 日韩 在线| 欧美性高清videossexo| 成人日日夜夜| 精品日韩电影| 蜜臀精品一区二区三区在线观看| 久草手机视频在线观看| 精品国产精品一区二区夜夜嗨| 偷拍精品精品一区二区三区| 在线视频不卡一区二区| 成人听书哪个软件好| 欧美brazzers| 久久91亚洲精品中文字幕| 曰本一区二区三区视频| 91pony九色| 欧美日韩在线视频首页| 8888四色奇米在线观看| 国产传媒一区| 久久精品免费观看| 青青草av在线播放| 精品国产一区二区三区久久久狼 | 欧美大片免费观看网址| 免费观看黄色大片| 91欧美一区二区| 国产免费无遮挡| 欧美做受高潮电影o| 欧美在线看片| 第一次破处视频| 亚洲国产97在线精品一区|