//module1.js module.exports = { msg : 'module1', foo(){ console.log(this.msg); } }
//module2.js module.exports = function(){ console.log('module2'); } //至关于给exports对象赋值
//module3.js exports.foo = function(){ console.log('foo() module3'); } exports.boo = function(){ console.log('boo() module3'); } exports.arr = [1,2,3,4,4,6,6,5,2,1] //至关于给exports对象属性赋值
let uniq = require('uniq') //数组去重排序第三方包,是一个函数 let module1 = require('./modules/modules1') let module2 = require('./modules/modules2') let module3 = require('./modules/modules3') module1.foo() //module1 module2() //module2 module3.foo() //foo() module3 module3.boo() //boo() module3 console.log(uniq(module3.arr))
//module1.js module.exports = { msg : 'module1', foo(){ console.log(this.msg); } } //module2.js module.exports = function(){ console.log('module2'); } //至关于给exports对象赋值 //module3.js exports.foo = function(){ console.log('foo() module3'); } exports.boo = function(){ console.log('boo() module3'); } //app.js let module1 = require('./module1') let module2 = require('./module2') let module3 = require('./module3') module1.foo() module2() module3.boo() module3.foo()
<script src="./js/dist/build.js"></script>
//1.定义没有依赖的模块 define(function(){ return 模块 }) //2.定义有依赖的模块 define(['module1','module2'],function(m1,m2){ return 模块 })
require(['module1','module2'],function(m1,m2){ 使用m1 m2 })
//定义没有依赖的模块 define(function(){ let name = 'module1.js', function getName(){ return name } //暴露模块 return {getName} }) //定义有依赖的模块 define(['module1','jquery'],function(module1,$){ let msg = 'module2.js', function show(){ console.log(msg,module1.getName()) } $('body').css('backgroundColor','red') //暴露模块 return {show} }) //引入模块 (function(){ requirejs.config({ //baseUrl: 'js/lib', //基本的路径,和paths里面的路径要拼接 paths:{ //配置路径 module1:'./modules/module1', module2:'./modules/module2', jquery:'./libs/jquery-1.10.1' } }) requirejs(['module2'],function(module2){ module2.show() }) })() //html <script data-main="js/main.js" src="js/lib/require.js"></script>
//定义没有依赖的模块 define(function(reqiuire,exports,module){ exports.xxx = value module.exports = value }) //定义有依赖的模块 define(function(require,exports,module){ //同步引入依赖模块 let module2 = require('./module2') //异步引入依赖模块 require.async('./module3',function(module3){ }) //暴露模块 exports.xxx = value })
define(function(require){ let m1 = require('./module1') let m4 = require('./module4') m1.show() m4.show() })
define(function(require,exports,module){ let msg = 'module1' function foo(){ return msg } //暴露模块 module.exports = {foo} }) define(function(require,exports,module){ let msg = 'module2' function boo(){ console.log(msg) } module.exports = boo }) define(function(require,exports,module){ let data = 'module3' function fun(){ console.log(data) } exports.module3 = {fun} }) define(function(require,exports,module){ let msg = 'module4' //同步引入 let module2 = require('./module2') module2() //module2 //异步引入 require.async('./module3',function(module3){ module3.module3.fun() //module3 }) function fun2(require,exports,module){ console.log(msg) } exports.fun2 = fun2 }) define(function(require){ let module1 = require('./module1') module1.foo() //module1 let module4 = require('./module4') module4.fun2() //module4 }) //html <script src="js/lib/sea.js"></script> <script> seajs.use('./js/modules/main.js') </script>
3. 定义.babelrc文件 (rc:run control 运行时控制文件)javascript
//module1.js //暴露模块 分别暴露 export function foo() { console.log('foo() module1') } export function boo() { console.log('boo() module1') } export let arr = [1,2,3,4,5] //module2.js //统一暴露 function fun(){ console.log('fun() module2'); } function fun2(){ console.log('fun2() module2'); } //module3.js //默认暴露 能够暴露任意数据类型 暴露什么数据就是接受什么数据 export default ()=>{ console.log('默认暴露的箭头函数') } //默认暴露只能暴露一次,不然会报错,暴露多个数据能够放到一个对象中暴露 export {fun,fun2} //main.js //引入其余的模块 //import xxx from '路径' import $ from 'jquery' import {foo,boo,arr} from './module1' import {fun,fun2} from './module2' import module3 from './module3' $('body').css('backgroundColor','red') console.log(foo,boo,arr) console.log(fun,fun2) module3() //规定在使用分别暴露和统一暴露的时候,必需要用解构赋值的方法接受 //html <script src="js/dist/bundle.js"></script>