requirejs的GitHub:requirejs

r.js的GitHub:r.js

grunt-contrib-requirejs的GitHub:grunt-contrib-requirejs

  1. requirejs的一个典型配置,main.js

    require.config({
    shim: {
    '$': {
    exports: 'Zepto' //zepto.js里面暴漏的全局变量
    },
    '_': {
    exports: '_'
    },
    'B': {
    deps: [
    '_' //依赖关系
    ],
    exports: 'Backbone'
    }
    },
    paths: {
    '$': 'zepto', //配置路径
    '_': 'underscore',
    'B': 'backbone'
    }
    });
    requirejs(['$',''], function(b) {
    debugger;
    });

    关于config.shim.exports这里有很好的解释:shim.exports

  2. r.js的使用方法
    node r.js -o baseUrl=src name=main out=dist/build.js optimize=none

    这样用的话config.paths里面main.js里面的paths配置会无效,看这里的解释:

    r.js optimizer does not load paths defined by a require.config

  3. 关于第2点写两遍paths是重复劳动,r.js里面有一个mainConfigFile参数,将命令行改成这样

    node r.js -o name=main mainConfigFile=src/main.js out=dist/build.js optimize=none

    为什么name和mainConfigFile都指向main呢,因为工程里配置文件和启动文件都是main.js,我们完全可以分开放,

    src/config.js:

    require.config({
    shim: {
    '$': {
    exports: 'Zepto'
    },
    '_': {
    exports: '_'
    },
    'B': {
    deps: [
    '_'
    ],
    exports: 'Backbone'
    }
    },
    paths: {
    '$': 'zepto',
    '_': 'underscore',
    'B': 'backbone'
    }
    });

    src/main.js:

    requirejs(['$',''], function(b) {
    debugger;
    });

    然后运行:

    node r.js -o name=main mainConfigFile=src/config.js out=dist/build.js optimize=none

    r.js的配置文件说明看这里

  4. requirejs里嵌套依赖的问题:
    如果main.js不是这样依赖于1.js,而是像下面这样:
    requirejs(['$'], function(b) {
    requirejs(['1'],function() {
    });
    });

    那么用r.js生成的文件里是不会包含1.js的内容的,这种情况下要加上参数findNestedDependencies

    node r.js -o mainConfigFile=src/config.js name=main out=dist/build.js optimize=none findNestedDependencies=true
  5. 引用外部js的问题
    require.config({
    shim: {
    '$': {
    exports: 'Zepto'
    },
    '_': {
    exports: '_'
    },
    'B': {
    deps: [
    '_'
    ],
    exports: 'Backbone'
    }
    },
    paths: {
    '$': 'http://apps.bdimg.com/libs/zepto/1.1.4/zepto',
    '_': 'underscore',
    'B': 'backbone'
    }
    });

    zepto引用外部的js文件了,r.js无法访问

    $ node r.js -o mainConfigFile=src/config.js name=main out=dist/build.js optimize=none findNestedDependencies=true
    
    Tracing dependencies for: main
    Cannot optimize network URL, skipping: http://apps.bdimg.com/libs/zepto/1.1.4/zepto.js E:/chengzhichao/tmp/test_grunt/dist/build.js
    ----------------
    E:/chengzhichao/tmp/test_grunt/src/.js
    E:/chengzhichao/tmp/test_grunt/src/main.js

    r.js只把main.js,1.js弄到了build.js里面,这种情况下应该怎么办呢?
    a.忽略zepto.js的path
    b.将config.js包含进生成的build.js里面

    node r.js -o mainConfigFile=src/config.js name=main out=dist/build.js optimize=none findNestedDependencies=true include=config.js paths.$=empty:
  6. grunt-requirejs配置基本照搬r.js的配置

requirejs和r.js的心得的更多相关文章

  1. requireJs和r.js压缩工具

    上面release是执行命令 node r.js -o build.js 生成的,需要切换到目录require/tools下面,也就是 有r.js和build.js的目录,才能执行命令 代码目录如上: ...

  2. requirejs实验002. r.js合并文件. 初体验.

    requirejs的官网上有介绍如何使用r.js合并,压缩文件的.http://requirejs.org/docs/optimization.html https://github.com/jrbu ...

  3. 转:requirejs打包压缩r.js使用示例

    为了应对日益复杂,大规模的JavaScript开发.我们化整为零,化繁为简.将复杂的逻辑划分一个个小单元,各个击破.这时一个项目可能会有几十个甚至上百个JS文件,每个文件为一个模块单元.如果上线时都是 ...

  4. requirejs 使用实例r.js打包

    在这里,请先看基础文章与相关技术文档: 安装: npm init npm install requirejs --save npm install jquery@1.11.1 --save 创建基本目 ...

  5. requirejs原理深究以及r.js和gulp的打包【转】

    转自:http://blog.csdn.net/why_fly/article/details/75088378 requirejs原理 requirejs的用法和原理分析:https://githu ...

  6. requireJS中如何用r.js对js进行合并和压缩css文件

    我运行的环境是windows+node.js,首先是用npm安装requirejs(全局安装,即使用 'npm install requirejs -g',这样方便在各个目录调用),接着就是下载r.j ...

  7. requireJS的优化工具 ---- r.js

    requireJS是javascript的模块加载器,是基于AMD规范实现的. r.js是其提供的对模块进行打包和构建的一个工具 下载 r.js 创建r.js 的配置文件 build.js build ...

  8. requirejs的打包工具r.js

    不建议用命令行,还是用配置文件比较方便--build.js. 我的build.js文件内容大概如下: ( { appDir : './', baseUrl : './scripts', dir : ' ...

  9. 转: requirejs压缩打包r.js使用示例 2 (~~很详细的教程)

    这一篇来认识下打包工具的paths参数,在入门一中 就介绍了require.config方法的paths参数.用来配置jquery模块的文件名(jQuery作为AMD模块时id为“jquery”, 但 ...

随机推荐

  1. Asp.Net Mvc: 浅析TempData机制(转发 作者: Tristan G )

    Asp.Net Mvc: 浅析TempData机制 环境: Windows 2008, VS 2008 SP1, Asp.Net Mvc 1.0 --------------------------- ...

  2. 织梦dede标签tags的美化教程

    我们在行dede仿站的时候,经常会遇到tags标签的调用,调用非常简单,官方有专门的调用标签,但是官方的调用是一成不变的模式,dede5.6以前的版本,基本上都是黑色相同大小的表示,而在dede5.7 ...

  3. PHP之路——验证码实现

    验证码生成并保存到session <?php //开始session session_start(); //画布大小 $image = imagecreate(100, 40); $color ...

  4. IOS--UITextView 多行文本的输入和显示 的使用方法详细

    IOS--UITextView 多行文本的输入和显示 的使用方法详细   // UITextView的常用方法 主要用来输入和显示多行文本信息 UITextView *oneTextView = [[ ...

  5. 完整的struts.xml文件骨架

    完整的struts.xml文件骨架可以直接拿来用,修改一下就可以啦. <?xml version="1.0" encoding="UTF-8"?> ...

  6. Android Service 简介

    Service是Android系统中的一种组件,它跟Activity的级别差不多,但是它不能自己运行,只能后台运行,并且可以和其他组件进行交互.Service是没有界面的长生命周期的代码.Servic ...

  7. oracle_执行计划_谓词信息和数据获取(access and filter区别) (转)

    These two terms in the Predicate Information section indicate when the data source is reduced. Simpl ...

  8. javascript正则表达式(一)——语法

    前言 js中类RegExp类表示正则表达式,具有强大的模式匹配.文本检索和替换功能.正则表达式的模式规则是由一个字符序列组成,包括所有字母和数字在内,大多数的字符都是按照直接量匹配字符,某些特殊字符并 ...

  9. xamarin提供在线检查.net代码是否支援xamarin,ios,android

    大概是多少比你想的更多的移动.我们很高兴地宣布一个新的在线服务Xamarin NET移动扫描仪-扫描您的编译.NET代码的兼容性与Xamarin.iOSXamarin.Android是,Windows ...

  10. [Design Pattern] Observer Pattern 简单案例

    Observer Pattern,即观察者模式,当存在一对多关系,例如一个对象一有变动,就要自动通知被依赖的全部对象得场景,属于行为类的设计模式. 下面是一个观察者模式的简单案例. Observer ...