2018-12-19

回答

DOM(文档对象模型)是可扩展标记语言的标准编程接口,用来处理如 HTML 或 XML 这样由节点组成的树形结构的标记语言。这些节点(例如元素和文本节点)都是能够被编程接口操作的对象,他们任何可见的改变都会在文档中实时反映出来。在浏览器中,这些接口可供 JavaScript 进行使用,使其操作 DOM 节点来改变他们的样式、内容、在文档中的位置或者通过事件监听器来进行交互。

加分回答

  • DOM 的设计与特定的编程语言相独立,以便使文档的结构化表述可以通过单一、一致的 API 获得。
  • 随着页面的加载,DOM 在浏览器中是逐步构建的,因此脚本通常放在页面底部,或设置 defer 属性后置于 <head> 中,或放在 DOMContentLoaded 事件监听器内部。为了避免错误,脚本对 DOM 节点的操作应该放在 DOM 完成构建之后。
  • document.getElementById()document.querySelector() 是用来选择 DOM 节点的常用方法。
  • innerHTML 属性赋值为一个新的 HTML 可解析的字符串时,可以方便快捷高效的将一个动态 HTML 内容添加到节点对象上。如
document.querySelector('section').innerHTML = `<h1>30 Seconds</h1><div>${content}</div><footer>by Vanessa</footer>`
  • BOM 主要处理浏览器窗口和框架,不过通常浏览器特定的 JavaScript 扩展都被看做 BOM 的一部分。window 对象的属性和方法通常被称为 BOMDOM 描述了处理网页内容的方法和接口,BOM 描述了与浏览器进行交互的方法和接口。

返回总目录

每天 30 秒

  • 30Seconds

    前端面试 30s 系列问答翻译,英文原文请看 30-seconds-of-interviews

    68 引用 • 155 回帖 • 2 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    81 引用 • 241 回帖 • 315 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    163 引用 • 1111 回帖 • 492 关注
感谢    关注    收藏    赞同    反对    举报    分享