requirejs

//index.html
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
    <!--
<script data-main="js/main" src="require.js"></script>
-->

<script data-main="js/test" src="js/require.js"></script>
</head>
<body>
<script>
</script>
</body>
</html>

 

//test.js

requirejs.config({
//默认相对于html页面, baseUrl指定为相对页面下的js目录 baseUrl : "js",
//这个可以是缩写 paths : { },
//这个里面指定的是顺序,就像backbone需要jq和underscore一样; shim : [] });
//加载lib目录下的test1,并执行返回对象下的App requirejs(["lib/test1"],function(test1){ test1.App(); })

  

test1.js

//依赖模块m1 和 m2
//如果依赖是以".." “/”做开头或者是“.js"作结尾查询目录的方式就不是根据正常的查找了
define(["model/m1","model/m2"],function (m1,m2) { return { App : function(){ console.log( m1 ); m2; return "App is runing" } }; });

  

model/m1.js

define(function(){
    return "m1"
})

  

model/m2.js

//这个又是依赖控制器c1 和 c2了;
//这个是变成当前目录上的目录下的/controller/xx define(["../controller/c1","../controller/c2"],function(c1,c2){ console.log( c1 ) console.log( c2 ); return "m2" })

  

//controller/c1.js

define(function(){
    return "this is c1"
})

  

//controller/c2.js

//这个又开始依赖view目录下的v1了,
define(["view/v1"],function(v1){ return "this is c2" })

  

//如此就变成一个个模块了,开发就方便一些了,代码就不会一大堆了

你可能感兴趣的:(requirejs)