上一篇是把整个jQuery库作为一个模块。这篇来写一个自己的模块:选择器。

为演示方便这里仅实现常用的三种选择器id,className,attribute。RequireJS使用define来定义模块。

新建目录结构如下

这次新建了一个子目录js,把main.js和selctor.js放入其中,require.js仍然和index.html在同一级目录。

HTML 如下

<!doctype html>
<html>
<head>
<title>requirejs入门(二)</title>
<meta charset="utf-8">
<style type="text/css">
.wrapper {
width: 200px;
height: 200px;
background: gray;
}
</style>
</head>
<body>
<div class="wrapper"></div>
<script data-main="js/main" src="require.js"></script>
</body>
</html>

这次把script标签放到了div的后面,因为要用选择器去获取页面dom元素,而这要等到dom ready后。

因为把main.js放到js目录中,这里data-main的值须改为“js/main”。

selector.js 如下

define(function() {

    function query(selector,context) {
var s = selector,
doc = document,
regId = /^#[\w\-]+/,
regCls = /^([\w\-]+)?\.([\w\-]+)/,
regTag = /^([\w\*]+)$/,
regNodeAttr = /^([\w\-]+)?\[([\w]+)(=(\w+))?\]/; var context =
context == undefined ?
document :
typeof context == 'string' ?
doc.getElementById(context.substr(1,context.length)) :
context; if(regId.test(s)) {
return doc.getElementById(s.substr(1,s.length));
}
// 略...
} return query;
});

define的参数为一个匿名函数,该匿名函数执行后返回query,query为函数类型。query就是选择器的实现函数。

main.js 如下

require.config({
baseUrl: 'js'
}); require(['selector'], function(query) {
var els = query('.wrapper');
console.log(els)
});

require.config方法执行配置了baseUrl为“js”,baseUrl指的模块文件的根目录,可以是绝对路径或相对路径。这里用的是相对路径。相对路径指引入require.js的页面为参考点,这里是index.html。

把目录r2放到apache或其它web服务器上,访问index.html。

网络请求如下

main.js和selector.js都请求下来了。

selector.js下载后使用query获取页面class为“.wrapper”的元素,控制台输出了该元素。如下

总结:

  1. 使用baseUrl来配置模块根目录,baseUrl可以是绝对路径也可以是相对路径
  2. 使用define定义一个函数类型模块,RequireJS的模块可以是JS对象,函数或其它任何类型(CommonJS/SeaJS则只能是JS对象)

下载

最新文章

  1. 安卓初級教程(4):sqlite建立資料庫
  2. Sap SE16n 修改表数据
  3. Java开发中经典的小实例-(二分法)
  4. js对象常用2中构造方法
  5. 向Array中添加改进的冒泡排序
  6. GCC 编译优化指南
  7. 链接中 href=&#39;#&#39; 和 href=&#39;###&#39; 的区别以及优缺点
  8. github创建tag
  9. 一个人的旅行HDU 2066 floyd
  10. NPOI:创建Workbook和Sheet
  11. 64 位 Windows 平台开发注意要点之文件系统重定向
  12. Spring Security(二十六):8. Spring Security Community
  13. centos之Too many open files问题-修改linux最大文件句柄数
  14. mvc4+entityFramework5 发布时遇到的纠结问题
  15. djkstra nlogn
  16. 关于try catch
  17. UWP开发入门(四)——自定义CommandBar
  18. mysql的启动,停止与重启
  19. 设置zookeeper开机自启动
  20. Android内存优化10 内存泄漏常见情况1 静态泄漏

热门文章

  1. lesson5:Condition的原理分析及demo展示
  2. java对象的内存分配
  3. bug记录-setTimeout、setInterval之IOS7
  4. 关于this的指向问题
  5. CSS背景特殊属性值
  6. AngularJs练习Demo17 ngRoute
  7. Session生命周期讨论
  8. 深入了解session
  9. phpmyadmin自增字段
  10. POJ1840 hash