天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript進階教程(第三課第二部分)第1/2頁

    要使定時器循環工作你需要寫一個函數實現循環調用。這里是一個例子:

    var the_count = 0;
    var the_timeout;
    function doTimer()
    {
        window.document.timer_form.the_text.value = the_count;
        the_count += 2;
        the_timeout = setTimeout("doTimer();", 2000);
    }

    這里用到的定時器就是所用的定時器。當用戶點擊按鈕時就調用該函數。該函數將the_count的當前值寫到文字框中。然后the_count增加2,則開始調用函數自身。文字框中的數值也相應更新,the_count在增加2, 則再次調用函數自身。在等待的這兩秒期間瀏覽器則可以執行其他的同步工作。the_count一增加2就執行另一次setTimeout()。你不用擔心會造成內存崩潰,因為在給定時間內只有一個setTimeout()在執行。

    而無限的"while" 循環則會鎖定瀏覽器的工作,在執行該循環的過程中瀏覽器不能同時執行別的任何指令。而setTimeout則可以使循環的間隙中讓瀏覽器執行別的工作。

    如何取消setTimeout?

    現在你已經學習了如何設置一個無限循環。但是你必須懂得如何終止循環。其指令就是clearTimeout。上例中定時器還有下面這個表單元素:

    <input type="button" value="stop timer" onClick="clearTimeout(the_timeout);">

    點擊這個按鈕就可以終止定時器。指令是clearTimeout(),其實很簡單,如果你這樣設置setTimeout,the_timeout = setTimeout("some Javascript",3000);

    你可以這樣取消定時器:clearTimeout(the_timeout);

    很簡單,對吧?下面我們看一個復雜循環定時器,一個可以報告時間的定時器。

    現在時間是:

   

    點擊“啟動時鐘”則時鐘開始運行。它從你的計算機中讀取時間并每半秒更新一次文字框中的顯示。這個例子通過一個自調用的函數設置了一個定時器。同時這個例子可以讓你了解一點Date對象的功能。當講解cookies時,我提到過Date對象。

    以下是代碼:
    function writeTime() {
        // 獲得日期對象
        var today = new Date();

        // 從對象中獲得信息
        var hours = today.getHours();
        var minutes = today.getMinutes();
        var seconds = today.getSeconds();

        // fixTime 使分和秒可以正常顯示
        // 對于小于10的數字則在該數字前加一個0
        minutes = fixTime(minutes);
        seconds = fixTime(seconds);

        //將時間字符串組合在一起并寫出
        var the_time = hours + ":" + minutes + ":" + seconds;
        window.document.the_form.the_text.value = the_time;

        //每半秒鐘執行一次該函數
        the_timeout= setTimeout('writeTime();',500);
    }

    function fixTime(the_time) {
        if (the_time <10)
        {
            the_time = "0" + the_time;
        }

        return the_time;
    }

    我們仔細研究一下代碼。

    var today = new Date();
    正如new Array() 可以生成一個新的數組,你可以可以用new Date() 生成一個新的日期對象。生成對象之后,你可以對其提出你的問題。你生成的新的日期對象的括號中間沒有任何參數, 但JavaScript會查詢計算機的始終并用其生成新的日期對象。現在我們的日期對象名為"today" ,我們可以從中提取相應的信息。

    var hours = today.getHours();
    這條用于獲得當前的小時值。它是軍隊格式的時間,即,如果當前時間是下午兩點,則它返回的值是14。getHours()是Javascript的日期對象內置的方法調用。

    var minutes = today.getMinutes(); var seconds = today.getSeconds();
    這幾行原理和getHours()類似。

    minutes = fixTime(minutes);
    getMinutes存在一些問題,如果分鐘是11:01, getMinutes將返回 "1"。時鐘的顯示格式可不是這樣,它應該顯示為“01”。fixTime函數就是用于執行糾正顯示格式的功能。

    下面兩行將字符串組合在一起并顯示出來,
    the_timeout = setTimeout('writeTime();', 500);

    設置每半秒執行一次該函數的循環。

    下一講我們將學習如何在定時器中加入變量。

JavaScript技術JavaScript進階教程(第三課第二部分)第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 做暖暖视频在线看片免费 | 国产69精品久久久久乱码 | 中文字幕A片视频一区二区 中文字幕AV在线一二三区 | 苍井空小公主qvod | 办公室里呻吟的丰满老师电影 | 小柔的性放荡羞辱日记 | 国产精品无码人妻在线 | 欧美 亚洲综合在线一区 | 亚洲国产精品第一影院在线观看 | 亚洲1卡二卡3卡4卡新区在线 | 日本不卡免免费观看 | 亚洲国产中文字幕在线视频综合 | 午夜国产精品视频在线 | 寂寞夜晚视频高清观看免费 | AV无码国产精品午夜A片麻豆 | 99久久精品国产一区二区三区 | 亚洲乱色视频在线观看 | 国产人妻人伦精品59HHH | 国产一区二区免费在线观看 | 国产电影午夜成年免费视频 | 秋霞影音先锋一区二区 | 美女脱三角裤 | 在线观看国产区 | 2017必看无码作品 | 日本黄色www | 久久婷婷久久一区二区三区 | 偷拍亚洲制服另类无码专区 | 精品无码久久久久久动漫 | 毛片TV网站无套内射TV网站 | 秋霞电影网午夜一级鲁丝片 | av亚洲色天堂2017 | 超碰在线视频caoporn | 白丝女仆被啪到深夜漫画 | 九九热免费在线观看 | 九色PORNY真实丨国产大胸 | 无颜之月5集全免费看无删除 | 国产午夜人做人免费视频中文 | 午夜免费国产体验区免费的 | 亚洲综合中文 | 午夜DV内射一区二区 | 亚洲国产高清福利视频 |