博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RequireJS入门(二) 转
阅读量:6811 次
发布时间:2019-06-26

本文共 1816 字,大约阅读时间需要 6 分钟。

上一篇是把整个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 {
                
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 如下

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对象)

 

转载于:https://www.cnblogs.com/wanliyuan/p/5039155.html

你可能感兴趣的文章
Metrics-Java版的指标度量工具
查看>>
ssh中懒加载问题org.hibernate.LazyInitializationException
查看>>
整理一波数组去重方法
查看>>
zkw好写吗
查看>>
二叉搜索树的第k个结点
查看>>
HMM模型详解
查看>>
Java 文件读写示例1
查看>>
tinyhttpd源码分析
查看>>
[转]BAT 批处理脚本 教程
查看>>
关于pthread_cond_wait()使用的理解
查看>>
openstack pike版本安装笔记6(dashboard组件,控制台)
查看>>
DBCC CHECKDB
查看>>
jsp实现验证码
查看>>
嵌入式开发之simulation--- 双目移动dsp机器人
查看>>
网站访问数据统计工具
查看>>
FTP 文件上传跟下载
查看>>
冲刺第五天
查看>>
ESP32 GPIO入门之闪灯
查看>>
ora-01033:oracle initialization or shutdown in progress 解决方法
查看>>
【原】oracle11g 客户端安装检测失败问题
查看>>