console.log()是web开发人员工作中的好朋友。但是你知道控制台包含的不仅仅是console.log()吗?这篇文章要讨论的就是JavaScript中的控制台。! \" p& `8 V& l
简介 1 Z j" F0 Y7 j9 @$ H9 f# L I
Web控制台是一个工具,主要用于记录与网页相关的信息,例如:网络请求、JavaScript安全错误、警告、CSS等。它使我们能够通过在网页内容中执行JavaScript表达式来与网页交互。7 {% N4 M4 i5 D* z0 K* @$ c
控制台的类型# E5 |8 z3 l8 s, U1 z
console.log() console.error() console.warn() console.clear() console.time() console.table() console.count() console.group()1 V# `0 }8 R* A0 @% J
1. console.log() ( z+ M4 S8 u5 i* M1 e4 T" _ q
主要用于将输出信息打印到控制台。log()中可以放入任何类型,无论是强类型、数组、对象、还是布尔值等。
- I- d4 L6 y- v. n) f1 E$ a //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()
/ t% Z: ~# v% z" v7 Q: Z
2. console.error() ) }! p' U+ U. d, `) H2 |0 ^: d
此方法用于将错误消息记录到控制台。在测试代码时很有用。默认情况下,错误消息将突出显示为红色。4 e8 e X+ k/ a1 |$ N9 Q* k
// console.error() method
console.error('This is a sample Error')
, \( x) \7 ?/ B% B) z& n" U& w; L 3. console.warn()
% D( [/ Q* D; `( r% H 用于将警告消息记录到控制台。默认情况下,警告消息将突出显示为黄色。
& T3 y" s2 q1 I6 t6 j( Y3 {4 f. c9 a // console.warn() method
console.warn('This is a sample Warning')
6 D) T4 t* ?1 ]. l" q: U' d- ^" Q/ k 4. console.clear() - r. _; E8 p- G/ l2 P- ?. o, E
用于清除控制台信息。清除控制台时,如果是基于Chromium的浏览器,将打印一个简单的叠加文本,如下面的截图所示“Console was cleared”,而在Firefox中,则不会返回任何消息。, K; B4 r* d( Z
// console.clear() method
console.clear()
' y' {" C$ |3 L 5. console.time()和console.timeEnd()
' L9 Z, x3 F- e2 T; T 无论何时我们想知道一段代码或一个函数所需要花费的时间,都可以使用JavaScript控制台对象提供的time()和timeEnd()方法。关键是要有一个必须相同的标签,而里面的代码可以是任何东西(函数、对象、甚至直接console.log()都可以)。- ?6 [2 \5 G: q8 z5 C+ _
// 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')
' ~9 }+ v# P( z* i3 ~, e2 x 6. console.table() 7 M' F5 K& ?! ~6 M
这个方法允许我们在控制台中生成表格。输入数据必须是数组或显示为表格的对象。" l; H" t' ]; O5 B
// console.table() method
console.table({a:1, b:2, c:3, d:4, e:5})
- `! K/ ?, u3 P9 x. p* b- ~
7. console.count() / Y4 D4 f) i( A N# \/ @
这个方法在调用时会将数字(调用次数)写入到控制台。
* H1 `' [8 i, w7 u5 a ] // console.count() method
console.log('This is a sample count')
for(let i=0; i<10; i++){
console.count('This is iteration number', i)
}
/ E9 C7 g- J2 `/ [1 ] f 8. console.group()和console.groupEnd()
1 N1 {9 C/ W$ n# M: Z6 i3 b 控制台对象的group()和groupEnd()方法允许我们将内容分组到单独的代码块中,并且这些代码块将缩进。和time()和timeEnd()一样,它们也接受值相同的标签。
0 Y. f# A; `4 A8 f4 E" ]: \9 p) Z3 X' s // 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')
5 m6 v" E2 L8 v+ e" ]