小程序的模块化
2021/10/12 22:14:13
本文主要是介绍小程序的模块化,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
模块化
可以将一些公共的代码抽离成为一个单独的 js 文件,作为一个模块。模块只有通过 module.exports
或者 exports
才能对外暴露接口。
注意:
exports
是module.exports
的一个引用,因此在模块里边随意更改exports
的指向会造成未知的错误。所以更推荐开发者采用module.exports
来暴露模块接口,除非你已经清晰知道这两者的关系。- 小程序目前不支持直接引入
node_modules
, 开发者需要使用到node_modules
时候建议拷贝出相关的代码到小程序的目录中,或者使用小程序支持的 npm 功能。
module.export和exports的关联
- exports是module.exports的一个引用
- module.exports可以重新赋值,这就改变了导出的本质不在是一个对象
- export一旦重新赋值,改变不了导出的本质,依然还是一个对象
//a.js module.exports.a= "hello"; //b.js const b=require("./a.js") //require引入的方式是common规范,只能在node环境下运行不能直接在浏览器环境下运行 console.log(b)
此时我们node b.js可以在终端看到的是一个对象
module.exports对外暴露的是一个对象
此时我们将a.js中的暴露方法改变一下
exports.a= "hello";
可以看到两种暴露的方法,得到的结果一样,都是对象
二者的区别:
- exports是module.exports的一个引用
- module.exports可以直接复制,它将修改暴露的本质(暴露一个对象),exports直接赋值,它将不会暴露我们暴露的本质,依然是一个对象
此时我们修改a.js中的文件
module.exports="hello"
我们node b.js之后可以看到终端输出hello字符串
此时我们再修改a.js中的文件
exports="hello"
我们node b.js之后可以看到终端输出一个对象
module.exports和export暴露的区别:前者可以暴露多个成员或者模块,二后者只能暴露一个成员或者模块
module.exports={ a:"hello", fn:()=>console.log("fn函数") }
此时我们node b.js可以看到
我们改为exports可以看到
exports={ a:"hello", fn:()=>console.log("fn函数") }
此时暴露的只是一个空的对象
这篇关于小程序的模块化的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-09-28uniapp 小程序获取到数据库的换行符怎么展示-icode9专业技术文章分享
- 2024-09-20微信小程序全栈项目实战:从零开始的全面指南
- 2024-09-20微信小程序项目实战:零基础入门教程
- 2024-09-19微信小程序项目中miniprogram_npm文件跟node_modules文件的差别-icode9专业技术文章分享
- 2024-08-27小程序 单行显示,超出部分省略号显示的方法代码-icode9专业技术文章分享
- 2024-08-27微信小程序如何获取到特种设备的刘海屏高度-icode9专业技术文章分享
- 2024-08-27微信小程序如何获取苹果手机底部一横线高度信息方法代码-icode9专业技术文章分享
- 2024-08-27微信小程序 顶部状态栏标签背景为none但还是看不到状态栏什么原因-icode9专业技术文章分享
- 2024-08-21微信小程序全栈入门:从零开始的一站式指南
- 2024-08-21微信小程序入门:轻松打造你的第一款小程序