本文实例讲述了seajs和requirejs模块化。分享给大家供大家参考,具体如下:
如今,webpack、gulp等构件工具流行,有人说seajs、requirejs等纯前端的模块化工具已经被淘汰了,我不这么认为,毕竟纯前端领域想要实现模块化就官方来讲,还是有一段路要走的。也因此纯前端的模块化工具依然有价值,而且就我了解一些中小企业一直都在用纯前端的模块化手段。
如今,重新关注seajs和requirejs,不求理解多么深刻,要求会用能用就可以。
模块化的起因是传统的直接引入js方法存在问题:
下面是seajs和requirejs的简单案例。
seajs 我用的seajs版本是2.2.3
html部分
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>极客学院首页</title> </head> <body> <button id="testbtn0">测试按钮0</button> <button id="testbtn1">测试按钮1</button> <script type="text/javascript" src="./js/sea.js"></script> <script type="text/javascript"> seajs.use('./js/main'); </script> </body> </html>
main.js文件
define(function(require,exports,module){ //引入两个js文件 require("test0"); require("test1"); })
test0.js
define(function(require,exports,module){ var $$=require("common").$$; var testbtn0=$$("#testbtn0"); testbtn0.addEventListener("click",function(e){ alert(e.target.innerText); }); })
test1.js
define(function(require, exports, module) { var $$ = require("common").$$; var testbtn1 = $$("#testbtn1"); testbtn1.addEventListener("click", function(e) { alert(e.target.innerText); }); })
coomm.js
define(function(rerquire,exports,module){ /*//第一种导出方案 exports.$$=function(tag){ return document.querySelector(tag); }*/ //第二种导出方案 module.exports={ $$:function(tag){ return document.querySelector(tag); }, test:"测试数据" } //第三种导出方案 /* return { $$:function(tag){ return document.querySelector(tag); }, test:"测试数据" }*/ })
以上是为seajs的,而requirejs的直接就是该一下html文件就可以了,真是哭笑不得啊。才发现二者是通过的。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>极客学院首页</title> </head> <body> <button id="testbtn0">测试按钮0</button> <button id="testbtn1">测试按钮1</button> <script type="text/javascript" data-main="./js/main" src="./js/require.js"></script> </body> </html>
关于导出接口有三种,分别是exports,用来导出变量;然后是module.exports用于导出对象;最后是return直接返回。
最后对seajs和requirejs的不通点做个总结,选择seajs作者github:
个人总结的不同是:
CMD,seajs 推崇依赖就近,AMD ,requirejs推崇依赖前置,实际是两者在简单实现上,是可以一致的。就比如本文的例子。
seajs比如requirejs小很多。
更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。