JavaScript高级程序设计学习笔记--DOM
DOM(文档对象模型)是针对HTML和XML文档的一个API(应用程序接口)。
Document类型
文档的子节点
虽然DOM标准规定Document节点的子节点可以是DocumentType,Element,ProcessingInstruction或Comment,但还有两个内置的访问其子节点的快捷方式。第一个就是
documnetElement属性,该属性始终指向HTML页面中的<html>元素。另一个就是通过childNodes列表访问文档元素,但通过documentElement属性则能更快捷、更直接地访问该元素。
documnetElement、firstChild和childNodes[0]的值相同,都指向<html>元素 var html=documnet.documnetElement; //取得对<html>的访问 alert(html===documnet.childNodes[0]); //true alert(html===documnet.firstChild); //true
文档信息
修改tilte属性的值不会改变<title>元素。
想要取得文档中的所有元素,可以向getElementsByTagName()中传入"*",在JavaScript及CSS中,星号(*)通常表示“全部”,下面看一个例子:
var allElements=documnet.getElementsByTagName("*");
可以使用write()和writeIn()方法动态地包含外部资源,例如JavaScrip文件等。在包含JavaScript文件时,必须注意不能直接包含字符串"</script>",因为这会导致该字符串
被解释为脚本块的结束,它后面的代码将无法执行。为避免这个问题,只需加入转义符\即可,如下:
<body> <script type="text/javascript"> documnet.write("<script type=\"text/javascript\" scr=\"file.js\">"+ "<\/script>"); </script> </body>
在HTML中,标签名始终都以全部大写表示;而在XML(有时候也包括XHTML)中,标签名则始终会与源代码中保持一致。
动态脚本
动态加载外部脚本
var script=documnet.createElement("script"); script.type="text/javascript"; script.scr="client.js"; documnet.body.appendChild(script);
动态嵌入脚本
function loadScriptString(code){ var script=documnet.createElement("script"); script.type="text/javascript"; try{ script.appendChild(documnet.createTextNode(code)); }catch(ex){ script.text=code; } documnet.body.appendChild(code); }
下面是调用这个函数的示例:
loadScriptString("function sayHi(){alert('Hi');}");
以这种方式加载的代码会在全局作用域中执行,而且当脚本执行后将立即可用。实际上,这样执行代码与在全局作用域中把相同的字符串传递给eval()是一样的。
动态样式
动态加载外部样式
var link=documnet.createElement("link"); link.rel="stylesheet"; link.type="text/css"; link.href="style.css"; var head=documnet.getElementsByTagName("head")[0]; head.appendChild(link);
必须将<link>元素添加到<head>而不是<body>元素,才能保证在所有浏览器中的行为一致。
动态嵌入样式
function loadStypeString(css){ var style=documnet.createElement("style"); style.type="text/css"; try{ style.appendChild(documnet.createTextNode(css)); }catch(ex){ style.stylesheet.cssText=css; } var head=documnet.getElementsByTagName("head")[0]; head.appendChild(link); }
调用这个函数的示例如下:
loadStypeString("body{background-color:red}");
转载于:https://www.cnblogs.com/Gyoung/p/3821309.html
JavaScript高级程序设计学习笔记--DOM相关推荐
- JavaScript高级程序设计学习笔记(三)
分享一下第五章(引用类型)的笔记,内容比较多,我拆成了两部分,今天这部分是关于Object.Array.Date和RegExp类型的. 以下的笔记是书上一些我以前学习的时候,没有太重视的js基础知识, ...
- javascript高级程序设计学习笔记
javascript高级程序设计,当枕头书已经好久了~zz 现在觉得自己在js的开发上遇到了一些瓶颈,归根究底还是基础太薄弱,所以重新刷一遍js高程希望有更新的认识. 一.javascript简介 ...
- JavaScript高级程序设计--学习笔记(第六章)
文章目录 第六章 面向对象的程序设计 1. 理解对象 1.1 属性类型 1.2 定义多个属性 1.3 读取属性的特性 2. 创建对象 2.1 工厂模式 2.2 构造函数模式 2.3 原型模式 2.4 ...
- JavaScript高级程序设计学习笔记二(在HTML中使用JavaScript)
在 HTML 中使用 JavaScript 在html中使用JavaScript脚本有两种方式一种是嵌入在HTML中的脚本,另一种是引入外部的脚本.两种方式都离不开<script>元素. ...
- javascript高级程序设计 学习笔记 第五章 上
第五章 引用类型的值(对象)是引用类型的一个实例.在 ECMAScript 中,引用类型是一种数据结构, 用于将数据和功能组织在一起.它也常被称为类,但这种称呼并不妥当.尽管 ECMAScri ...
- JavaScript高级程序设计学习笔记--事件
HTML事件处理程序 <input type="button" value="Click Me" onclick"showMessage()&q ...
- JavaScript高级程序设计学习笔记----初识JavaScript
一.JavaScript概述 1.JavaScript 介绍: 简称JS,是一种浏览器解释型语言,嵌套在HTML文件中交给浏览器解释执行.主要用来实现网页的动态效果,用户交互及前后端的数据传输等. 2 ...
- JavaScript高级程序设计学习笔记第二十章--JSON
1.JSON:JavaScript Object Notation, JavaScript 对象表示法. 2.最重要的是要理解它是一种数据格式,不是一种编程语言.虽然具有相同的语法形式,但 JSON ...
- JavaScript高级程序设计---学习笔记(四)
1.全局变量不能通过delete操作符删除,而直接在window对象上定义的属性可以. var age = 29;window.color = "red";delete age;/ ...
最新文章
- EDA电子设计技术与应用
- hdu 5092 Seam Carving
- 10a 16a 插座区别_10A插座和16A插座有什么区别?
- 轻量级网络之mobilenet_v1
- inv(a) matlab,在MATLAB中,inv(A)表示的是()
- 平方根/立方根/根式
- plsql 记录型变量
- 信息学奥赛一本通(1317:【例5.2】组合的输出)
- EasyUI:datagrid清空所有选择行
- 佳能Canon PIXMA G1010 打印机驱动
- svn版本管理软件——svn分支管理
- web 打印时 表格多页 导致缺少线段 看上去页面不完整的处理方案
- PowerBI-筛选器函数-KEEPFILTERS
- Django的模板语言DTL介绍以及渲染方式
- android 应用变量,真正免root的应用变量详细使用教程
- 统信UOS系统安装详细教程(小白也能装系统啦~)
- windows防火墙是干什么的_我可以用windows防火墙做什么
- js实现:百钱买百鸡, 求红白黑球的个数
- rem和vw,vh的介绍
- 基于视觉导航的自主机器人简介(一)
热门文章
- 如何用研发流程搞垮一个团队?
- mybatis 一对一、一对多查询、多对多(使用注解)
- android 对java 支持_Android在未来对 Java 8 特性的支持
- testflight测试软件怎么,TestFlight使用步骤
- c# mysql 1062_C#中MySQL函数用DATASET 和 MySqlDataAdapter 操作数据库
- python--二叉树库函数
- django3数据库设计之商城项目
- jquery的ajax查询数据库,jquery中使用ajax获取远程页面信息
- 【文献阅读】Self-Normalizing Neural Networks
- Python之Pandas库常用函数大全(含注释)