0. 使用环境

Dojo版本:1.14.2

此次总结以dojo的base为主,即不需要手动引入组件

1. 常用不归类方法

1.1. dojo.addOnLoad

在页面加载完成并且dojo.require语句的请求也返回了结果之后执行

dojo.addOnLoad(function () {
/* Any content that depends upon dojo.require statements goes here... */
});

1.2. dojo.isXXX

1.2.1. 检测底层浏览器

用于检测浏览器, 源代码位于\dojo\_base\sniff.js,当前版本不推荐直接使用,而是使用dojo.sniff,但是直接使用很方便。

如果是,返回对应浏览器的版本号。

dojo.isIE
dojo.isFF // 是否为FireFox
dojo.isChrome
...

1.2.2. 检测类型

代码位于js/dojo/1.14.2/dojo/_base/lang.js

dojo.isString
dojo.isArray
dojo.isFunction
dojo.isObject
dojo.isArrayLike
dojo.isAlien // 是内置函数或ActiveX组件之类的本地函数

1.3. 通过模块管理源代码

dojo.provide    //
dojo.require //
dojo.declare // 声明构造函数

2. DOM操作

2.1. 查找节点

2.1.1. dojo.byId

替代document.getElementById的方法。

2.1.2. dojo.query

通过CSS3风格的语法实现快速查询节点

dojo.query("d2");
dojo.query(".cc");
dojo.query("div#d3");
dojo.query("div.cc");
dojo.query("form[name='foo']");

2.2. 构造节点

dojo.toDom(("<tr><td>First!</td></tr>"));       // 字符串转DOM
dojo.create("tr"); // 返回节点
dojo.empty("d1"); //清空节点内容
dojo.place("d2","d1"); // 将d2节点放在d1节点内,作为最后一个子节点
dojo.place("d2","d1","before"); // 将d2节点放在d1节点之前,第三个参数的值域为:before, after, replace, only, first, last

2.3. DOM实用功能

2.3.1. dojo.isDescendant

判定祖先

dojo.isDescendant('s1','d4');       // true

2.3.2. dojo.setSelectable

设置可选择性,是否可以选中

dojo.setSelectable("d1");           // 设置不可选中
dojo.setSelectable("d1",true); // 设置可选中

2.3.3. 为节点添加样式

2.3.3.1. dojo.style
dojo.style("d1", {
height : "100px",
width : "100px",
border : "solid 3px red"
});
2.3.3.2 对节点的class属性的操作

代码位于/dojo/_base/html.js/dojo/dom-class.js

dojo.hasClass("d4","ac");

// addClass,三种写法
dojo.addClass("d1","d1c");
dojo.addClass(dojo.byId("d1"),"d2c");
dojo.query("d1").addClass("d1c"); // 这里必须是 dojo/NodeList 才可以执行此操作 // 三种写法,同addClass
dojo.removeClass("d4","ac"); dojo.toggleClass("d4","ac") dojo.replaceClass("d4","dc","ac");

2.3.4. 操作属性

dojo.attr("d4","attr1");            // 获得d4节点的attr1属性
dojo.attr("d4","attr1","dd"); // 设置d4节点的attr1属性
dojo.hasAttr("d1","attr1");
dojo.removeAttr("d1","attr1")

3. 实用工具

3.1. 数组处理

// 查找元素位置
dojo.indexOf([1,2,3,4,3], 3); // 2
dojo.lastIndexOf([1,2,3,4,3], 3); // 4 // 根据条件测试元素
dojo.every([2,4,6], function (x) { return x % 2 == 0 }); // true
dojo.some([3,5,7], function f(x) { return x % 2 == 0 }); // false // 迭代操作元素
dojo.forEach([1,2,3], function(x) {
console.log(x);
}); // 转换元素
var z = dojo.map([2,3,4], function(x) {
return x + 1;
}); //returns [3,4,5] dojo.filter([2,3,4], function(x) {
return x % 2 == 0;
}); //returns [2,4] // every,some,forEach,map,filter支持简化的字符串式函数
// 以every为例,其他用法一样
[2,4,6].every(function (x) { return x % 2 == 0 });

3.2. JavaScript对象实用程序

3.2.1. dojo.mixin、dojo.extend

// mixin生成一个对象实例,该实例混入了其他对象的结果;
// extend修改的是一个函数的原型;
dojo.mixin
dojo.extend
function Man(  ) {
this.x = 10;
} function Myth( ) {
this.y = 20;
} function Legend( ) {
this.z = 30;
} var theMan = new Man;
var theMyth = new Myth;
var theLegend = new Legend; function ManMythLegend( ) {} // dojo.mixin
// var theManTheMythTheLegend = new ManMythLegend;
// dojo.mixin(theManTheMythTheLegend, theMan, theMyth, theLegend); // dojo.extend
// dojo.extend(ManMythLegend, theMan, theMyth, theLegend);
// var theTheManTheMythTheLegend = new ManMythLegend;

3.2.2. dojo.clone

JavaScript提供的是浅复制,dojo提供的是深复制,根据需要选择

function foo(  ) {
this.bar = "baz";
} var foo1 = new foo;
var foo2 = foo1; // 浅复制 console.log(foo1.bar); // baz
console.log(foo2.bar); // baz foo1.bar = "qux"; console.log(foo1.bar); // qux
console.log(foo2.bar); // qux foo3 = new foo;
foo4 = dojo.clone(foo3); // 深复制 foo3.bar = "qux"; console.log(foo3.bar); // qux
console.log(foo4.bar); // baz

3.3. 事件相关

3.3.1. dojo.connect / dojo.disconnect

为节点添加UI事件

// 一次性事件
var handle = dojo.connect(dojo.byId("d1"), "onclick", function () {
console.log("d1...");
dojo.disconnect(handle);
});

3.3.2. dojo.keys

键码的标准化,代码位于 js/dojo/1.14.2/dojo/keys.js

dojo.keys.ENTER     // 13,回车键的码

3.3.3. 阻止事件

dojo.stopEvent(event);      // 抑制浏览器导航,并阻止事件冒泡,等同于   evt.preventDefault();evt.stopPropagation();

3.3.4. JSON

dojo.fromJson(/*String*/ json);     // 返回JSON对象
dojo.toJson(/*Object*/ json, /*Boolean?*/ prettyPrint); // 返回JSON字符串
dojo.fromJson('{"k1":"v1","k2":"v2"}');
dojo.toJson({'k1':'v1','k2':'v2'});
dojo.toJson({'k1':'v1','k2':'v2'}, true);

3.3.5. Ajax

dojo.xhr(/*String*/ method, /*Object*/ args, /*Boolean?*/ hasBody)
dojo.xhr("GET", {
url: 'http://localhost:63342/TestInIDEA/DOJO/html/main/1.html',
handle: function (loadOrError, response, ioArgs) { }
});

3.3.6. 表单

dojo.formToObject("register");
{first: "Foo", last: "Bar", favorites: Array(2)}
dojo.formToJson("register");
"{"first":"Foo","last":"Bar","favorites":["green","blue"]}"
dojo.formToQuery("register");
"first=Foo&last=Bar&favorites=green&favorites=blue"
dojo.queryToObject("first=Foo&last=Bar&favorites=green&favorites=blue");
{first: "Foo", last: "Bar", favorites: Array(2)}
dojo.objectToQuery(dojo.queryToObject("first=Foo&last=Bar&favorites=green&favorites=blue"));
"first=Foo&last=Bar&favorites=green&favorites=blue"

4. 使用扩展

  1. dojo.string
  2. dojo.date
  3. dojo.number
  4. dojo.currency
  5. dojo.Color
dojo.Color.named.black

参考资料

  • 《DOJO权威指南》

20190320 Dojo常用方法总结的更多相关文章

  1. Using dojo/query(翻译)

    In this tutorial, we will learn about DOM querying and how the dojo/query module allows you to easil ...

  2. AngularJs2与AMD加载器(dojo requirejs)集成

    现在是西太平洋时间凌晨,这个问题我鼓捣了一天,都没时间学英语了,英语太差,相信第二天我也看不懂了,直接看结果就行. 核心原理就是require在AngularJs2编译过程中是关键字,而在浏览器里面运 ...

  3. Dojo前端开发框架与jQuery前端开发框架,对比分析总结

    最近Dojo和jQuery双双发布了最新的1.8版本,有着相同版本号的两个Javascript库也有许多核心的相同之处:相同的资源加载机制AMD.相同的选择器 引擎Sizzle等.作为业界知名的Jav ...

  4. 前端开发:Javascript中的数组,常用方法解析

    前端开发:Javascript中的数组,常用方法解析 前言 Array是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array ...

  5. Jquery元素选取、常用方法

    一:常用的选择器:(李昌辉) 基本选择器 $("#myDiv") //匹配唯一的具有此id值的元素 $("div") //匹配指定名称的所有元素 $(" ...

  6. Dojo: Quick Start

      1.Dojo学习地址 2.Dojo快速开始 2.1.Dojo引入 2.2.指定Dojo模块的位置 2.3.模块加载require 3.查找Dom节点 3.1.根据id查找dom节点 3.2.根据c ...

  7. python浅谈正则的常用方法

    python浅谈正则的常用方法覆盖范围70%以上 上一次很多朋友写文字屏蔽说到要用正则表达,其实不是我不想用(我正则用得不是很多,看过我之前爬虫的都知道,我直接用BeautifulSoup的网页标签去 ...

  8. C# Webbrowser 常用方法及多线程调用

    设置控件的值 /// <summary> /// 根据ID,NAME双重判断并设置值 /// </summary> /// <param name="tagNa ...

  9. list,tuple,dict,set常用方法

    Python中list,tuple,dict,set常用方法 collections模块提供的其它有用扩展类型 from collections import Counter from collect ...

随机推荐

  1. Linux实践:文件破解

    Linux实践:文件破解 标签(空格分隔): 20135321余佳源 一.掌握NOP.JNE.JE.JMP.CMP汇编指令的机器码 NOP:NOP指令即"空指令".执行到NOP指令 ...

  2. Anaconda2和Anaconda3同时安装

    转载于:https://www.cnblogs.com/zle1992/p/6720425.html 1.先从网站(国内的清华镜像:https://mirrors.tuna.tsinghua.edu. ...

  3. <构建之法>8,9,10章的读后感

    第八章 这一章主要讲的是需求分析,主要介绍在客户需求五花八门的情况下,软件团队如何才能准确而全面地找到这些需求. 第九章 问题:我们现在怎样培养才能成为一名合格的PM呢? 第十章 问题:如果典型用户吴 ...

  4. java 值传递 数组传递

    在java中,不允许程序员选择值传递还是地址传递各个参数,基本类型总是按值传递.对于对象来说,是将对象的引用也就是副本传递给了方法,在方法中只有对对象进行修改才能影响该对象的值,操作对象的引用时是无法 ...

  5. SMBv1 is not installed by default in Windows 10 Fall Creators Update 2017 and Windows Server, Semi-annual Channel

    windows 10 rs3 release enable SMBv1 windows 10 rs3 release file sharing https://support.microsoft.co ...

  6. From CORBA technology To Thrift technology

    技术在变,需求不变,把复杂的事情搞简单,而不是相反. 无论CORBA还是Thrift,目标只有一个:一处定义,多处使用,解决的问题只有一个:规范和简化客户端与服务器的通信的开发工作. 是不是和java ...

  7. linux系统centOS7下搭建redis集群中ruby版本过低问题的解决方法

    问题描述: 在Centos7中,通过yum安装ruby的版本是2.0.0,但是如果有些应用需要高版本的ruby环境,比如2.2,2.3,2.4... 那就有点麻烦了,譬如:我准备使用redis官方给的 ...

  8. [CB]IPv6 在中国 - 大规模部署进行中 进展明显

    IPv6 在中国 - 大规模部署进行中 进展明显 2019年02月04日 08:21 3078 次阅读 稿源:solidot 0 条评论 中国有着世界上最大的网民人口,但它的 IPv6 普及度却处于世 ...

  9. Angular 简单的Post

    <!DOCTYPE html><html ng-app="myApp"><head lang="en"> <meta ...

  10. PHP 4种输出的方式

    <?php //测试用的数组 $info = array('11'=>'aaa', '22'=>'bbb', '33'=>'ccc'); //第一种,将整个数组作为一个对象输出 ...