console.log()是web开发人员工作中的好朋友。但是你知道控制台包含的不仅仅是console.log()吗?这篇文章要讨论的就是JavaScript中的控制台。/ T& P# G. u$ m3 B( ]$ I0 h
简介 9 X- M; y( Q$ j5 W c: z( p- v; X
Web控制台是一个工具,主要用于记录与网页相关的信息,例如:网络请求、JavaScript安全错误、警告、CSS等。它使我们能够通过在网页内容中执行JavaScript表达式来与网页交互。
# |2 t/ U7 g+ M# ~ 控制台的类型3 U& r+ @- `8 {) {
console.log() console.error() console.warn() console.clear() console.time() console.table() console.count() console.group(). G! y* n# U# @9 V" P
1. console.log() / _- r ?. U" J6 H2 ~8 |# H
主要用于将输出信息打印到控制台。log()中可以放入任何类型,无论是强类型、数组、对象、还是布尔值等。' x( d' K9 U; n: Q9 h _
//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()
1 R: Z/ |# g% j& a# x+ m 2. console.error()
4 O+ o" b, j$ k4 G$ I+ e 此方法用于将错误消息记录到控制台。在测试代码时很有用。默认情况下,错误消息将突出显示为红色。' K' z* [9 F2 U# A
// console.error() method
console.error('This is a sample Error')
% e `% R0 T1 ~! E9 y9 Z6 P) p
3. console.warn()
! s! d' T! u9 {0 z7 e) \0 ]$ P 用于将警告消息记录到控制台。默认情况下,警告消息将突出显示为黄色。! E7 r( s* ]8 m2 r
// console.warn() method
console.warn('This is a sample Warning')
1 x" |# r. u4 O- J3 y& L+ b 4. console.clear()
! C1 c8 B, l% T* Q$ F 用于清除控制台信息。清除控制台时,如果是基于Chromium的浏览器,将打印一个简单的叠加文本,如下面的截图所示“Console was cleared”,而在Firefox中,则不会返回任何消息。5 a7 R( t2 N+ M9 K- T: n. ? S
// console.clear() method
console.clear()
2 s; _) k" C1 S% p
5. console.time()和console.timeEnd()
1 W* p: S% n' f/ N2 ~% y1 a 无论何时我们想知道一段代码或一个函数所需要花费的时间,都可以使用JavaScript控制台对象提供的time()和timeEnd()方法。关键是要有一个必须相同的标签,而里面的代码可以是任何东西(函数、对象、甚至直接console.log()都可以)。: ~7 J0 F( p+ i" G, Z+ r3 c; N
// 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')
% x# d( S0 z7 C) D& k- I$ P3 ] 6. console.table() 0 x4 [; G9 v/ C, P+ \
这个方法允许我们在控制台中生成表格。输入数据必须是数组或显示为表格的对象。$ v( l; F- v( H: Y6 |( Z* P( q( B8 G
// console.table() method
console.table({a:1, b:2, c:3, d:4, e:5})
1 {/ T; E- p6 I) y2 l6 I0 [ v' q 7. console.count() 7 ]3 g& H( X5 c7 L" p' J
这个方法在调用时会将数字(调用次数)写入到控制台。8 p" ^- }8 k4 Z# m' I/ h' `5 k
// console.count() method
console.log('This is a sample count')
for(let i=0; i<10; i++){
console.count('This is iteration number', i)
}
6 X9 j0 V) o* s( d. n 8. console.group()和console.groupEnd()
6 k. @' L q; D+ V9 ? 控制台对象的group()和groupEnd()方法允许我们将内容分组到单独的代码块中,并且这些代码块将缩进。和time()和timeEnd()一样,它们也接受值相同的标签。* t" i" c4 v! g/ 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')
& W8 w i- X- |. j3 q