jQuery修改成SeaJs的模块代码非常简单,就是用下面这段语句将jQuery源代码包裹起来:

  1. define('jquery',[],function(require, exports, module){
  2. //这里放jQuery源代码
  3. module.exports = jQuery;
  4. });

也可以加一个判断,如果define已经被定义,就把jQuery模块化,如果define没有被定义,正常执行jQuery代码:

  1. /*
  2. * http://julabs.com
  3. */
  4. (function(factory) {
  5. if (typeof define === 'function') {
  6. define('/jquery', [], factory);
  7. }
  8. else {
  9. factory();
  10. }
  11. })(function(require) {
  12. //这里放jQuery源代码
  13. if (require) return $.noConflict(true);
  14. });

如果你用的是jQuery1.7版本以上的,那就更方便了。可以看下jQuery源码的最后几行,你会发现类似下方的代码:

  1. if ( typeof define === "function" && define.amd && define.amd.jQuery ) {
  2. define( "jquery", [], function () { return jQuery; } );
  3. }

如果判断语句为真,那么jQuery就会自动模块化。所以改下判断语句,只留typeof define === "function"jQuery便可以自动模块化:

  1. if ( typeof define === "function") {
  2. define( "jquery", [], function () { return jQuery; } );
  3. }

模块化后的调用代码如下:

  1. <script src="/script/sea.js"></script>
  2. <script>
  3. /*
  4. * http://julabs.com
  5. */
  6. seajs.config({
  7. 'base':'/script',
  8. 'alias':{
  9. 'jquery':'jquery.sea.js'
  10. }
  11. });
  12. seajs.use(['jquery'],function($){
  13. console.log($);
  14. });
  15. </script>

jQuery插件的模块化:

以一个简单的插件为例:

  1. /*!
  2. * http://julabs.com
  3. */
  4. (function($){
  5. $.sayHello = function(){
  6. console.log("Hello");
  7. };
  8. })(jQuery)

一般模块化代码像下面这样:

  1. /*!
  2. * http://julabs.com
  3. */
  4. (function (factory) {
  5. if (typeof define === 'function') {
  6. // 如果define已被定义,模块化代码
  7. define('jquerySayHello',['jquery'], function(){
  8. // 返回构造函数
  9. return factory
  10. });
  11. } else {
  12. // 如果define没有被定义,正常执行插件代码
  13. factory(jQuery);
  14. }
  15. }(function ($) {
  16. // 这里才是插件真正的构造函数
  17. console.log('init'); // 注意这行代码
  18. $.sayHello = function(){
  19. console.log("Hello");
  20. };
  21. }));

使用插件的代码如下:

  1. seajs.config({
  2. 'base':'/script',
  3. 'alias':{
  4. 'jquery':'jquery.sea.js',
  5. 'jquerySayHello':'jquery.sayHello.sea.js'
  6. }
  7. });
  8. seajs.use(['jquery','jquerySayHello'],function($,jquerySayHello){
  9. jquerySayHello($); // 初始化插件
  10. $.sayHello();
  11. });
  12. seajs.use(['jquery','jquerySayHello'],function($,jquerySayHello){
  13. jquerySayHello($); // 初始化插件
  14. $.sayHello();
  15. });

注意我在插件构造函数里面写的console.log('init');这段代码,可以看到,如果我请求两次插件,插件就要初始化两次。这个虽然可以让代码只在使用时才执行,减少了资源消耗,但如果一个页面中多处需要这个插件的话,就要执行很多次。如果改成下面这种,直接在本模块里就执行:

  1. /*!
  2. * http://julabs.com
  3. */
  4. (function (factory) {
  5. if (typeof define === 'function') {
  6. // 如果define已被定义,模块化代码
  7. define('jquerySayHello',['jquery'], function(require,exports,moudles){
  8. factory(require('jquery')); // 初始化插件
  9. return jQuery; // 返回jQuery
  10. });
  11. } else {
  12. // 如果define没有被定义,正常执行jQuery
  13. factory(jQuery);
  14. }
  15. }(function ($) {
  16. console.log('init');
  17. $.sayHello = function(){
  18. console.log("Hello");
  19. };
  20. }));

使用插件的代码如下:

  1. /*
  2. * http://julabs.com
  3. */
  4. seajs.config({
  5. 'base':'/script',
  6. 'alias':{
  7. 'jquery':'jquery.sea.js',
  8. 'jquerySayHello':'jquery.sayHello.sea.js'
  9. }
  10. });
  11. seajs.use(['jquery','jquerySayHello'],function($){
  12. $.sayHello();
  13. });
  14. seajs.use(['jquery','jquerySayHello'],function($){
  15. $.sayHello();
  16. });

可以看到,插件的构造函数只执行了一次。

seajs模块化jQuery与jQuery插件【转】的更多相关文章

  1. ***使用jQuery去封装插件(组件化、模块化的思想),即扩展方法

    如何使用jQuery去封装插件,区分扩展全局方法与扩展一个普通的jQuery实例对象的方法 1.给全局对象扩展方法:①$.方法 = function(参数可加可不加){}  ②使用:$.方法(有参数的 ...

  2. 使用requireJS的shim参数 解决插件 jquery.ui 等插件问题

    没有requireJS框架之前,如果我们想使用jquery框架,会在HTML页面中通过<script>标签加载, 这个时候jquery框架生成全局变量$和jQuery等全局变量.如果项目中 ...

  3. 推荐几款jquery图片切换插件

    一.前言 毕业季到了,大家都在匆匆忙忙的记录大学里最美好的时光,照片中各种花式.各种姿势都涌现出来了.这么多的照片怎么展示出来给自己的好友看呢?有人选择做成视频,有人选择ps之后做成图片集,而我选择利 ...

  4. 提升用户体验的最佳免费 jQuery 表单插件

    网页表单是一个老生常谈的话题.出于这样或那样的目的,一些示例中都会包括用户注册,电子商务结算,用户设置甚至联系人表格.而输入栏是非常容易用现代的CSS3技术来应用样式.但是到底什么决定整体用户体验? ...

  5. jQuery为开发插件提拱了两个方法:jQuery.fn.extend(); jQuery.extend();

    jQuery为开发插件提拱了两个方法,分别是: jQuery.fn.extend(); jQuery.extend(); jQuery.fn jQuery.fn = jQuery.prototype ...

  6. jQuery 人脸识别插件,支持图片和视频

    jQuery Face Detection 是一款人脸检测插件,能够检测到图片,视频和画布中的人脸坐标.它跟踪人脸并输出人脸模型的坐标位置为一个数组.我们相信,面部识别技术能够给我们的 Web 应用带 ...

  7. myWaterfall - jQuery瀑布流布局插件

    myWaterfall - jQuery瀑布流布局插件 Demo http://jsfiddle.net/q3011893/p5k2ogy8/embedded/result,html,css,js/ ...

  8. 推荐15款最佳的 jQuery 分步引导插件

    当用户浏览到一个网站,它可能从不知道如何浏览,如何操作网站或 Web 应用程序的内容和流程.在这篇文章中,我们编制了一些最好的 jQuery 引导插件列表.你会发现这些插件对于提高你的网站的整体用户体 ...

  9. Cropper – 简单的 jQuery 图片裁剪插件

    Cropper 是一个简单的 jQuery 图像裁剪插件.它支持选项,方法,事件,触摸(移动),缩放,旋转.输出的裁剪数据基于原始图像大小,这样你就可以用它们来直接裁剪图像. 如果你尝试裁剪跨域图像, ...

随机推荐

  1. python中的n次方表示法 **n

    例题:计算2的n次方,n由用户输入(N次方用**表示)# n=eval(input('手动输入n的值:')) #个人感觉,不确定是int还是float时,用eval来表示,eval后面接表达式# pr ...

  2. Dubbo必须会的知识点

    前言 应用架构演变: 单一架构ORM:单机构建网站,是一个高内聚版本,所有功能部署在一起.通过一个容器和JSP/Servlet技术或通过一些开源的框架如SSM以及SSH,通过数据库管理系统来存储数据. ...

  3. js图形打印

    1. 打印等边三角形 document.writeln("打印三角形</br>"); for(var i=0;i<5;i++){ for(var j=5;j> ...

  4. js中数组Array对象的方法sort()的应用

    一. sort()方法的介绍 //给一组数据排序 var arrNum = [12,1,9,23,56,100,88,66]; console.log("排序前的数组:"+arrN ...

  5. Sqlmap爆库命令的简单使用

    转载:https://blog.csdn.net/qq_41617034/article/details/89502428 测试地址:因为涉及商业隐私,这里就不列啦 我这里用的是windows,并没有 ...

  6. MyBatis学习(四)代码生成器MyBatis-Generator

    一.简介 前面写过一篇文章介绍了如何使用Mybatis,那么如果我门数据库中有许许多多的表的时候,每张表都手动去写对应的mapper的映射关系,会非常麻烦,那么我们可以使用代码生成器MyBatis-G ...

  7. php bypass disable function

    前言 最近开学,事太多了,好久没更新了,然后稍微闲一点一直在弄这个php bypass disable function,一开始自己的电脑win10安装蚁剑的插件,一直报错.怀疑是必须linux环境. ...

  8. 精心总结ansible-playbook剧本的这6种变量

    #变量作用 #根据需求灵活修改,如:需要安装不同版本号的服务,或进行版本升级回退等 1.通过vars定义变量 #1.1.定义一个变量 version: 1.1.2 #定义多个变量 vars: - v1 ...

  9. Mac 环境下配置 MySQL 以及 Mac终端登录MySQL

    1.首先mysql官网下载Mac 版 mysql直接安装 2.打开偏好设置-> MySQL -> 查看是否开启mysql服务 3.打开终端 进入mysql目录: /usr/local/my ...

  10. Spring Boot(二) :Redis 使用

    Redis 介绍 Redis 是目前业界使用最广泛的内存数据存储.相比 Memcached,Redis 支持更丰富的数据结构,例如 hashes, lists, sets 等,同时支持数据持久化.除此 ...