坑人的 Javascript 模块化编程 sea.js

忧伤 加 蛋疼的 开始了 看文档

  Sea.js 进行配置

  1. seajs.config({
  2.  
  3. // 设置路径,方便跨目录调用
  4. paths: {
  5. 'arale': 'https://a.alipayobjects.com/arale',        //这特么是不是调用标识呀 通过alias 别名来进行调用 狗日的说清楚呀
  6. 'jquery': 'https://a.alipayobjects.com/jquery'
  7. },
  8.  
  9. // 设置别名,方便调用
  10. alias: {
  11. 'class': 'arale/class/1.0.0/class',
  12. 'jquery': 'jquery/jquery/1.10.1/jquery'
  13. }
  14.  
  15. });
  1. // 加载一个模块 我屮艸芔茻 ,a 是哪个 哪个是a模块 你妹滴说清楚呀
  2. seajs.use('./a');
  3. // 加载一个模块,在加载完成时,执行回调
  4. seajs.use('./a', function(a) {
  5. a.doSomething();
  6. });
  7.  
  8. // 加载多个模块,在加载完成时,执行回调
  9. seajs.use(['./a', './b'], function(a, b) {
  10. a.doSomething();
  11. b.doSomething();
  12. });
  1. // 所有模块都通过 define 来定义
  2. define(function(require, exports, module) {
  3.  
  4. // 通过 require 引入依赖
  5. var $ = require('jquery');
  6. var Spinning = require('./spinning');
  7.  
  8. // 通过 exports 对外提供接口
  9. exports.doSomething = ...
  10.  
  11. // 或者通过 module.exports 提供整个接口
  12. module.exports = ...
  13. });

另一种

  1. define("js/main", ["jquery", "nivoslider", "css/nivo-slider.css", "css/default/default.css"], function (require) {    //[] 这他娘滴是啥
  2. var $ = require("jquery"),
  3. nav = require("./nav"),
  4. slider = require("./slider");
  5.  
  6. nav.render($(".nav:first"));
  7. slider.render();
  8. }),
  9. define("js/data", {
  10. navList: [
  11. {
  12. name: "案例展示",
  13. link: "gallery"
  14. }, {
  15. name: "服务条款",
  16. link: "service"
  17. }, {
  18. name: "联系我们",
  19. link: "contact"
  20. }
  21. ]
  22. }), //怎么还用上了json 我操

好了好了官方文档来了

  1. define(id?, dependencies?, factory);

id

当前模块的唯一标识。该参数可选。如果没有指定,默认为模块所在文件的访问路径。如果指定的话, 必须是顶级或绝对标识(不能是相对标识)。

dependencies

当前模块所依赖的模块,是一个由模块标识组成的数组。该参数可选。如果没有指定,模块加载器会从factory.toString() 中解析出该数组。

** 注意:强烈推荐不要设定 id 和 dependencies 参数。 在开发阶段,模块加载器会自动获取这两个参数。部署上线时,则可以通过优化工具来提取这两个参数。

factory

模块的工厂函数。模块初始化时,会调用且仅调用一次该工厂函数。factory 可以是函数, 也可以是对象、字符串等任意值,这时 module.exports 会直接设置为 factory 值。

factory 函数在调用时,会始终传入三个参数: requireexports 和 module, 这三个参数在所有模块代码里可用。

  1. define(function(require, exports, module) {
  2.  
  3. // The module code goes here
  4.  
  5. });

坑人的 Javascript 模块化编程 sea.js的更多相关文章

  1. 坑人的 Javascript 模块化编程 require.js

    坑人的 Javascript 模块化编程 require.js

  2. Javascript模块化编程require.js的用法

    JS模块化工具requirejs教程(一):初识requirejs http://www.runoob.com/w3cnote/requirejs-tutorial-1.html JS模块化工具req ...

  3. Javascript模块化编程 require.js使用详解

    一.为什么用require.js,产生的背景 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载. & ...

  4. Javascript模块化编程-require.js[3]

    很多情况下,JS都是放到一个或者多个文件里,只要加载这些文件就可以了. 但是对于一些小型项目而言,这种写法是没有任何问题的. 但是对于某些大型网站,JS的量是很大的,如果还采用这种方式,网站时常在加载 ...

  5. Javascript模块化编程(三):require.js的用法

    Javascript模块化编程(三):require.js的用法 原文地址:http://www.ruanyifeng.com/blog/2012/11/require_js.html 作者: 阮一峰 ...

  6. Javascript模块化编程之路——(require.js)

    转自:http://www.ruanyifeng.com/blog/2012/10/javascript_module.html Javascript模块化编程(一):模块的写法 随着网站逐渐变成&q ...

  7. (转)Javascript模块化编程(三):Require.js的用法

    转自 ruanyifeng 系列目录: Javascript模块化编程(一):模块的写法 Javascript模块化编程(二):AMD规范 Javascript模块化编程(三):Require.js的 ...

  8. 应用require.js进行javascript模块化编程小试一例

    长久以来都渴望应用javascript的模块化编程.今日紧迫更甚,岁月蹉跎,已经不能再等了. 拜读阮一峰的有关文章已经好几遍,文章写得真好,简洁流畅,头头是道,自觉有点明白了.但经验告诉我们,一定要亲 ...

  9. Javascript模块化编程-require.js

    转自:https://www.cnblogs.com/digdeep/p/4607131.html Javascript模块化编程(一):模块的写法 随着网站逐渐变成"互联网应用程序&quo ...

随机推荐

  1. 您应该将报表从Excel转换为Power BI的8个原因

    传统上,Microsoft Excel是企业的首选报告工具,但Power BI为企业提供了强大的分析和报告功能.通过快速实验可视化,广泛数据集的统计功能和计算,以及快速重组字段动态获得答案的能力,很明 ...

  2. 微软Power BI 每月功能更新系列——7月Power BI 新功能学习

    Power BI Desktop 7月产品功能摘要 7月是Power BI Desktop团队的重要发布!但由于官方延迟更新,我们的讲述也就更晚了一点,也许大家觉得没有必要了,都8月了,谁还看7月的? ...

  3. Oracle对象(视图、序列、索引)

    数据库对象:表.视图.序列.索引.同义词创建视图:create view 名 as 子查询描述结构:describe 对象名修改视图:create or replace view 名 as 子查询 视 ...

  4. 【转载】 深度学习总结:用pytorch做dropout和Batch Normalization时需要注意的地方,用tensorflow做dropout和BN时需要注意的地方,

    原文地址: https://blog.csdn.net/weixin_40759186/article/details/87547795 ------------------------------- ...

  5. c标签取数组中的对象值的2种方法

    1:循环遍历 <c:forEach items="${partsDeltailsList}" var="var" varStatus="vs&q ...

  6. day 016 面向对象---类与类的关系

    ---恢复内容开始--- 一  依赖关系(最轻的一种关系,在方法中引入另一个类的对象) class Elephant: def __init__(self,name): self.name=name ...

  7. HDU 1425 C++使用sort函数

    sort Time Limit: 6000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissi ...

  8. PTA——猴子吃桃

    PTA 7-35 猴子吃桃问题 #include<stdio.h> int main() { ; scanf("%d",&n); ; i<n; i++) ...

  9. hdu6440 Dream(费马小定理)

    保证 当  n^p=n(mod p) 是成立 只要保证n*m=n*m(mod p); #include<bits/stdc++.h> using namespace std; int ma ...

  10. vue项目的创建

    https://jingyan.baidu.com/article/456c463b359e630a5931444e.html