位置: 编程技术 - 正文

JavaScript操作HTML DOM节点的基础教程(js+html)

编辑:rootadmin

推荐整理分享JavaScript操作HTML DOM节点的基础教程(js+html),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:html的javascript,JAVAscript操作office,JAVAscript操作word,html怎么用javascript,JAVAscript操作word,JAVAscript操作office,javascript+html,javascript+html,内容如对您有帮助,希望把文章链接给更多的朋友!

因为 DOM 的存在,这使我们可以通过 JavaScript 来获取、创建、修改、或删除节点。NOTE:下面提供的例子中的 element 均为元素节点。获取节点

父子关系

兄弟关系

通过节点直接的关系获取节点会导致代码维护性大大降低(节点之间的关系变化会直接影响到获取节点),而通过接口则可以有效的解决此问题。

通过节点直接的关系获取节点会导致代码维护性大大降低(节点之间的关系变化会直接影响到获取节点),而通过接口则可以有效的解决此问题。

NTOE:细心的人会发现,在节点遍历的例子中,body、ul、li、p节点之间是没有空格的,因为如果有空格,那么空格就会被当做一个TEXT节点,从而用ulNode.previousSibling获取到得就是一个空的文本节点,而不是 <li>First</li> 节点了。即节点遍历的几个属性会得到所有的节点类型,而元素遍历只会得到相对应的元素节点。一般情况下,用得比较多得还是元素节点的遍历属性。实现浏览器兼容版的element.children有一些低版本的浏览器并不支持 element.children 方法,但我们可以用下面的方式来实现兼容。

NOTE:此兼容方法为初稿,还未进行兼容性测试。接口获取元素节点

getElementById

获取文档中指定 id 的节点对象。

动态的获取具有指定标签元素节点的集合(其返回值会被 DOM 的变化所影响,其值会发生变化)。此接口可直接通过元素而获取,不必直接作用于 document 之上。

getElementsByClassName获取指定元素中具有指定 class 的所有节点。多个 class 可的选择可使用空格分隔,与顺序无关。var elements = element.getElementsByClassName('className');NOTE:IE9 及一下版本不支持 getElementsByClassName兼容方法

querySelector / querySelectorAll

获取一个 list (其返回结果不会被之后 DOM 的修改所影响,获取后不会再变化)符合传入的 CSS 选择器的第一个元素或全部元素。

NOTE: IE9 一下不支持 querySelector 与 querySelectorAll创建节点

创建节点 -> 设置属性 -> 插入节点

JavaScript操作HTML DOM节点的基础教程(js+html)

修改节点

textContent获取或设置节点以及其后代节点的文本内容(对于节点中的所有文本内容)。

NOTE:不支持 IE 9 及其一下版本。innerText (不符合 W3C 规范)获取或设置节点以及节点后代的文本内容。其作用于 textContent 几乎一致。

NOTE:不符合 W3C 规范,不支持 FireFox 浏览器。FireFox 兼容方案

插入节点

appendChild

在指定的元素内追加一个元素节点。

insertBefore

在指定元素的指定节点前插入指定的元素。

删除节点

删除指定的节点的子元素节点。

innerHTML

获取或设置指定节点之中所有的 HTML 内容。替换之前内部所有的内容并创建全新的一批节点(去除之前添加的事件和样式)。innerHTML 不检查内容,直接运行并替换原先的内容。NOTE:只建议在创建全新的节点时使用。不可在用户可控的情况下使用。

存在的问题+

低版本 IE 存在内存泄露 安全问题(用户可以在名称中运行脚本代码)

PS: appendChild() , insertBefore()插入节点需注意的问题使用appendChild()和insertBefore()插入节点都会返回给插入的节点,

值得注意的是,如果这两种方法插入的节点原本已经存在与文档树中,那么该节点将会被移动到新的位置,而不是被复制。

在这段代码中,页面输出的结果和没有Javascript时是一样的,元素并没有被复制,由于元素本来就在最后一个位置,所以就和没有操作一样。如果把id为test的元素的两个子元素点换位置,就可以在firbug中看到这两个div已经被调换了位置。如果我们希望把id为a的元素复制一个,然后添加到文档中,那么必须使被复制的元素现脱离文档流。这样被添加复制的节点被添加到文档中之后就不会影响到文档流中原本的节点。即我们可以把复制的元素放到文档的任何地方,而不影响被复制的元素。下面使用了cloneNode()方法,实现节点的深度复制,使用这种方法复制的节点会脱离文档流。当然,我不建议使用这种方法复制具有id属性的元素。因为在文档中id值是唯一的。

相似的操作方法还有 removeNode(node)删除一个节点,并返回该节;replaceNode(newNode,node)替换node节点,并返回该节点。这两种方法相对来说更容易使用一些。

JavaScript中循环遍历Array与Map的方法小结 js循环数组各种方法eg1:for(vari=0;imyStringArray.length;i++){alert(myStringArray[i]);//Dosomething}eg2:Array.prototype.foo="foo!";vararray=['a','b','c'];for(variinarray){alert(array[i]);}fo

详解JavaScript中数组和字符串的lastIndexOf()方法使用 Array.prototype.lastIndexOf和String.prototype.lastIndexOf是非常的实用的方法,不过很多人不知道它其实可以传递两个参数,第二个参数决定了搜索的起始位置:语

Javascript数组Array基础介绍 Javascript,一门神奇的语言,它的数组也同样独特。我们要去其糟粕,取其精华,把常用的最优实践总结出来。如有错误,请指出。javascript数组是一种类

标签: js+html

本文链接地址:https://www.jiuchutong.com/biancheng/369989.html 转载请保留说明!

上一篇:举例说明JavaScript中的实例对象与原型对象(举例说明Java实现适配器模式)

下一篇:JavaScript中循环遍历Array与Map的方法小结(javascript中循环结构包括)

  • 服务外包行业要交社保吗
  • 汇算清缴补交所得税后报表需要调整吗
  • 税务机关如何处理公司多交税
  • 工资薪金所得和劳务报酬所得的区别
  • 资源税的计税依据煤炭
  • 增值税发票是什么纸张型号
  • 购买税控盘分录怎么做
  • 企业需要政府哪方面政策支持
  • 备用金可以不要发票吗
  • 企业接受外部劳务派遣用工支出税前扣除问题
  • 发票不在业务发生地
  • 前期物业开办费和承接费一样吗
  • 境外支付佣金如何开发票
  • 预收账款缴纳企税怎么算
  • 货运代理可以开9个点的发票吗?
  • 公司贷款买车后影响公司收购吗
  • 集团控股公司
  • 营改增之后账务怎么处理
  • 可以自行设计的软件
  • 无形资产摊销表模板
  • 简化丢失专用发票的处理流程
  • 实收金额比应收金额多
  • 所得税不退税怎么写情况说明
  • 增资后可以减资吗
  • 进厂的政府补贴怎么拿
  • 在建工程暂估转固定资产
  • 红掌的养殖方法和注意事项
  • 子公司开票给母公司,冲减利润,怎么避免税务风险
  • ksysslim.exe是什么
  • 建筑企业预缴企业所得税怎么计算
  • 年金单位缴费计入个人账户(税前)
  • 企业所得税申报流程
  • 享受小型微利企业税收优惠的条件
  • 未分配利润与净利润关系
  • 华为od测试岗机试需要怎么准备
  • 文本超出单元格
  • 如何查询发票领到几月份了
  • 电子商业汇票业务
  • 收到劳务派遣发票可以抵扣吗
  • 法人如何提取公积金余额
  • web cms漏洞
  • okhttp3源码
  • 在建工程会计科目明细
  • 税务查账后如何结转
  • 金蝶k3如何设置现金流量表取数公式
  • 不抵扣勾选是什么
  • 完税证明能作为抵扣凭证吗
  • SQL查询中in和exists的区别分析
  • 个体工商户怎么开发票
  • 暂估入库价格是否含税
  • 收到土地使用权的租金
  • 收到员工社保
  • 科研专用费是什么
  • 归还银行的贷款会计分录
  • 上期留抵税额可以留多久
  • 简易计税项目的进项税能抵一般项目的销项税额吗?
  • 特殊销售方式下的销售额确认图文怎么做
  • 固定资产处置的会计科目
  • 环保局检查锅炉房都查什么
  • win7怎么装win8系统
  • win10预览版退回正式版
  • linux服务端
  • ubuntu for lot
  • Linux中终止某个用户的所有进程的简单方法
  • babylon.exe进程有什么作用 babylon进程是什么文件
  • ubuntu 04 10
  • win10应用商店更新软件更新不了
  • 新手如何入门
  • win10系统谷歌浏览器为什么打不开
  • Win10年度升级版将正式提供暗黑主题 未自定义颜色都会变暗
  • js组件是什么
  • jquery选择器的基本语法
  • shell 数组变量
  • pycharm支持python3.9
  • Android 自定义view
  • android 显示图片
  • python asyncio
  • 怎么在电脑上下载浙政钉
  • 涠洲岛船票售完
  • 每个省几个市
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设