精品欧美一区二区三区在线观看 _久久久久国色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)

国产曰批免费观看久久久| 成人综合久久| ㊣最新国产の精品bt伙计久久| 国产精品久久久久久久久久久久久久 | 亚洲精品77777| 日本国产精品| 在线精品亚洲一区二区不卡| 无遮挡亚洲一区| 国产精品高潮呻吟久久久| 亚洲欧美一区在线| 亚洲二区在线播放视频| 欧美牲交a欧美牲交aⅴ免费下载| 国产小视频在线| 麻豆成人91精品二区三区| 中文字幕在线日韩| www日本在线观看| 手机av在线| 国产精品素人一区二区| 国产成人成网站在线播放青青 | 亚洲欧美另类综合| 久久国产精品99国产| 最近2019中文字幕一页二页| 岛国av免费在线| av在线最新| 国产精品欧美久久久久无广告| av一区观看| 夜夜躁日日躁狠狠久久av| 欧美激情视频一区二区三区在线播放 | 国产精品成人国产| 亚洲福利国产精品| 亚洲一卡二卡| 理论片中文字幕| 美国一区二区三区在线播放 | 日韩精品一区二区三区丰满| 国产情侣激情自拍| 亚洲欧美日本国产专区一区| 欧美成人久久久| 国产精品美女高潮无套| 国产精品白丝av嫩草影院| 欧美亚洲综合另类| 免费国产a级片| 超碰在线观看免费| 久久久精品日韩欧美| 99re资源| 国产精品怡红院| 日韩电影一区二区三区| 久久久噜噜噜久久中文字免| 永久免费看片直接| 精品在线手机视频| 亚洲国产精品嫩草影院久久| 天堂av8在线| 日韩在线短视频| 欧美日韩国产一中文字不卡| 国产成人亚洲综合无码| 国产剧情在线| 国产精品美女一区二区| 欧美日本亚洲| 五月婷婷六月激情| 国产一区二区三区香蕉| 国产欧美日韩中文| 亚洲国产无线乱码在线观看| 小嫩嫩精品导航| 91av网站在线播放| 狠狠躁夜夜躁人人爽天天高潮| 欧美 日韩 国产一区二区在线视频 | 亚洲福利av| 黄色免费在线播放| 久久影院视频免费| 99re资源| 日韩在线一区二区三区四区| 国产盗摄精品一区二区三区在线| 91网站免费看| 国产夫妻自拍av| 国产剧情在线观看一区二区| 国产精品自拍网| 中文字幕+乱码+中文| 免费视频一区二区| 国产精品亚洲综合天堂夜夜| 免费在线观看av的网站| 视频一区二区三区在线| 国产精品va在线播放| 成人一二三四区| 免费成人在线网站| 成人av电影天堂| 国产普通话bbwbbwbbw| 国产麻豆精品theporn| 99re在线观看| 天天躁日日躁狠狠躁喷水| 99久久99久久久精品齐齐| 久久久福利视频| 国产在线观看免费网站| 久久亚洲私人国产精品va媚药| 你懂的网址一区二区三区| 国产区av在线| 亚洲视频综合在线| www在线观看免费| 成人午夜精品| 911国产精品| 9.1在线观看免费| 最新亚洲精品| 日韩一区二区欧美| 久久久久人妻一区精品色欧美| 最新日韩av| 韩国19禁主播vip福利视频| 成人毛片18女人毛片| 日本亚洲欧美天堂免费| 亚洲自拍偷拍一区| 日韩a在线观看| 国产精品美女久久久久高潮| 大桥未久一区二区三区| 鲁鲁在线中文| 69久久99精品久久久久婷婷| 超碰caoprom| 欧美精品一区二区三区精品| 中文一区二区视频| 免看一级a毛片一片成人不卡| 国产一区二区三区久久久久久久久| 国产精品电影一区| 国内老熟妇对白hdxxxx| 国产视频在线观看一区二区三区| 18视频在线观看娇喘| 青春草免费在线视频| 一本大道久久a久久精二百| 亚洲精品在线视频播放| 亚洲精品合集| 欧美精品制服第一页| 中文人妻av久久人妻18| 国产成人aaaa| 欧美人xxxxx| 超碰在线最新网址| 欧美日韩成人综合天天影院| 无码人妻精品一区二区三区温州| 亚洲v在线看| 国产成人午夜视频网址| 丰满熟女一区二区三区| 国产精品高潮呻吟| 黄色片一级视频| 91精品短视频| 欧美成人全部免费| 天天操天天爽天天干| 国产成人免费视频精品含羞草妖精| 日韩在线观看电影完整版高清免费| 美女精品视频| 日韩亚洲电影在线| 精品伦精品一区二区三区视频密桃| 欧美成人午夜| 国产欧美日韩中文字幕在线| 国产一二三区在线| 欧美日韩国产色| 日本性生活一级片| 欧美色图首页| 999视频在线免费观看| 免费在线观看av片| 欧美在线影院一区二区| 能免费看av的网站| 国产精品久久久久久久免费软件 | 欧美一级xxx| 三级黄色在线观看| 日韩1区2区日韩1区2区| 日本不卡一区二区三区视频| 伊人色综合一区二区三区影院视频| 精品国偷自产国产一区| 少妇久久久久久被弄高潮| 国内久久精品视频| 最新视频 - x88av| 91嫩草国产线观看亚洲一区二区 | 国产伦精品一区二区三区妓女| 一区在线视频观看| 好吊妞www.84com只有这里才有精品| 日本最新在线视频| 欧美日本一区二区在线观看| 毛片aaaaaa| 六月丁香婷婷久久| 一区二区三区在线观看www| 久久国产三级| 日韩中文字幕免费| 99久久亚洲精品日本无码| 亚洲天堂精品视频| 黄色三级视频在线| 日本大胆欧美| 91久久综合亚洲鲁鲁五月天| 99re在线视频| 这里只有精品免费| 青草草在线视频| zzijzzij亚洲日本少妇熟睡| 日本少妇高潮喷水视频| 亚洲黄色录像| 国产日本欧美在线观看| 91蜜桃在线视频| 精品美女一区二区| 中文字幕视频网站| 国产欧美va欧美不卡在线| 爱爱爱爱免费视频| 欧美日韩福利| 精品亚洲欧美日韩| yw.尤物在线精品视频| 蜜月aⅴ免费一区二区三区| 丰满人妻一区二区| 天涯成人国产亚洲精品一区av| 巨胸大乳www视频免费观看| 日韩成人精品在线| 4444在线观看| 免费欧美视频| 91精品久久久久久久久青青| av资源在线看片| 尤物yw午夜国产精品视频| av片免费观看| 一区二区三区四区不卡视频 | 三级影片在线看| 成人av资源在线| 日韩一级免费在线观看| 亚洲精品国产首次亮相| 精品乱码一区二区三区| 欧美黄色网络| 97视频在线观看视频免费视频| 国产视频精选在线| 欧美www视频| 久久国产乱子伦精品| 亚洲精品一二三| 国产精久久一区二区三区| 欧美 日韩 国产 在线观看| 播放一区二区| 91精品国产色综合久久不卡98口| 麻豆tv入口在线看| 亚洲性无码av在线| 天堂av在线免费观看| 精品欧美乱码久久久久久| 在线免费看毛片| 在线视频中文字幕一区二区| 欧美激情亚洲综合| 亚洲国产日韩综合久久精品| 三级黄色录像视频| 欧美高清一级片在线观看| 黄色在线观看av| av一二三不卡影片| 国产chinese中国hdxxxx| 国产精品99久久久久久宅男| 亚洲精品视频三区| 久久99精品国产麻豆婷婷洗澡| www.日本xxxx| 日本中文字幕不卡| 国产免费视频传媒| 日韩成人一级大片| jizz欧美激情18| 蜜臀av性久久久久蜜臀aⅴ流畅 | 精品乱人伦小说| 午夜精品久久久久久久99老熟妇| 欧美一区二区精品| jizz中国少妇| 日韩欧美123| 狠狠人妻久久久久久综合麻豆| 日韩欧美黄色影院| 性中国古装videossex| 精品99一区二区| 天天操天天操天天操| 精品亚洲一区二区三区四区五区| 色视频免费在线观看| 亚洲美女视频网站| 香蕉视频在线免费看| 久久夜色撩人精品| 欧美xxxx免费虐| 97av在线影院| 成人mm视频在线观看| 成人在线国产精品| 91精品尤物| 久久婷婷开心| 精品久久影院| 午夜啪啪福利视频| 国产尤物精品| 精品久久久久久久免费人妻| 奇米777欧美一区二区| 久久6免费视频| 国产成人综合自拍| 国产精品无码永久免费不卡| 日本一区二区三区四区在线视频| 午夜激情福利电影| 一区二区三区蜜桃网| 亚洲 欧美 日韩 综合| 欧美视频一区二区三区在线观看| 国产伦精品一区二区三区免.费| 欧美成人官网二区| 黑人与亚洲人色ⅹvideos| 久久精品国产亚洲| 亚洲涩涩在线| 成人激情电影一区二区| 国产伦精品一区二区三区免费优势| 欧美韩国日本精品一区二区三区| 99久精品视频在线观看视频| 日韩欧美猛交xxxxx无码| 久久只有精品| 91精产国品一二三| 国产午夜精品一区二区三区嫩草| 国产精品夜夜夜爽阿娇| 黑人精品xxx一区| 国产精品乱码一区二区| 亚洲第一综合天堂另类专| 91青青在线视频| 久久久在线视频| www.91精品| 欧美日韩视频在线一区二区观看视频| 999久久久精品国产| 日本三级免费网站| 国产91在线|亚洲| 懂色av粉嫩av浪潮av| 福利微拍一区二区| 99久久精品无免国产免费| 亚洲最新视频在线| 男人av在线播放| 91日韩久久| 忘忧草精品久久久久久久高清| 男人的天堂99| 成人动漫一区二区在线| 国产探花在线免费观看| 欧美亚洲日本国产| 三级做a全过程在线观看| 欧美激情视频一区二区| 成人黄色免费网站| 欧美精品123| 激情婷婷亚洲| 亚洲成人激情小说| 国产精品免费免费| 久久精品99北条麻妃| 亚洲欧美国产另类| 成人免费图片免费观看| 国产女人水真多18毛片18精品| 国产精品久久久久无码av| 国产小视频精品| 久久久久国产精品免费免费搜索| 日本免费在线播放| 日韩欧美在线不卡| а√天堂在线官网| 成人黄色中文字幕| 我不卡神马影院| 中文字幕色网站| 亚洲精品日韩一| 国产精品伦理一区| 日韩亚洲一区二区| 91成人精品观看| 中文字幕日韩一区二区三区| 麻豆一区二区在线| 99re6热在线精品视频| 欧美午夜宅男影院| av资源种子在线观看| 国产精品亚洲精品| 久久精品国产68国产精品亚洲| 天天干天天综合| 亚洲欧美综合另类在线卡通| 国产精品国产av| 草民午夜欧美限制a级福利片| 精品一区二区三区亚洲| 一本色道久久88亚洲精品综合| 国产成人免费视频网站高清观看视频 | 亚洲精品国产精品国| 欧美激情按摩在线| 精品深夜福利视频| 青青视频在线播放| 国产欧美视频在线观看| 亚洲精品一区二区二区| 俺去了亚洲欧美日韩| 日韩欧美另类中文字幕| 久久国产精品视频在线观看| 91麻豆国产在线观看| 色一情一乱一伦| 日韩在线一区二区三区免费视频| 色诱色偷偷久久综合| 日本三日本三级少妇三级66| 成人国产亚洲欧美成人综合网| 日韩精品久久久久久久酒店| 亚洲欧洲在线观看| 图片一区二区| 国产日韩亚洲欧美在线| 久久综合丝袜日本网| 久草热在线观看| 欧美成人一区在线| 秋霞影视一区二区三区| 欧美日韩大尺度| 中文字幕制服丝袜成人av| 99国产成人精品| 国内精品久久久久久中文字幕| 久久91麻豆精品一区| 日韩欧美亚洲另类| 性欧美大战久久久久久久久| 国产免费永久在线观看| 亚洲一区二区三区成人在线视频精品 | 欧美国产欧美综合| www.热久久| 国产精品igao视频| 亚洲精品中文字幕乱码| 日本japanese极品少妇| 51久久夜色精品国产麻豆| 欧美freesex黑人又粗又大| 亚洲精品成人久久久998| 成人晚上爱看视频| 亚洲一区二区三区高清视频| 久久久久久久97| 色综合久久一区二区三区| av av在线| 91精品欧美一区二区三区综合在| 欧美巨大丰满猛性社交| 欧美少妇在线观看|