一,为什么使用模块化,什么时候使用,二,使用的体会,三,怎么使用模块化
1.图片预览
2.用户登录状态
3.弹框
4.页面跳转
二,使用的问题
页面传参的问题,参数的传入,传出,以及保存,
使用return,的方式
个人简单的实践原理,进行函数的封装,需要的时候调这个js就好
1.ceshi.js
//函数
function getAreaInfo() {
var data = [{
'id':
1},{
'id':
2}];
console.log(
1)
}
//数据
var data = [{
'id':
1 }, {
'id':
2 }];
module.exports.data = data
exports.getAreaInfo = getAreaInfo
2.index.js
//引入
const util =
require(
'../../utils/ceshi.js')
onLoad:
function(){
util.getAreaInfo()
console.log(util.data)
}
输出的结果
微信官方的
模块化
可以将一些公共的代码抽离成为一个单独的 js 文件,作为一个模块。模块只有通过 module.exports
或者 exports
才能对外暴露接口。
需要注意的是:
exports
是module.exports
的一个引用,因此在模块里边随意更改exports
的指向会造成未知的错误。所以更推荐开发者采用module.exports
来暴露模块接口,除非你已经清晰知道这两者的关系。- 小程序目前不支持直接引入
node_modules
, 开发者需要使用到node_modules
时候建议拷贝出相关的代码到小程序的目录中。
// common.js
function sayHello(name) {
console.log(`Hello ${name} !`)
}
function sayGoodbye(name) {
console.log(`Goodbye ${name} !`)
}
module.exports.sayHello = sayHello
exports.sayGoodbye = sayGoodbye
在需要使用这些模块的文件中,使用 require(path)
将公共代码引入
var common = require('common.js')
Page({
helloMINA: function() {
common.sayHello('MINA')
},
goodbyeMINA: function() {
common.sayGoodbye('MINA')
}
})
Tips
tip
: require 暂时不支持绝对路径