学员端小程序
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

92 lines
3.7 KiB

1 year ago
  1. # 为什么使用uni-config-center
  2. 实际开发中很多插件需要配置文件才可以正常运行,如果每个插件都单独进行配置的话就会产生下面这样的目录结构
  3. ```bash
  4. cloudfunctions
  5. └─────common 公共模块
  6. ├─plugin-a // 插件A对应的目录
  7. │ ├─index.js
  8. │ ├─config.json // plugin-a对应的配置文件
  9. │ └─other-file.cert // plugin-a依赖的其他文件
  10. └─plugin-b // plugin-b对应的目录
  11. ├─index.js
  12. └─config.json // plugin-b对应的配置文件
  13. ```
  14. 假设插件作者要发布一个项目模板,里面使用了很多需要配置的插件,无论是作者发布还是用户使用都是一个大麻烦。
  15. uni-config-center就是用了统一管理这些配置文件的,使用uni-config-center后的目录结构如下
  16. ```bash
  17. cloudfunctions
  18. └─────common 公共模块
  19. ├─plugin-a // 插件A对应的目录
  20. │ └─index.js
  21. ├─plugin-b // plugin-b对应的目录
  22. │ └─index.js
  23. └─uni-config-center
  24. ├─index.js // config-center入口文件
  25. ├─plugin-a
  26. │ ├─config.json // plugin-a对应的配置文件
  27. │ └─other-file.cert // plugin-a依赖的其他文件
  28. └─plugin-b
  29. └─config.json // plugin-b对应的配置文件
  30. ```
  31. 使用uni-config-center后的优势
  32. - 配置文件统一管理,分离插件主体和配置信息,更新插件更方便
  33. - 支持对config.json设置schema,插件使用者在HBuilderX内编写config.json文件时会有更好的提示(后续HBuilderX会提供支持)
  34. # 用法
  35. 在要使用uni-config-center的公共模块或云函数内引入uni-config-center依赖,请参考:[使用公共模块](https://uniapp.dcloud.net.cn/uniCloud/cf-common)
  36. ```js
  37. const createConfig = require('uni-config-center')
  38. const uniIdConfig = createConfig({
  39. pluginId: 'uni-id', // 插件id
  40. defaultConfig: { // 默认配置
  41. tokenExpiresIn: 7200,
  42. tokenExpiresThreshold: 600,
  43. },
  44. customMerge: function(defaultConfig, userConfig) { // 自定义默认配置和用户配置的合并规则,不设置的情况侠会对默认配置和用户配置进行深度合并
  45. // defaudltConfig 默认配置
  46. // userConfig 用户配置
  47. return Object.assign(defaultConfig, userConfig)
  48. }
  49. })
  50. // 以如下配置为例
  51. // {
  52. // "tokenExpiresIn": 7200,
  53. // "passwordErrorLimit": 6,
  54. // "bindTokenToDevice": false,
  55. // "passwordErrorRetryTime": 3600,
  56. // "app-plus": {
  57. // "tokenExpiresIn": 2592000
  58. // },
  59. // "service": {
  60. // "sms": {
  61. // "codeExpiresIn": 300
  62. // }
  63. // }
  64. // }
  65. // 获取配置
  66. uniIdConfig.config() // 获取全部配置,注意:uni-config-center内不存在对应插件目录时会返回空对象
  67. uniIdConfig.config('tokenExpiresIn') // 指定键值获取配置,返回:7200
  68. uniIdConfig.config('service.sms.codeExpiresIn') // 指定键值获取配置,返回:300
  69. uniIdConfig.config('tokenExpiresThreshold', 600) // 指定键值获取配置,如果不存在则取传入的默认值,返回:600
  70. // 获取文件绝对路径
  71. uniIdConfig.resolve('custom-token.js') // 获取uni-config-center/uni-id/custom-token.js文件的路径
  72. // 引用文件(require)
  73. uniIDConfig.requireFile('custom-token.js') // 使用require方式引用uni-config-center/uni-id/custom-token.js文件。文件不存在时返回undefined,文件内有其他错误导致require失败时会抛出错误。
  74. // 判断是否包含某文件
  75. uniIDConfig.hasFile('custom-token.js') // 配置目录是否包含某文件,true: 文件存在,false: 文件不存在
  76. ```