Dojo1.11官方教程文档翻译(3.1)Dojo DOM函数

2024-03-11 04:48

本文主要是介绍Dojo1.11官方教程文档翻译(3.1)Dojo DOM函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

3.1Dojo DOM函数

原文地址:https://dojotoolkit.org/documentation/tutorials/1.10/dom_functions/index.html
GitBook地址:https://www.gitbook.com/book/limeng1900/dojo1-11-tutorials-translation-in-chinese/details
转载请注明出处:http://blog.csdn.net/taijiedi13/ – 碎梦道


在本教程中,你将学到如何通过使用Dojo来简单的以跨浏览器的方式操作DOM。只需要基本DOM知识和几个Dojo函数,你就能够飞速且高效地创建、读取、更新和删除页面里的元素。

入门

对于基于浏览器的JavaScript而言,文档对象模型(DOM)就是一块可以画的玻璃板,我们把内容和用户界面放在上面展示给用户。如果我们想要在浏览器加载HTML时进行增大、替换或者添加,就要用JavaScript和DOM来实现。Dojo旨在通过提供几个便利的函数使DOM相关的工作更加容易和高效,它可以填补跨浏览器不兼容的问题并让常见操作更加简单。
下面通过一个包含无序列表来学习这些函数:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>Demo: DOM Functions</title><script src="//ajax.googleapis.com/ajax/libs/dojo/1.10.4/dojo/dojo.js"data-dojo-config="async: true"></script><script>require(["dojo/domReady!"], function() {});</script></head><body><ul id="list"><li id="one">One</li><li id="two">Two</li><li id="three">Three</li><li id="four">Four</li><li id="five">Five</li></ul></body>
</html>

这个页面已经有Dojo脚本标签了,你应该认识require代码块。所有操作DOM的代码必须等DOM准备好了才能执行。

检索

首先,为了使用DOM,我们需要知道如何从DOM获取元素。最简单的方法是使用dojo/dombyId方法。当你向dom.byId传递一个ID,你将获得带有这个ID的DOM节点对象。如果没有匹配到节点,将返回空对象。
它等同于使用document.getElementById,但是有两个优点:一是它更加简短,在一些浏览器getElementById实现带bug时它也能正常工作。dom.byId的另一个优秀特性是当给它传递一个节点时,它会立刻返回那个节点。这可以帮助我们创建同时使用字符串和DOM节点的API。下面看一个示例:

// Require the DOM resource
require(["dojo/dom", "dojo/domReady!"], function(dom) {function setText(node, text){node = dom.byId(node);node.innerHTML = text;}var one = dom.byId("one");setText(one, "One has been set");setText("two", "Two has been set as well");});

View Demo

setText 函数给节点设置文本,不过因为它传递节点参数给dom.byId,所以它输入一个节点ID的字符串或者一个DOM节点都可以。

创建

你经常会做的另一件事就是创建元素。Dojo不会禁止你用原生的document.createElement方法来创建元素,不过用它创建元素并设置必须的属性和特性非常啰嗦。而且跨浏览器也让我们有更多的理由使用更便利的dojo/dom-constructcreate方法来设置属性。
domConstruct.create参数如下:节点名称字符串,节点属性对象,可选的父节点或兄弟节点,相对父节点和兄弟节点的一个可选的位置(默认为“last”),它返回一个新的DOM元素节点。下面先看示例;

require(["dojo/dom", "dojo/dom-construct", "dojo/domReady!"],function(dom, domConstruct) {var list = dom.byId("list"),three = dom.byId("three");domConstruct.create("li", {innerHTML: "Six"}, list);domConstruct.create("li", {innerHTML: "Seven",className: "seven",style: {fontWeight: "bold"}}, list);domConstruct.create("li", {innerHTML: "Three and a half"}, three, "after");
});

View Demo
创建了一个内容为“Six”的列表项,并放进列表里。另一个新加列表项是以内容为“Seven”创建的,它的类名属性设为“seven”,它的样式是字体加粗。最后创建一个内容为“Three and a half”的列表项,来插入到ID是“three”的列表项后面。
你什么时候可以设置一个元素的内容属性innerHTML来创建元素?如果你已经有一个HTM字符串的内容,设置innerHTML会比较快。domConstruct.create可以用来创建一个元素但不马上把它放在DOM里,或者当你想要在不干扰其他兄弟节点的情况下插入或追加一个新元素。

布局

如果你已经有一个节点并且打算布置它,你需要使用domConstruct.place。参数如下:用来放置的DOM节点或者节点的字符串ID、一个作为引用的DOM节点或者节点的字符串ID、可选的位置字符串默认为“last”。跟domConstruct.create 里很像,其实domConstruct.create后台就是用的domConstruct.place。示例中,我们往页面添加了几个按钮:

<button id="moveFirst">The first item</button>
<button id="moveBeforeTwo">Before Two</button>
<button id="moveAfterFour">After Four</button>
<button id="moveLast">The last item</button>

这个例子定义了一个函数,使用domConstruct.place来移动列表的第三个节点:

require(["dojo/dom", "dojo/dom-construct", "dojo/on", "dojo/domReady!"],function(dom, domConstruct, on){function moveFirst(){var list = dom.byId("list"),three = dom.byId("three");domConstruct.place(three, list, "first");}function moveBeforeTwo(){var two = dom.byId("two"),three = dom.byId("three");domConstruct.place(three, two, "before");}function moveAfterFour(){var four = dom.byId("four"),three = dom.byId("three");domConstruct.place(three, four, "after");}function moveLast(){var list = dom.byId("list"),three = dom.byId("three");domConstruct.place(three, list);}// Connect the buttonson(dom.byId("moveFirst"), "click", moveFirst);on(dom.byId("moveBeforeTwo"), "click", moveBeforeTwo);on(dom.byId("moveAfterFour"), "click", moveAfterFour);on(dom.byId("moveLast"), "click", moveLast);
});

View Demo
位置参数的值可以是 “before”、”after”、”replace”、”only”、”first”和”last”。请看 reference guide for domConstruct.place 了解每项的效果。
在这个简单的例子里, domConstruct.place比原生的parentNode.appendChild(node)做的更多一点。它的价值在于用同一个API很容易地指定位置,不管它引用的是一个父节点或者兄弟节点。

销毁

通常你会创建节点,但是偶尔你也要移除节点。在Dojo里有两种方式:domConstruct.destroy会销毁节点和它所有的子节点,domConstruct.empty将销毁给出的节点的子节点。它们都将一个DOM节点或者一个节点的字符串ID作为唯一参数。下面我们将往页面里添加两个按钮:

<button id="destroyFirst">Destroy the first list item</button>
<button id="destroyAll">Destroy all list items</button>
function destroyFirst(){var list = dom.byId("list"),items = list.getElementsByTagName("li");if(items.length){domConstruct.destroy(items[0]);}
}
function destroyAll(){domConstruct.empty("list");
}// Connect buttons to destroy elements
on(dom.byId("destroyFirst"), "click", destroyFirst);
on(dom.byId("destroyAll"), "click", destroyAll);

View Demo
第一个按钮每次点击会销毁列表中的第一项,第二个完全清空列表。

小结

目前,我们有一个很全面的工具集,可以进行简单的DOM操作,从节点的创建、移动到销毁,但它们都只在一个节点上工作。如果你想要处理的节点没有ID呢?下一个教程关于dojo/query,基于CSS选择器来查找和处理节点。

这篇关于Dojo1.11官方教程文档翻译(3.1)Dojo DOM函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/796686

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C