微信小程序-模块化

可以将一些公共的代码抽离成为一个单独的 js 文件,作为一个模块。模块只有通过 module.exports 或者 exports 才能对外暴露接口。

 

注意:

  • exports 是 module.exports 的一个引用,因此在模块里边随意更改 exports 的指向会造成未知的错误。所以更推荐开发者采用 module.exports 来暴露模块接口,除非你已经清晰知道这两者的关系。
  • 小程序目前不支持直接引入 node_modules , 开发者需要使用到 node_modules 时候建议拷贝出相关的代码到小程序的目录中,或者使用小程序支持的 npm 功能。

官方定义方式->

// common.js
function sayHello(name) {
  console.log(`Hello ${name} !`)
}
function sayGoodbye(name) {
  console.log(`Goodbye ${name} !`)
}

module.exports.sayHello = sayHello
exports.sayGoodbye = sayGoodbye

 也可以->

// common.js
function sayHello(name) {
  console.log(`Hello ${name} !`)
}
function sayGoodbye(name) {
  console.log(`Goodbye ${name} !`)
}

module.exports = {
  sayHello : sayHello
  sayGoodbye : sayGoodbye
}

 

 

 

使用->

var common = require('common.js')
Page({
  helloMINA: function() {
    common.sayHello('MINA')
  },
  goodbyeMINA: function() {
    common.sayGoodbye('MINA')
  }
})

 

 

同理,如果想定义一些全局常量可以如下写法:

url.js文件

module.exports = {
    baiduUrl: 'http://www.baidu.com',
    qqUrl: 'http://www.baidu.com'
};

 

使用:

const url= require('../url');

var mUrl  = url.baiduUrl

 

posted @ 2021-10-25 14:21  听着music睡  阅读(281)  评论(0编辑  收藏  举报