zoukankan      html  css  js  c++  java
  • RequireJS入门(二) 转

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

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

    新建目录结构如下

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

    HTML 如下

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    <!doctype html>
    <html>
        <head>
            <title>requirejs入门(二)</title>
            <meta charset="utf-8">
            <style type="text/css">
                .wrapper {
                     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 如下

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    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 如下

    1
    2
    3
    4
    5
    6
    7
    8
    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对象)

    r2.zip

  • 相关阅读:
    Java反射研究(3)
    Java反射研究(2)
    Java反射研究(1)
    从百度文库中复制文本的方法
    jdk/bin中的native2ascii.exe使用
    EA经典入门教程
    JSP自定义标签(3)
    JSP自定义标签(1)
    将Java doc转换为chm的方法
    多态性——vptr和vtable
  • 原文地址:https://www.cnblogs.com/wanliyuan/p/5039155.html
Copyright © 2011-2022 走看看