码迷,mamicode.com
首页 > Web开发 > 详细

RequireJS入门(二)

时间:2015-01-12 17:13:21      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:

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

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

 

新建目录结构如下

技术分享

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

 

HTML 如下

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        #wrapper {
            width: 200px;
            height: 200px;
            background: gray;
        }
    </style>
</head>
<body>
    <div id="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){
        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获取页面id为“#wrapper”的元素,控制台输出了该元素。如下

总结:

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

RequireJS入门(二)

标签:

原文地址:http://www.cnblogs.com/jymz/p/4218653.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!