2019独角兽企业重金招聘Python工程师标准>>>

有人最近要求我们写一个关于MooTools 1.2的30天的教程,这似乎也是个很不错的主意,于是我们决定现在就开始。在这些教程中,我们假设用户没有任何MooTools或者是JavaScript经验,但是至少有基本的HTML和CSS知识。

MooTools 1.2 JavaScript库介绍

MooTools 1.2是 个强大的轻量级的JavaScript库,专门为减轻Web中交互性JavaScript开发。在某种程度上,你可以认为MooTools是CSS的扩 展。例如,CSS可以让你在鼠标移上去时发生改变。JavaScript允许你接触更多的时间(点击事件、鼠标悬停事件、键盘事 件……),MooTools让这一切变得非常容易。

另外,MooTools还有各种各样的非常好的扩展,可以让你不只是改变一个元素的属性,还可以让你有”morph“(变形)或者”tween“(补间动画)属性,让你有能力去创建动画效果,就像你在我的导航菜单上看到的一样(Fdream注:原作者的,我的首页也有)。

这只是一个例子,MooTools可以让你做更多的事情。在接下来的30天里,我们将深入MooTools库,探索从数组(Array)和函数(Function)到Fx.Slide,以及其他捆绑插件的每一个东西。

引用MooTools 1.2

首先,下载并引用MooTools 1.2核心库。

  • 下载MooTools 1.2核心库
  • 把MooTools 1.2核心库上传到你的服务器或者工作区
  • 在你的HTML文档头部head标记之内链接MooTools 1.2核心库
参考代码:  [复制代码]  [保存代码]

(Fdream注:现在MooTools 1.2下载下来后,默认的后缀名是”.txt“,请更改后缀为”.js“。)

在Head标签之内添加Script标签

现在,你已经在你的页面中应用了了MooTools了,你还需要一个地方来写你的代码。这里有两种选择:

1. 把下面的代码写在你的head标签之内,你的代码写在script标记之内:

参考代码:  [复制代码]  [保存代码]

2. 在外部建立一个JavaScript文件,然后在页面头部链接此文件:

参考代码:  [复制代码]  [保存代码]

在这里,你可以使用任何一种方式。我通常把domready事件中调用的方法放在script标记之间,而我的函数放在外部文件中。

把代码放在domready中

MooTools的方法必须在domready事件中调用。

参考代码:  [复制代码]  [保存代码]
  1. window.addEvent('domready', function() {
  2. exampleFunction();
  3. });

(Fdream注:不完全是这样,但是可以保证你的JavaScript代码尽可能少地出错。顺便说一下domready事件:当页面的HTML代 码(不包括图片、flash等等,只是代码)下载完成时,此时会触发domready事件。这样可以在页面完全下载完成(包括图片、flash等都下载完 成)之前执行你的脚本,从而避免因为一张大图要下很长时间而导致脚本不能执行,从而出现异常。)

把代码放在一个函数中

你仍然可以在domready之外创建你的函数,然后在domready中调用它:

参考代码:  [复制代码]  [保存代码]
  1. var exampleFunction = function() {
  2. alert('hello')
  3. };
  4. window.addEvent('domready', function() {
  5. exampleFunction();
  6. });

关于库的详细介绍

在这第一讲中,我们会仔细地看了一下这个库架构的一些关键组件,然后粗略地看一下其他基本功能。

Core(核心)

核心(core)部分包含MooTools库的一些公共函数(Function)来完成一些常见的任务,也加强了许多原有功能(后面会有详细介绍)。下面的内容只是作为MooTools功能的一些例子,并不能替代您阅读MooTools的文档。

  • 检查一个值(如果没有值或者为0则返回false) - $chk(value);
  • 返回两个值之间的一个随机整数 - $random(min, max);
  • 可以更容易地检测浏览器、浏览器的引擎及浏览器的能力

(Fdream注:第一个描述有误,$chk(value)只是检查一个值是不是已经定义或者已经赋值,为0时会返回true,只有undefined或者null时返回false。)

Native(本地对象)

在库的这一部分也包含了一些公共工具,可以让你很容易地操作数组(Array,值或者对象的简单列表)、函数(Function)、数值(Number)、字符串(String)、哈希对象(Hash)和事件(Event)。这里是本地对象中的一些工具特性:

  • 对数组中的每个元素执行一段脚本 - .each();
  • 得到数组中的最后一个元素 - .getLast();
  • 每个x毫秒触发一个事件 - .periodical();
  • 对小数取整 - .round();
  • 把rgb转换为十六进制(HEX) - .rgbToHex();

Class(类)

一个JavaScript类(相对于CSS的类),是一个功能可以重复使用的对象。若要更多地了解MooTools类,你可以看看Valerio的这篇简单介绍的文章(MooTools类——怎样使用它们)。我也同时推荐David Walsh的MooTools类模板。

Element(元素)

MooTools库的Element类提供了一些非常有用的功能。通过这个类,你可以选择DOM元素、操控他们的属性和位置、改变他们的CSS风格。这里是MooTools提供的一些非常强大的处理DOM元素的工具:

  • 选择所有有相同ID或者CSS类名的DOM元素 - .getElements();
  • 给一个元素添加一个CSS类 - .addClass();
  • 取得一个元素的属性值 - .getProperty();
  • 改变一个元素的属性值 - .setProperty();
  • 取得一个元素的样式属性值 - .getStyle();
  • 改变一个元素的样式属性值 - .setStyle();
  • 取得一个元素的坐标位置 - .getCoordinates();

(Fdream注:不推荐在一个页面中有多个相同ID,最好不要出现,在一些浏览器下很容易出现不可预见的错误。)

Utilities(实用工具)

实用工具(Utilities)提供了更多精良的选择逻辑,包括domready事件、可以管理AJAX调用的工具、可以轻松管理cookie的工具,甚至还有”swiff“功能,可以提供JavaScript接口给ActionScript。

FX(效果)

这可能是MooTools最有趣的部分了。通过Fx(效果),你可以创建”Tween“(补间动画)和”morph“(形变动画)效果,从而让你的DOM对象动起来。

  • 在两个样式属性值之间创建一个动画变形(比如让一个div平缓地变大) - var myFx = new Fx.Tween(element);
  • 在多个不同的属性值之间创建一个动画变形(比如在让一个div平缓变大的过程中,让它的边框越来越初,同时变换它的背景颜色) - var myFx = new Fx.Morph(element);

Request(请求)

包含一些可以轻松处理JavaScript XMLHttpRequest(AJAX)功能的工具。为了减轻整个请求/响应(request/response)带来的痛苦,Request对象还有一些专门用来处理HTML和JSON对象(JavaScript对象表示法)的扩展。

Plugins(插件)

MooTools插件扩展了核心功能,可以轻松地为你的web项目添加高级UI功能。插件列表如下:

  • Fx.Slide
  • Fx.Scroll
  • Fx.Elements
  • Drag
  • Drag.Move
  • Color
  • Group
  • Hash.Cookie
  • Sortables
  • Tips
  • SmoothScroll
  • Slider
  • Scroller
  • Assets
  • Accordion

全局概览

在开始下一讲之前,花一点时间全面地看一下MooTools的文档。可能有些地方你看不太懂,不要管它,尽管通读它,然后吸收那些你懂的。在接下来 的29天中,我们将逐步深入这个库特定的部分,然后把MooTools分解成一些容易消化的小部分,但是首先,一定要好好看一下整个目录。

更多学习

一个压缩包,包含了你开始起步所需要的所有东西

包括一个MooTools 1.2核心库、一个简单的HTML文件、一个用来写你的函数的外部的JavaScript文件、一个CSS样式表文件。这个HTML文件已经已经写了详细的注释,并包含有domready事件。

其他的MooTools教程

同时,这里列出了一些其他帮助你开始的的MooTools教程。

MooTools 1.2 备忘录

这里是一份很好的MooTools 1.2功能的归纳表,我才给自己打印了一份,正在找地方把它给挂起来。也许我应该顺便拜访一下打印机,然后让它们给我提供一张海报大小的:)。不管怎样,这里是MooTools 1.2备忘录的链接。

Mootools论坛

如果你想和其他人讨论MooTools,检查代码示例或者深入讨论某个问题,你可以来这里。这才刚刚开张,但是正在逐渐热起来:MooTools 1.2论坛。

转载于:https://my.oschina.net/halfcoder/blog/11048

MooTools教程(1):认识MooTools相关推荐

  1. Mootools教程

    mootools教程1 http://microsoft.iteye.com/blog/432521 mootools教程2 http://xiangyuan8603.iteye.com/blog/1 ...

  2. MooTools教程(5):事件处理

    今天我们开始第五讲,在上一讲(<Mootools 1.2教程(4)--函数>)中,我们学习了在MooTools 1.2中建立和使用函数的几种不同方式.下一步就是理解事件了.和选择器类似,事 ...

  3. MooTools教程(4):函数和MooTools

    今天开始MooTools系列教程的第4讲.如果你还没有看过上一讲,请先查看上一篇教程<<Mootools 1.2教程(3)--数组使用简介>.今天我们先不讲MooTools,而是讲一 ...

  4. MooTools教程(3):数组管理DOM元素

    篇教程--<Mootools 1.2教程(2)--DOM选择器>中,我们介绍了一下选择器,其中有很多方法就会返回数组(一个你可以对其中内容进行多种操作的特殊列表).今天,我们在来看看如何使 ...

  5. MooTools教程(2):DOM选择器

    如果你还没有准备好,请先阅读上一篇<Mootools 1.2教程(1)--MooTools介绍>.我们讲了怎么引用MooTools 1.2以及怎么在domready里面调用你的脚本. 今天 ...

  6. 一周学会Mootools 1.4中文教程:(7)汇总收尾

    转眼之间已经第七课了,这也将成为最后一课,如果这7课下来您感觉水平没有达到预想的水平,没关系您可以继续关注本站的博文,我会陆续发一些类似的文章帮您提升水平,另外我最近打算和群里的几个Mootools爱 ...

  7. 流行的AJAX框架对比:jQuery,Mootools,Dojo,Ext JS

    来源:http://developer.51cto.com/art/200906/129502.htm 本文介绍了四种流行的AJAX框架,包括简洁的jQuery,面向对象的 Mootools,拥有强大 ...

  8. mootools的学习资源

    网上看到有朋友搜集了很多关于mootools的资料链接,非常好,感谢. 一.教程/文章/代码实例: http://clientside.cnet.com/wiki/mootorial/ --- The ...

  9. MooTools中文介绍

    MooTools是一个简洁,模块化,面向对象的JavaScript框架.它能够帮助你更快,更简单地编写可扩展和兼容性强的JavaScript代码. Mootools从Prototype.js中汲取了许 ...

最新文章

  1. 办公电脑选购方案指南
  2. Kubernetes — 调度系统
  3. Netty with protobuf(二)
  4. Cortex-M0微处理器异常入口流程的细节
  5. Linux中fork函数的作用及用法
  6. 机器学习-朴素贝叶斯分类
  7. Linux系统版本介绍
  8. ACL2020 | SongNet(格式可控的文本生成)
  9. x86代表电脑的操作系统是32位 和 x64代表电脑的操作系统是64位
  10. 【Node.js】论一个低配版Web实时通信库是如何实现的1( WebSocket篇)
  11. android studio 使用夜神模拟器
  12. 云上部署oracle rac,在青云上部署oracle rac全过程
  13. css中background的属性
  14. JAVA 实现签名和解签
  15. 模型上线和pmml简介
  16. 好玩的CMD几个命令
  17. Linux中搭建静态网站(练习题)
  18. android录音波浪动画_Android自定义View实现波浪动画
  19. 冰雪融化时,你能看到什么?
  20. 麓言信息广州学APP设计培训有哪些?

热门文章

  1. ExtJS-Grid框增加复选框checkbox
  2. 用户用老版IE访问网站时的jquery提示插件
  3. windows 7下同时安装visual studio 2012和2010
  4. 从oracle9i/92数据库中导出数据至 oracle 8.1.7 数据库中
  5. 转载 .net面试题大全(有答案)
  6. 4G EPS 中的 Control Plane
  7. Linux Kernel TCP/IP Stack — L1 Layer — NIC Controller — NAPI
  8. 高频变压器的磁饱和及变压器最大电流测量
  9. Newtonsoft.Json 概述
  10. POLARDB产品特性和通用业务场景