console.log()是web开发人员工作中的好朋友。但是你知道控制台包含的不仅仅是console.log()吗?这篇文章要讨论的就是JavaScript中的控制台。
% w4 c6 s$ d& J; o8 @ 简介
! b! {, C1 f$ L Web控制台是一个工具,主要用于记录与网页相关的信息,例如:网络请求、JavaScript安全错误、警告、CSS等。它使我们能够通过在网页内容中执行JavaScript表达式来与网页交互。
9 H7 @% X' R3 ?$ X! m3 `+ k 控制台的类型
; y* b/ h& I. U' I1 p console.log() console.error() console.warn() console.clear() console.time() console.table() console.count() console.group()$ N, p6 r( F1 U/ P- j
1. console.log() 4 ^7 U9 a- w9 T/ o0 E8 s
主要用于将输出信息打印到控制台。log()中可以放入任何类型,无论是强类型、数组、对象、还是布尔值等。7 u% K4 K, [' [4 ]
//console.log() method
console.log('string')
console.log(800)
console.log(true)
console.log(null)
console.log(undefined)
console.log({a:1, b:2}) // object inside log()
console.log([1,2,3,4]) // array inside log()
! `( Y8 P+ G( `) x 2. console.error()
9 W$ d" d7 {! l& t: } 此方法用于将错误消息记录到控制台。在测试代码时很有用。默认情况下,错误消息将突出显示为红色。
! L2 a- A$ W6 j' U V( [* _ // console.error() method
console.error('This is a sample Error')
: H1 m7 _9 k1 g% @" z 3. console.warn()
) o1 r J- n' G5 v 用于将警告消息记录到控制台。默认情况下,警告消息将突出显示为黄色。9 f$ e6 g! r: F' L1 n- D" H6 ?: T
// console.warn() method
console.warn('This is a sample Warning')
) m U* D/ G! e+ s8 x0 ]; H 4. console.clear() 1 R0 w2 I; q+ z3 a/ t- h- a" K
用于清除控制台信息。清除控制台时,如果是基于Chromium的浏览器,将打印一个简单的叠加文本,如下面的截图所示“Console was cleared”,而在Firefox中,则不会返回任何消息。2 G9 l* n3 Y [9 C( v- r
// console.clear() method
console.clear()
" g5 e( @8 v2 |& ~1 ~& D. _( } 5. console.time()和console.timeEnd()
- m* q2 `) G0 j8 `/ v 无论何时我们想知道一段代码或一个函数所需要花费的时间,都可以使用JavaScript控制台对象提供的time()和timeEnd()方法。关键是要有一个必须相同的标签,而里面的代码可以是任何东西(函数、对象、甚至直接console.log()都可以)。
5 Q% j2 W! S) ~: M4 O- a7 W // console.time() and console.timeEnd() method
// console.time() method
console.time("Let's see time console")
let time1 = function(){
console.log('time1 function is running')
}
let time2 = function(){
console.log('time2 function is running')
}
time1()
time2()
// console.timeEnd() method
console.timeEnd('Time Taken')
" u" d/ M* |5 r6 M! O: P# R 6. console.table()
5 p' B2 q+ y" a# a 这个方法允许我们在控制台中生成表格。输入数据必须是数组或显示为表格的对象。3 Z2 v( w5 D3 s8 g# j2 u) |0 C
// console.table() method
console.table({a:1, b:2, c:3, d:4, e:5})
6 S( ^: ?) L% F6 L, `+ \9 o1 l
7. console.count()
$ W9 e: p! @0 P, \& p+ w H* U& Y 这个方法在调用时会将数字(调用次数)写入到控制台。2 f% M6 p* `/ _, a U
// console.count() method
console.log('This is a sample count')
for(let i=0; i<10; i++){
console.count('This is iteration number', i)
}
. \5 U- y6 T, r' C7 S 8. console.group()和console.groupEnd()
8 k6 t9 m, b( @+ ^+ E R 控制台对象的group()和groupEnd()方法允许我们将内容分组到单独的代码块中,并且这些代码块将缩进。和time()和timeEnd()一样,它们也接受值相同的标签。9 R/ {6 e/ r$ i- ]
// console.group() and console.groupEnd() method
// console.group() method
console.group('This is a sample group')
console.log('This is a sample group log')
console.warn('This is a sample group warning')
console.error('This is a sample group error')
// console.groupEnd() method
console.groupEnd('This is a sample group')
console.log('This is a new section')
: g% W4 e- j4 O