• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    JavaScript中的console.profile()函數詳細介紹_javascript技巧

    來源:懂視網 責編:小采 時間:2020-11-27 21:31:09
    文檔

    JavaScript中的console.profile()函數詳細介紹_javascript技巧

    JavaScript中的console.profile()函數詳細介紹_javascript技巧:編寫JavaScript程序時,如果需要知道某段代碼的執行時間,可以使用console.time()。不過,在分析邏輯較為復雜的JavaScript程序,試圖從中找出性能瓶頸的時候,console.time()就不適用了 — 深入分析邏輯較為復雜的JavaScript程序的運行就意味著插入
    推薦度:
    導讀JavaScript中的console.profile()函數詳細介紹_javascript技巧:編寫JavaScript程序時,如果需要知道某段代碼的執行時間,可以使用console.time()。不過,在分析邏輯較為復雜的JavaScript程序,試圖從中找出性能瓶頸的時候,console.time()就不適用了 — 深入分析邏輯較為復雜的JavaScript程序的運行就意味著插入
    編寫JavaScript程序時,如果需要知道某段代碼的執行時間,可以使用console.time()。不過,在分析邏輯較為復雜的JavaScript程序,試圖從中找出性能瓶頸的時候,console.time()就不適用了 — 深入分析邏輯較為復雜的JavaScript程序的運行就意味著插入大量的console.time()語句,而這無疑是不可接受的。對于復雜邏輯的JavaScript程序調優,正確的方法是使用console.profile()。

    瀏覽器支持

    安裝了Firebug插件的Firefox、Google Chrome以及Safari都支持console.profile()語句,最新版的IE和Opera也提供了Profile功能。在幾大瀏覽器上console.profile()的使用大同小異,本文僅介紹Firebug中console.profile()的使用情況。值得注意的一點是:如果使用Firebug控制臺來直接編寫JavaScript實驗代碼,那么console.profile()是無效的。

    console.profile()的使用

    console.profile()的使用非常簡單:在需要開始profile的地方插入console.profile(),在結束profile的地方插入console.profileEnd()即可。以下面的代碼為例:

    代碼如下:
    function doTask(){
    doSubTaskA(1000);
    doSubTaskA(100000);
    doSubTaskB(10000);
    doSubTaskC(1000,10000);
    }
    function doSubTaskA(count){
    for(var i=0;i }

    function doSubTaskB(count){
    for(var i=0;i }

    function doSubTaskC(countX,countY){
    for(var i=0;i for(var j=0;j }
    }

    console.profile();
    doTask();
    console.profileEnd();

    在運行doTask()函數前執行console.profile(),doTask()函數運行完成后執行console.profileEnd(),這樣即可收集到doTask()函數運行過程中的細節信息。在Firebug的控制臺中可以看到:

    從結果中可以看到:此次profile時間共計101.901ms,涉及5次函數調用。結果的默認標題是”Profile”,可以通過向console.profile()函數傳入參數來進行自定義。比如,使用console.profile(“Test Profile”)即可在結果中將此次profile的標題改為”Test Profile”,這對于同時執行多個profile過程的情況下尤為有用。具體profile結果中各列的含義為:

    1.Function。函數名。
    2.Calls。調用次數。比如,在上面的例子中,doSubTaskA()函數被執行了2次。
    3.Percent。該函數調用所消耗的時間在總體時間中所占的百分比。
    4.Own Time。除去調用其它函數所消耗的時間,該函數本身的耗時數量。比如,在上面的例子中,doTask()無疑執行了很長時間,但是因為其耗時全部花在了對其它函數的調用上,因此其本身所耗時間并不多,僅為0.097ms。
    5.Time。與Own Time相反,不考慮對其它函數的調用因素,計算函數的總耗時。在上面的例子中,doTask()函數執行了101.901ms。對于Time和Own Time,也可以得到一個結論:如果Time比Own Time數值要大,那么該函數內部就涉及了對其它函數的調用。
    6.Avg。計算函數的平均總耗時,其計算公式為:Avg=Time/Calls。在上面的例子中,doSubTaskA()函數被執行了2次,其總耗時為1.054ms,因此其平均總耗時為0.527ms。
    7.Min。對該函數調用的最小耗時。比如,在上面的例子中,doSubTaskA()函數被執行了2次,其最小耗時,也就是耗時較少的那次調用花掉了0.016ms。
    8.Max。對該函數調用的最大耗時。比如,在上面的例子中,doSubTaskA()函數被執行了2次,其最大耗時,也就是耗時較多的那次調用花掉了1.038ms。
    9.File。函數所在的JS文件。

    Firebug中Profile按鈕的使用

    除了在JavaScript代碼中插入console.profile()語句,Firebug還提供了Profile按鈕以便動態實時地對頁面中的JavaScript代碼進行profile。該按鈕位置為:

    當需要進行profile時,可以按下該按鈕,如果接下來的頁面操作觸發了任何JavaScript代碼,Firebug將會對此進行記錄。profile過程結束時只要再一次按下該按鈕即可。其最終結果與插入console.profile()語句所得到的結果時一致的。

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    JavaScript中的console.profile()函數詳細介紹_javascript技巧

    JavaScript中的console.profile()函數詳細介紹_javascript技巧:編寫JavaScript程序時,如果需要知道某段代碼的執行時間,可以使用console.time()。不過,在分析邏輯較為復雜的JavaScript程序,試圖從中找出性能瓶頸的時候,console.time()就不適用了 — 深入分析邏輯較為復雜的JavaScript程序的運行就意味著插入
    推薦度:
    標簽: js 函數 javascript
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 欧美精品一区二区在线精品| avtt天堂网久久精品| 久久综合精品国产二区无码| 国产精品福利在线观看免费不卡| 久久精品人人做人人妻人人玩| 精品一久久香蕉国产线看播放| 国产成人精品久久免费动漫| 中文字幕久久精品| 国内精品久久久久久久久电影网| 99精品高清视频一区二区| 亚洲av日韩精品久久久久久a| 久久夜色撩人精品国产小说| 国产成人精品免费大全| 精品三级在线观看| 国产精品精品自在线拍| 亚洲AV无码精品色午夜果冻不卡| 久久久久久无码国产精品中文字幕| 影音先锋国产精品国语对白| 国产成人精品免费视频大| 精品无码AV无码免费专区| 亚洲动漫精品无码av天堂| 亚洲国产精品13p| 久久久久久亚洲精品无码| 久草视频精品在线| 国产精品99爱免费视频| 亚洲国产精品久久| 国产在视频线精品视频二代| 国产精品vⅰdeoxxxx国产| 久久亚洲精品成人AV| 久久夜色精品国产欧美乱| 精品无码人妻一区二区三区品 | 久久久久久九九99精品| 在线精品亚洲一区二区| 亚洲午夜精品第一区二区8050| 亚洲国产精品自产在线播放| 无码精品人妻一区二区三区免费| 久热精品视频第一页| 少妇亚洲免费精品| 亚洲国产精品无码久久久不卡 | 亚洲精品成人无限看| 日韩精品无码一本二本三本|