console.log()是web开发人员工作中的好朋友。但是你知道控制台包含的不仅仅是console.log()吗?这篇文章要讨论的就是JavaScript中的控制台。* g; h+ F/ }9 f! t6 d" x$ B4 V- j
简介
- s4 H+ v1 j P. d Web控制台是一个工具,主要用于记录与网页相关的信息,例如:网络请求、JavaScript安全错误、警告、CSS等。它使我们能够通过在网页内容中执行JavaScript表达式来与网页交互。
. T: Z) m+ J' a) m6 X2 M" a 控制台的类型0 Q0 l# q# B0 @$ e/ x3 r" R
console.log() console.error() console.warn() console.clear() console.time() console.table() console.count() console.group()" W# ^% N2 R; w/ u8 F& V' @) h
1. console.log()
/ h: d5 B- q$ G6 S* U8 H/ R 主要用于将输出信息打印到控制台。log()中可以放入任何类型,无论是强类型、数组、对象、还是布尔值等。2 G. ^% R m4 _( Y: k- b2 M
//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()
' l9 Q" R1 f( S6 Y, |& O3 w 2. console.error()
2 _1 s) ^1 F7 ~0 n* z 此方法用于将错误消息记录到控制台。在测试代码时很有用。默认情况下,错误消息将突出显示为红色。
4 L$ ^9 A9 Y$ @# ?+ Y // console.error() method
console.error('This is a sample Error')
7 C' t. K# N0 c4 z5 Y
3. console.warn() - s1 C7 M+ i! ]( S# j
用于将警告消息记录到控制台。默认情况下,警告消息将突出显示为黄色。
3 W3 O f D/ W# |# F // console.warn() method
console.warn('This is a sample Warning')
, W- R" d) W8 ^6 K
4. console.clear()
* {% t/ E0 e4 w8 U% F6 P 用于清除控制台信息。清除控制台时,如果是基于Chromium的浏览器,将打印一个简单的叠加文本,如下面的截图所示“Console was cleared”,而在Firefox中,则不会返回任何消息。
8 R! f3 ~2 S2 p. M" y7 I // console.clear() method
console.clear()
1 k% ]; p; b8 K/ N! ^4 i/ M( t 5. console.time()和console.timeEnd()
+ x" w* u5 V. W* ^0 P 无论何时我们想知道一段代码或一个函数所需要花费的时间,都可以使用JavaScript控制台对象提供的time()和timeEnd()方法。关键是要有一个必须相同的标签,而里面的代码可以是任何东西(函数、对象、甚至直接console.log()都可以)。
& V$ i- @; _# P // 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')
* B& S3 G9 Q2 @! ^
6. console.table()
" E% E) d0 S7 q% L' S! z" Q6 O 这个方法允许我们在控制台中生成表格。输入数据必须是数组或显示为表格的对象。# [- t3 n0 u4 ^; I+ [
// console.table() method
console.table({a:1, b:2, c:3, d:4, e:5})
& j/ e% e! K1 L: m* F
7. console.count()
! q$ M: ]( B, i2 ? 这个方法在调用时会将数字(调用次数)写入到控制台。
9 y5 ?4 ] I4 K( [8 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)
}
& ?- c- l8 m1 J2 G: Z' h9 b8 G D9 U4 z2 L 8. console.group()和console.groupEnd()
4 t. ^$ B7 l: E; R; P7 A' ~ 控制台对象的group()和groupEnd()方法允许我们将内容分组到单独的代码块中,并且这些代码块将缩进。和time()和timeEnd()一样,它们也接受值相同的标签。, P7 W2 A4 l. {) b- g% H7 ]
// 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')
" d9 n J3 {' X