編寫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
}
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()語句所得到的結果時一致的。

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

記事本++7.3.1
好用且免費的程式碼編輯器

Atom編輯器mac版下載
最受歡迎的的開源編輯器