步加载的需求,所以node.js不支持AMD的异步模块化格式。在Lizard框架中的代码模块化采用的是requirejs这个加载器,支持AMD模
块。本文档介绍了node端版本的requirejs的用法,使得AMD模块也能在node端使用。
安装
安装requirejs
requirejs官方提供了一个可用于node的适配器r.js
。有两种方法可以在项目里面加入此库。
1. npm
在具体项目目录下使用如下命令来引入requirejs:
npm install requirejs
windows环境下安装需要注意不要加上-g
全局开关,否则不能正常安装。
安装完成后,可使用require('requirejs')
来加载requirejs。
2. 下载r.js
如果不想使用npm,也可以直接下载r.js,并把它放到项目中达到同样的目的。
点击下载。
在项目中通过require('/path/to/r.js')
来加载requirejs。
配置
配置requirejs
var requirejs=require('requirejs')
requirejs.config({
//把node自身的require方法传递给requirejs
nodeRequire: require
})
requirejs(["foo","bar"],function(foo,bar){})
在需要使用requirejs的地方可以用上面的代码来配置requirejs。首先加载requirejs模块,命名为requirejs
(可以为其他命名)。然后对requirejs
进行配置。配置的方法和参数可以参照浏览器版本的requirejs的配置说明
。不过有一点不同,如代码所示,我们需要把node的require
方法引进来。最后一行是简单地加载模块的示例,requirejs会尝试把foo
和bar
两个模块当成AMD模块来加载,如果失败,则会调用node的requie
方法来把它们当作commonjs模块加载。为了实现这样的适应性,所以我们需要配置node的require
方法。但实际测试并不尽如人意,保险起见,还是对AMD模块使用requirejs
加载,对commonjs模块使用require
加载。
构造AMD格式的node模块
在node中定义的模块是commonjs模块,如果想要构造AMD模块,我们需要 amdefine
这个包。
安装amdefine
同样,可以使用npm进行安装,在项目目录下执行:
npm install amdefine
在windows下也存在无法全局安装的问题,需要对项目单独安装。
定义define方法
if(typeof define !== 'function'){
var define=require('amdefine')(module)
}
amdefine提供了包装AMD模块的 define
方法。不过上面代码中对于node中是否包含define方法的检测判断请保留,最好原封不动地将这几行拷贝到自己的项目中。这样,我们就可以像使用前端requirejs一样,定义和使用AMD模块。
将node自己的common模块转换为AMD模块
原本想通过引用`amdefine`包来实现node端AMD模块的定义,不过requirejs本身定义了`define`方法,不必额外引入其他包。
你的这4个页面没有错 前提是你要打开frameset.html页面来运行程序如果你直接打开frame_quiz.html 或者 quiz_page2.html 都会报错的。因为你的js文件放到了secret_code.html里面 当你触发js事件的时候 可是找不到这个页面里的js代码的。所以会报错。
你只有打开frameset.html这个框架页 程序才会正确无误的运行。
------------------------------------------------------------------
那是浏览器的问题 跟你程序没关系 主流浏览器好用就可以呗。
360 IE FF 都可以的。