JAVA & XML & JAVASCRIPT & AJAX & CSS

          Web 2.0 技術儲備............

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            77 隨筆 :: 17 文章 :: 116 評論 :: 0 Trackbacks

          轉自:恒星設計? URL = http://www.bjcan.com/hengxing/more.asp?lb=94

          在使用JScript的時候,我們有時需要間隔的執行一個方法,比如用來產生網頁UI動畫特效啥的。這是我們常常會使用方法setInterval或setTimeout,但是由于這兩個方法是由腳本宿主模擬出來的Timer線程,在通過其調用我們的方法是不能為其傳遞參數。

          ??? 我們常用的使用場景是:

          window.setTimeout("delayRun()", n);
          window.setInterval("intervalRun()", n);
          window.setTimeout(delayRun, n);
          window.setInterval(intervalRun, n);
          ??? 顯然強行代參數的調用: window.setTimeout("delayRun(param)", n);
          window.setInterval("intervalRun(param)", n);
          window.setTimeout(delayRun(param), n);
          window.setInterval(intervalRun(param), n);
          ??? 都是錯誤的,因為string literals形式的方法調用,param必須是全局變量(即window對象上的變量)才行;而function pointer形式的調用,完全錯誤了,這是把函數的返回值當成了setTimeout/setInterval函數的參數了,完全不是我們所望的事情。

          ??? 解決這個問題的辦法可以使用匿名函數包裝的方式,在以下scenario中我們這么做:
          function foo()
          {
          ??? var param = 100;
          ??? window.setInterval(function()
          ??? {
          ??????? intervalRun(param);
          ??? }, 888);
          }

          function interalRun(times)
          {
          ??? // todo: depend on times parameter
          }
          ??? 這樣一來,就可以不再依賴于全局變量向delayRun/intervalRun函數中傳遞參數,畢竟當頁面中的全局變量多了以后,會給腳本的開發、調試和管理等帶來極大的puzzle。

          posted on 2006-04-27 10:39 Web 2.0 技術資源 閱讀(11611) 評論(8)  編輯  收藏 所屬分類: Javascript

          評論

          # 我生日 2008-08-12 21:57 龍前
          工會能夠化工   回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題! 2009-02-09 12:54 zean
          天才~  回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題![未登錄] 2009-06-22 13:37 java fan
          學習了  回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題! 2009-09-16 17:28 someone
          window.setInterval("intervalRun('param')", n);
          這樣就行了  回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題! 2010-07-21 09:57 simpleCode
          thanks a lot  回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題![未登錄] 2011-04-17 10:36 ice
          用到了 非常感謝 但是不太明白原理 可以解釋一下嗎  回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題! 2011-04-17 18:07 Web 2.0 技術資源
          q@ice
          請學習下Javascript的閉包特性,你就明白啦!  回復  更多評論
            

          # re: window.setTimeout() & window.setInterval() 使用方式與參數傳遞問題! 2011-12-19 11:03 阿斯大法
          不太懂……  回復  更多評論
            

          主站蜘蛛池模板: 辽源市| 玉山县| 游戏| 大石桥市| 克拉玛依市| 台东县| 霍林郭勒市| 山阳县| 沛县| 昌邑市| 清流县| 武义县| 宁波市| 开封市| 密山市| 呼图壁县| 河源市| 锡林郭勒盟| 西藏| 桐庐县| 泽普县| 荣成市| 重庆市| 大丰市| 宁国市| 施秉县| 阳泉市| 荣成市| 固镇县| 浦县| 油尖旺区| 扶余县| 乾安县| 莫力| 上林县| 虞城县| 泗阳县| 玉溪市| 肥西县| 务川| 舞阳县|