<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    夢(mèng)幻之旅

    DEBUG - 天道酬勤

       :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      671 隨筆 :: 6 文章 :: 256 評(píng)論 :: 0 Trackbacks

    Internet的基本結(jié)構(gòu)是建立在一系列靜態(tài)狀態(tài)上的,這些靜態(tài)狀態(tài)一般都稱做頁面。從第13章可以看到,DHTML打破了這個(gè)模型,為了響應(yīng)用戶的動(dòng)作,DHTML在相同的界面上創(chuàng)建了很多獨(dú)立的狀態(tài)。本章將就這種動(dòng)態(tài)理念進(jìn)行更深一步的探討。

    有了JavaScript,網(wǎng)頁就可以不再是一堆離散狀態(tài)的集合,借助于時(shí)間(time)和動(dòng)作(motion),可以創(chuàng)建出真正的動(dòng)態(tài)頁面。對(duì)象可以隨著時(shí)間而改變,可以在頁面上順暢地運(yùn)動(dòng),而且用戶還可以像在實(shí)際生活中與事物進(jìn)行交互那樣對(duì)對(duì)象進(jìn)行操作。目前好多操作在桌面應(yīng)用程序中都已經(jīng)用濫了,如拖曳對(duì)象或者滑動(dòng)控件,這些都是很好的桌面應(yīng)用的例子,不過這些操作現(xiàn)在還沒有被集成到Web中去。

    在接下來的方法中,大家可以學(xué)到在頁面上移動(dòng)對(duì)象所涉及的基本步驟,然后還可以應(yīng)用這些基本的知識(shí)來創(chuàng)建一個(gè)實(shí)時(shí)交互系統(tǒng),如滑動(dòng)控件和拖曳界面。

    14.1  setTimeout和setInterval的使用

    這兩個(gè)方法都可以用來實(shí)現(xiàn)在一個(gè)固定時(shí)間段之后去執(zhí)行JavaScript。不過兩者各有各的應(yīng)用場(chǎng)景。

     方 法

    實(shí)際上,setTimeout和setInterval的語法相同。它們都有兩個(gè)參數(shù),一個(gè)是將要執(zhí)行的代碼字符串,還有一個(gè)是以毫秒為單位的時(shí)間間隔,當(dāng)過了那個(gè)時(shí)間段之后就將執(zhí)行那段代碼。

    不過這兩個(gè)函數(shù)還是有區(qū)別的,setInterval在執(zhí)行完一次代碼之后,經(jīng)過了那個(gè)固定的時(shí)間間隔,它還會(huì)自動(dòng)重復(fù)執(zhí)行代碼,而setTimeout只執(zhí)行一次那段代碼。

    雖然表面上看來setTimeout只能應(yīng)用在on-off方式的動(dòng)作上,不過可以通過創(chuàng)建一個(gè)函數(shù)循環(huán)重復(fù)調(diào)用setTimeout,以實(shí)現(xiàn)重復(fù)的操作:

    File: settimeout_setinterval.js

    showTime();

    function showTime()

    {

        var today = new Date();

        alert("The time is: " + today.toString());

        setTimeout("showTime()", 5000);

    }

    一旦調(diào)用了這個(gè)函數(shù),那么就會(huì)每隔5秒鐘就顯示一次時(shí)間。如果使用setInterval,則相應(yīng)的代碼如下所示:

    File: settimeout_setinterval2.js

    setInterval("showTime()", 5000);

    function showTime()

    {

        var today = new Date();

        alert("The time is: " + today.toString());

    }

    這兩種方法可能看起來非常像,而且顯示的結(jié)果也會(huì)很相似,不過兩者的最大區(qū)別就是,setTimeout方法不會(huì)每隔5秒鐘就執(zhí)行一次showTime函數(shù),它是在每次調(diào)用setTimeout后過5秒鐘再去執(zhí)行showTime函數(shù)。這意味著如果showTime函數(shù)的主體部分需要2秒鐘執(zhí)行完,那么整個(gè)函數(shù)則要每7秒鐘才執(zhí)行一次。而setInterval卻沒有被自己所調(diào)用的函數(shù)所束縛,它只是簡(jiǎn)單地每隔一定時(shí)間就重復(fù)執(zhí)行一次那個(gè)函數(shù)。

    如果要求在每隔一個(gè)固定的時(shí)間間隔后就精確地執(zhí)行某動(dòng)作,那么最好使用setInterval,而如果不想由于連續(xù)調(diào)用產(chǎn)生互相干擾的問題,尤其是每次函數(shù)的調(diào)用需要繁重的計(jì)算以及很長的處理時(shí)間,那么最好使用setTimeout。

    posted on 2010-04-14 10:24 HUIKK 閱讀(277) 評(píng)論(0)  編輯  收藏 所屬分類: JavaScript
    主站蜘蛛池模板: av免费不卡国产观看| 亚洲日韩精品国产一区二区三区| 猫咪www免费人成网站| 岛国大片免费在线观看| 亚洲国产av高清无码| 1000部无遮挡拍拍拍免费视频观看 | 亚洲人色大成年网站在线观看| 十九岁在线观看免费完整版电影| 亚洲香蕉成人AV网站在线观看 | 中文无码日韩欧免费视频| 天堂亚洲免费视频| 一级毛片免费观看不收费| 亚洲午夜成人精品电影在线观看| 性生大片视频免费观看一级| 久久精品国产亚洲Aⅴ蜜臀色欲| 又黄又大的激情视频在线观看免费视频社区在线 | 亚洲福利一区二区三区| 最近免费mv在线电影| 亚洲一级毛片免观看| 成全影视免费观看大全二| 亚洲AV成人片无码网站| 成人亚洲网站www在线观看| 四虎成人精品国产永久免费无码| 亚洲精品尤物yw在线影院| 99re6在线视频精品免费| 亚洲图片一区二区| 毛片免费vip会员在线看| 特级av毛片免费观看| 亚洲国产精品无码av| 又黄又爽又成人免费视频| 婷婷亚洲综合五月天小说在线| 国产亚洲精品福利在线无卡一| 99re6在线精品视频免费播放| 中文字幕亚洲男人的天堂网络 | 国产亚洲精品va在线| 成人在线免费看片| 国产精品亚洲综合一区在线观看| 在线播放亚洲第一字幕| av无码免费一区二区三区| 国产免费区在线观看十分钟| 亚洲黄色在线网站|