JavaScript console对象与控制台使用示例详解

 更新时间:2022年10月14日 15:21:18   作者:爱思考的猪  
这篇文章主要介绍了JavaScript console对象与控制台的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

1. console对象

console对象是JavaScript的原生对象,提供了很多用于调试的方法,如console.log输出信息,console.count记录执行次数

console.log(console);

2. console的静态方法

  • console.log()、console.info()、console.debug()

console.log的使用

console.log('一行文字');
const name = 'jack';
const age = 21;
console.log(name,age); //jack,21

使用占位符

const name = 'ian';
const age = 21;
console.log('I am %s,i am %d years old',name,age);
//I am ian,i am 21 years old
  • %s 字符串
  • %d 整数
  • %i 整数
  • %f 浮点数
  • %o 对象的链接
  • %c css格式字符串

由于js是弱语言,没有类型的静态校验,通常我们不会使用占位符,而是直接使用字符串变量或者模板字符串。

console.info是console.log的别名,用法和console.log完全一致,console.debug和console.log的用法也基本一致

  • console.war()和console.error()

warn方法和error方法也是在控制台输出信息,它们与log方法的不同之处在于,warn方法输出信息时,在最前面加一个黄色三角,表示警告;error方法输出信息时,在最前面加一个红色的叉,表示出错。同时,还会高亮显示输出文字和错误发生的堆栈。其他方面都一样。

console.error('Error: %s (%i)', 'Server is not responding', 500)
// Error: Server is not responding (500)
console.warn('Warning! Too few nodes (%d)', document.childNodes.length)
// Warning! Too few nodes (1)
  • console.count()

console.count用于记录代码执行次数

    function foo(){
      count = console.count();
    };
    foo(); //default: 1
    foo(); //default: 2

 count方法还接收一个字符串用于将计算结果进行分类

    function foo(){
      count = console.count('foo');
    };
    foo(); // foo: 1
    foo(); // foo: 2
    function bar(){
      count = console.count('bar');
    };
    bar(); // bar: 1
    bar(); // bar: 2
  </script>
  • console.dir()、console.dirxml()

console.dir()用于对一个对象进行检查,并以易于阅读的方式输出

const user = {name:'ian', age:21};
console.log(user); //{name: 'ian', age: 21}
console.dir(user);
// Object
//   name: "ian"
//   age: 21
//   __proto__: Object

console.dirxml主要用于以目录树的形式显示DOM节点

console.log(documnet.body);
console.dirxml(document.body);
  • console.assert()

console.assert接收两个参数第一个是布尔值,第二个是提示信息,当第一个参数为true的时候,就显示一个错误,但不会中断代码的执行

console.assert(true,'数组长度不能小于0')
  • console.time()、console.timeEnd

这两个方法可以计算出一段代码执行完所用的时间

   console.time();
   for(let i=0;i<10000;i++){
    console.log(i);
   };
   console.timeEnd();
   //default: 164.182861328125 ms
  • console.trace()、console.clear()

console.trace方法显示当前代码在堆栈种的调用路径

    function foo() {
      console.trace();
    };
    function bar() {
      foo();
    };
    bar();
//index.html:14 console.trace
//foo @ index.html:14
//bar @ index.html:18
//(anonymous) @ index.html:20

console.clear()用于清空控制台

3. 自定义console

console对象所有的方法都可以被覆盖,因此可以自定义自己的方法

重写console.log()方法,将其改为document.write

console.log = function(str){
 document.write(str);
};

设置连console对象本身也可以被修改

console = null; //null

4. 控制台命令行API

4.1 $_

$_返回上一个表达式的值

1 + 2 ;
$_; //3

4.2 $0-$4

$0-$4保存了最近5个在Element面板选中的元素,$0表示(最近访问)第一个,$1表示第二个以此类推

4.3 $(selector)

( s e l e c t o r ) 返回第一个匹配的元素 , 等同于 d o c u m e n t . q u e r y S e l e c t o r ( ) , 需要注意的是 (selector)返回第一个匹配的元素,等同于document.querySelector(),需要注意的是 (selector)返回第一个匹配的元素,等同于document.querySelector(),需要注意的是是可以被复写的。

$$(selector)相当于document.querySelectorAll()

4.4 $x(path)

$x(path)返回一个数组,包含匹配特定 XPath 表达式的所有 DOM 元素。

$x('//p[a]'); 
//返回所有包含a标签的p元素

4.5 inspect(obj)

inspect方法用于显示对象的具体信息

inspect(window);

4.6 keys()和values()

keys()以数组的形式返回对象的所有键名,values()以数组的形式返回对象的所有键值

const obj = {name:'ian',age:21};
keys(obj);
//['name', 'age']
values(obj);
//['ian', 21]

4.7 其它的命令

  • copy() 复制,某个值到粘贴板
  • clear() 清空控制台
  • dir(object):显示特定对象的所有属性,是console.dir方法的别名
  • dirxml(object):显示特定对象的 XML 形式,是console.dirxml方法的别名

到此这篇关于JavaScript console对象与控制台使用示例详解的文章就介绍到这了,更多相关JS console对象与控制台内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript中的this指向和自定义属性详解

    JavaScript中的this指向和自定义属性详解

    下面小编就为大家带来一篇js中的this指向和自定义属性。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-09-09
  • Javascript 继承实现例子

    Javascript 继承实现例子

    在真正的Web站点和应用程序中,几乎不可能创建名为ClassA和ClassB的类,更可能的是创建表示特定事物(如形状)的类。考虑本章开头所述的形状的例子,Polygon、Triangle和Rectangle类就构成了一组很好的探讨数据。
    2009-08-08
  • 微信小程序五子棋游戏的悔棋实现方法【附demo源码下载】

    微信小程序五子棋游戏的悔棋实现方法【附demo源码下载】

    这篇文章主要介绍了微信小程序五子棋游戏的悔棋实现方法,结合实例形式分析了微信小程序中悔棋的原理与相关实现技巧,并附带demo源码供读者下载参考,需要的朋友可以参考下
    2019-02-02
  • 详解Javascript 基于长连接的服务框架问题

    详解Javascript 基于长连接的服务框架问题

    本文针对经常使用长连接进行消息收发的应答场景,采用 Websocket 长连接作为服务监听的对象,模拟了一套类 http 服务框架,通过实例代码介绍了Javascript 基于长连接的服务框架,需要的朋友可以参考下
    2022-07-07
  • 原生js实现一个放大镜效果超详细

    原生js实现一个放大镜效果超详细

    这篇文章主要介绍了原生js实现一个放大镜效果超详细,文章围绕主题展开详细的内容,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • js的alert弹出框出现乱码解决方案

    js的alert弹出框出现乱码解决方案

    alert弹出框出现乱码的情况,想必大家都有遇到过吧,其实解决方法很简单设置charset=utf-8在试试,看看是不是好了
    2013-09-09
  • 移动端界面的适配

    移动端界面的适配

    本文主要介绍了移动端页面适配相关知识,用于解决在所有手机上看到字体的大小都一样问题。下面跟着小编一起来看下吧
    2017-01-01
  • js实现千分符和保留几位小数的简单实例

    js实现千分符和保留几位小数的简单实例

    下面小编就为大家带来一篇js实现千分符和保留几位小数的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • JS使用AudioContext实现音频流实时播放

    JS使用AudioContext实现音频流实时播放

    这篇文章主要为大家详细介绍了JavaScript如何使用AudioContext实现音频流实时播放功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-01-01
  • 自动完成的搜索框javascript实现

    自动完成的搜索框javascript实现

    这篇文章主要介绍了自动完成的搜索框javascript实现代码,感兴趣的小伙伴们可以参考一下
    2016-02-02

最新评论