console 输出 DOM 对象

作者: CntChen | 来源:发表于2015-08-28 02:31 被阅读989次

背景

前端开发调试的时候,经常需要查看HTML DOM元素对象,如图所示:

dom_object.png

DOM元素对象包含了HTML DOM的各种属性,例如:

  • 位置
    element.offsetHeight
    element.offsetWidth

  • 事件绑定
    element.onclick
    element.onkeydown

  • 子孙DOM节点和祖先DOM节点
    element.childNodes
    element.parentNodes

  • 文本
    element.innerText
    element.outerHTML

  • 样式
    element.style.color
    element.style.backgroundColor

总之超级有用。

问题

一般我们会使用 console 控制台打出DOM元素对象。
然而,在Chrome和IE中无法单独打印DOM object。
测试代码:在jsfiddle查看测试代码

测试代码

HTML:

<div id="messagecontent">
    <div class="message">
        <p>hello</p>
    </div>
</div>

JS:

var messageContent = document.getElementById('messagecontent');
var messages = messageContent.childNodes;
console.log(messageContent); // Code1
console.log(messages); // Code2
console.log(messages[0]); // Code3
  • 在Chrome44中

Code1 对于docment.getElementById()得到的DOM object,console输出文本
Code2 DOM Object Array 输出对象数组 [赞]
Code3 DOM Object Array [x],输出文本

chrome_dom_console.png
  • 在IE11 Edge中

Code1 输出文本
Code2 输出文本
Code3 输出文本

ie_dom_console.png
  • 在 Firefox 中

Code1 可查看对象 [赞]
Code2 可查看对象 [赞]
Code3 可查看对象 [赞]

firefox_dom_console.png

原因

JS中使用messages[0].style.color = 'red';修改文本颜色成功,说明messages[0]确实是对象。并且在firefox中console可以查看对象,Chrome和IE中console 打印 DOM object 成文本,但其还是对象。

所以这个问题是浏览器的控制台输出策略不同
对于开发者,在Chrome和IE中查看DOM object不方便。

方案

把DOM对象封装成Array的形式

JS:

console.log([messageContent]);
console.log(messages);
console.log([messages[0]]);

这下在主流浏览器中都正常了,不过要到数组里面查看DOM object。

完。

相关文章

  • console 输出 DOM 对象

    背景 前端开发调试的时候,经常需要查看HTML DOM元素对象,如图所示: DOM元素对象包含了HTML DOM的...

  • Chrome 调试技巧

    1.console DOM输出 var ul = document.getElementsByTagName("u...

  • HTML DOM Console对象

    HTMLDOMConsole对象 Console 对象提供了访问浏览器调试模式的信息到控制台。 CONTENT a...

  • Vue指令

    1. v-el 获取dom对象 1.0 v-el dom methods:{ console.log(...

  • 小技巧

    输出时间 console.time('a')console.timeEnd('a') 删除对象属性 let a =...

  • 元素对象和选择器

    html dom树 通过获取dom节点的方法获取到 元素对象 还能通过console.dir(元素对象) 打印出元...

  • console 对象与控制台

    console 对象与控制台 console 对象的静态方法 console.log方法用于在控制台输出信息。它可...

  • 浏览器常用的输出方式

    console.xxx console.log() console.dir():输出一个对象的详细键值对信息 co...

  • 关于console输出注意事项

    当输出对象的时候,实际上是给console传递一个对象的索引(或者叫指针)。当对象被删除不会影响输出,因为删除对象...

  • 【JS】console - 控制台的几种输出方式

    console.log(' 普通输出~ '); console.warn(' 输出警告! '); console....

网友评论

  • 南柯_3894:谷歌 console.dir()
  • ecf4eda378c0:问题是,我在chrome里面打印,有时候是 DOM元素对象,有时候打印出来是 HTML内容的文本。。。还没找到原因
    @CntChen 不知道有没有碰到过?
  • 9ad359e9343e:找了很长时间了,终于找到你了啊
    ecf4eda378c0:问题是,我在chrome里面打印,有时候是 DOM元素对象,有时候打印出来是 HTML内容的文本。。。还没找到原因
  • Miss____Du:好细心啊 这么小的细节都有注意
    CntChen:@Miss____Du 调试代码需要哈

本文标题:console 输出 DOM 对象

本文链接:https://www.haomeiwen.com/subject/hjihcttx.html