javascript - 将js模块化的问题

查看:174
本文介绍了javascript - 将js模块化的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

(function(factory) {
    if (typeof define === 'function') {
        // 如果define已被定义,模块化代码
        define('sayHello', ['jquery'], function(require, exports, moudles) {
            factory(require('jquery')); // 初始化插件
            return jQuery; // 返回jQuery
        });
    } else {
        // 如果define没有被定义,正常执行jQuery
        factory(jQuery);
    }
} (function($) {
    console.log('init', $);
    $.sayHello = function() {
        console.log("Hello");
    };
}));

我的疑问在于
1.这个也属于自执行函数的一种写法吗?
2.factory是什么意思。
3.对这个的整个流程比较模糊
求大神帮助。。。。

解决方案

答案重置:

卧槽,手机版的sf真他妈神了,误点了删除按钮也没个提示就直接把我的答案给删了|_|

重新编辑答案:

这是一段不太典型的umd格式代码。

umd的目标很简单,就是希望这个库能够成功的运行在AMD, CommonJS以及普通的<script>标签加载的环境里。

常见的umd声明方式如下:

if( typeof define === "function" && define.amd ){
    //如果使用者的环境是`requirejs`加载器,那把该库的具体实现通过`define`关键字声明
    define(factory);
} else if( typeof module != "undefined" && typeof module.exports != "undefined" ){
    //如果使用者的环境是nodejs,或者webpack,browserify等加载器,那通过commonjs的模块方式暴露
    module.exports = factory();
} else {
    //最后如果使用者就是直接在html里通过<script src="xxx">的方式引入该库,那把该库的内容直接挂在window对象上 
    window["Sortable"] = factory();
}

factory就是你要开发的库的具体实现体

这篇关于javascript - 将js模块化的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆