小程序环境切换自定义组件

news2025/1/30 16:22:30

背景:

最近一直有参与小程序的项目,发现切换环境时经常要上传然后再设置为体验版,比较麻烦,所以尝试做了个切换环境的组件,分享给大家,希望大家能用得上,提点建议

组件长这个样子

展开后

功能: 

该组件可全局拖拽,点击环境切换后,需重启小程序

原理:

利用小程序的storage,储存环境变量的切换,在加载appjs时,先获取环境变量,及时切换环境对应的资源地址

关键api:

wx.setStorage

wx.getStorage

wx.getStorageSync

关键代码:

components\envChange

import {
  envKey
} from './../../utils/util'
Component({
  data: {
    storageKey: envKey,
    show: false,
    showList: false,
    list: [{
        label: 'dev',
        value: 'develop',
      }, {
        label: 'test',
        value: 'test',
      }, {
        label: 'sit',
        value: 'sit',
      }, {
        label: 'uat',
        value: 'uat',
      },
      {
        label: 'trial',
        value: 'trial',
      }, {
        label: 'release',
        value: 'release',
      }, {
        label: '取消',
        value: 'cancel',
      }
    ],
    env: ""
  },
  methods: {
    async init() {
      let envWhiteList = ['develop', 'sit', 'test', 'trial', 'uat']
      let data = {
        show: envWhiteList.indexOf(__wxConfig.envVersion) !== -1 || false,
        showList: false,
        env: __wxConfig.envVersion
      }
      try {
        let cur = await this.getCurrentEvt()
        data.env = cur && cur.label
      } catch (error) {
        console.error(error)
      } finally {
        this.setData(data)
      }
    },
    showListFun() {
      this.setData({
        showList: true
      })
    },
    closeListFun() {
      this.setData({
        showList: false
      })
    },
    async envChoose(e) {
      const {
        item
      } = e.target.dataset
      if (item.value === 'cancel') {
        this.setData({
          showList: false
        })
      } else {
        await this.setEnv({
          key: this.data.storageKey,
          value: item.value
        })
        wx.showToast({
          icon: 'none',
          title: '请手动重启小程序(点击右上方三个点的气泡按钮里面的重新进入小程序)',
          duration: 5000
        })

        this.init()
      }
    },
    getCurrentEvt() {
      try {
        return this.getEnv(this.data.storageKey)
      } catch (error) {
        reject(error)
      }
    },
    setEnv(data) {
      return new Promise((resolve, reject) => {
        wx.setStorage({
          key: String(data.key),
          data: String(data.value),
          success: (res) => {
            resolve(res)
          },
          fail: (error) => {
            console.error(error)
            reject(error)
          }
        })
      })
    },
    getEnv(key) {
      return new Promise((resolve, reject) => {
        wx.getStorage({
          key,
          success: (res) => {
            const target = this.data.list.find(obj => obj.value === res.data)
            resolve(target)
          },
          fail: (error) => {
            reject(error)
          }
        })
      })
    }
  },
  ready() {
    this.init()
  },
})

config\modules.js

const develop = require('./develop')
const sit = require('./sit')
const test = require('./test')
const trial = require('./trial')
const uat = require('./uat')
const release = require('./release')

module.exports = {
    develop,
    sit,
    test,
    trial,
    release,
    uat,
}

config\getConfig.js

import {
  envKey
} from './../utils/util'
import modules from './modules'

function getConfig(arg) {
  const env = wx.getStorageSync(envKey)
  return modules[env || arg]
}

module.exports = getConfig

config\index.js

const getConfig = require('./getConfig')

module.exports = (function () {
    switch (__wxConfig.envVersion) {
        case 'develop':
            return getConfig(__wxConfig.envVersion);
            break;
        case 'trial':
            return getConfig(__wxConfig.envVersion);
            // return require('./trial.js');
            break;
        default:
            return require('./release.js');
            break;
    }
})()

全局引用该组件或局部引用都可以,最后别忘了全局引入config

源码在gittee:mini_program_code_part: 小程序代码片段https://gitee.com/qiu2046/mini_program_code_part.git

可以优化的点:

1.添加时间校验,过期删除

2.加密

tip:特别需要注意小程序的模块加载顺序和模块引入方式与常见项目的区别

参考资料:

pointer-events - CSS(层叠样式表) | MDN**pointer-events **CSS 属性指定在什么情况下 (如果有) 某个特定的图形元素可以成为鼠标事件的 target (en-US)。https://developer.mozilla.org/zh-CN/docs/Web/CSS/pointer-events微信小程序自定义服务器环境切换_醉逍遥neo的博客-CSDN博客_小程序多环境切换微信小程序由于生态圈的封闭性,很多功能不支持或者实现起来很繁琐,这次就分享一下项目里对于小程序服务器切换相关的配置及使用心得。首先要解释一下后面会出现的两个变量名:SERVER_MODE: 综合性的切换服务器模式,通过在代码里手动修改配置文件里的服务器模式值,用于测试、预发及上线时的版本切换及环境模式判断,包括各个接口服务器、h5域名服务器、第三方appId、自定义服务器等一键切换。SERVER_DEV_MODE:接口api的切换服务器,通过在特定入口里打开特定页面,在该页面里可选切换api服务器环境https://blog.csdn.net/u010059669/article/details/108979412wepy框架微信小程序api环境切换_穿不过的墙的博客-CSDN博客wepy 小程序开发项目环境(开发环境,测试环境,预发环境,线上环境)原公司小程序环境使用非常奇怪 (测试体验版为测试环境)(正式版体验版为预发环境)现又新增开发环境,那么在使用的时候岂不是每切换一个环境都的重新打包(很麻烦)一般来项目都会封装request请求 那么当前的api环境一般会写在独立的js再去引入,// API_URL为当前的api环境请求地址 if(!!wx.getStorageSync("API_URL")){ switch(wx.getStorageSync("APhttps://blog.csdn.net/weixin_44969815/article/details/106857126【解决方法】微信小程序 module "xxx/xxx.js" is not defined(开发工具正常,真机预览报错)_Bottle的博客-CSDN博客背景小程序开发,写了一个公共模块,方便其他页面使用。开发工具中使用一切正常,但是用真机预览的时候就会报错「module “xxx/xxx.js” is not defined」。查了一圈,基本确定了是小程序 js 加载顺序的问题,那解决思路自然就有了。解决方法将引用的代码放到页面的 onLoad 方法或者 app.js 的 onLaunch 方法中执行。比如我这里就是放到了 app.j...https://blog.csdn.net/zhyl8157121/article/details/105350698Javascript模块化编程(三):require.js的用法 - 阮一峰的网络日志https://www.ruanyifeng.com/blog/2012/11/require_js.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/39859.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JVM的垃圾回收机制(GC)

系列文章目录 JVM的内存区域划分_crazy_xieyi的博客-CSDN博客 JVM类加载(类加载过程、双亲委派模型)_crazy_xieyi的博客-CSDN博客 文章目录 一、什么是垃圾回收?二、java的垃圾回收,要回收的内存是哪些?三、回收堆上…

FPGA Base Xilinx跨时钟域宏XPM_CDC

FPGA Base Xilinx跨时钟域宏XPM_CDC最近看手底下的小伙子们写代码,对于跨时钟域的处理极度的不规范,还是放下这句话基础不牢,地动山摇 其实Xilinx公司已经为用户提供了宏定义,实现跨时钟域处理,见截图 XPM_CDC在命名上…

关于旅游景点主题的HTML网页设计——青岛民俗 7页 带登录注册

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材,DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 游景点介绍 | 旅游风景区 | 家乡介绍 | 等网站的设计与制作| HTML期末大学生网页设计作业 HTML:结构 CSS:样式 在操作方面上运…

【C++】简化源码——vector的模拟实现

文章目录一、前言二、无参构造&析构三、基础接口1.empty和clear2.size和capacity3.[]和iterator四、resize和reserve五、尾插尾删六、其他构造七、迭代器失效1.insert2.erase八、memcpy问题九、vector.h一、前言 本篇的目的很简单,只有一个:模拟实现…

C语言刷题(一)

🐒博客名:平凡的小苏 📚学习格言:别人可以拷贝我的模式,但不能拷贝我不断往前的激情 目录 用递归法求一个整数一维数组a的最大元素 猴子吃桃问题 奇偶数换位问题 水仙花数(0-100000) 换啤酒…

web前端电影项目作业源码 大学生影视主题网页制作电影网页设计模板 学生静态网页作业成品 dreamweaver电影HTML网站制作

HTML实例网页代码, 本实例适合于初学HTML的同学。该实例里面有设置了css的样式设置,有div的样式格局,这个实例比较全面,有助于同学的学习,本文将介绍如何通过从头开始设计个人网站并将其转换为代码的过程来实践设计。 文章目录一、网页介绍一…

redis命令行操作库、键、和五大数据类型详解

一、数据库操作命令 redis默认有16个数据库,类似数组下标从0开始,初始默认使用0号库。 1.1 测试是否连通 ping测试服务器是否连通 返回pone就是连通了 1.2 切换数据库 select index1.3 数据移动 move key db1.4 显示数据总量 dbsize1.5 数据清除 …

Maven 跳过测试的几种方式

在 Maven 对项目进行编译的时候,我们通常可能会希望跳过复杂的测试。 尤其是在开始项目还不是非常稳定的阶段。 命令行中使用 -Dmaven.test.skiptrue 在命令行,只要简单的给任何目标添加 maven.test.skip 属性就能跳过测试: mvn install …

leetcode:6251. 统计回文子序列数目【dp + 统计xy子序列出现的个数】

目录题目截图题目分析ac code总结题目截图 题目分析 固定了中间的数i后从两边选xy 和 yx对于x y的情况,比较简单预处理每个数字出现的index为ids然后看看两边x各自的个数n1 n2n1和n2必须大于等于2左边可以选n1 * (n1 - 1) // 2右边可以选n2 * (n2 - 1) // 2两边乘…

【C++】通过哈希表实现map和set

前言 在前面,我们通过红黑树这一底层结构实现了map和set。它们是关联式容器。而现在,我们将通过哈希表这一数据结构重新实现map和set,即unordered系列的关联式容器。因为它们的遍历是无序的,和平衡二叉树不同,不能做到…

APOLLO UDACITY自动驾驶课程笔记——规划、控制

1、路径规划使用三个输入,第一个输入为地图,Apollo提供的地图数据包括公路网和实时交通信息。第二个输入为我们当前在地图上的位置。第三个输入为我们的目的地,目的地取决于车辆中的乘客。 2、将地图转为图形 该图形由“节点”(node)和“边缘…

直流潮流计算matlab程序

一、直流潮流计算原理 直流潮流发的特点是用电力系统的交流潮流(有功功率和无功功率)等值的直流电流来代替。甚至只用直流电路的解析法来分析电力系统的有功潮流,而不考虑无功分布对有功的影响。这样一来计算速度加快,但计算的准确…

Rocket MQ : 拒绝神化零拷贝

注: 本文绝非对零拷贝机制的否定笔者能力有限,理解偏差请大家多多指正不可否认零拷贝对于Rocket MQ的高性能表现有着积极正面的作用,但是笔者认为只是锦上添花,并非决定性因素。Rocket MQ性能卓越的原因绝非零拷贝就可以一言以蔽之。 笔者企图…

第146篇 笔记-智能合约介绍

定义:当满足某些预定义条件时,智能合约是一种在区块链网络上运行的防篡改程序。 1.什么是智能合约 智能合约是在区块链网络上托管和执行的计算机程序。每个智能合约都包含指定预定条件的代码,这些条件在满足时会触发并产生结果。通过在去中…

IDEA热部署插件JRebel and XRebel

IDEA热部署插件JRebel and XRebel嘚吧嘚下载安装激活配置使用嘚吧嘚 刚开始用过一段时间的eclipse,其他方面没感觉,但是eclipse的热部署真的是深得我心啊😊。 后来换了IDEA,瞬间就心动了,各个方面真的很好用&#xf…

U3D VideoPlayer播放视频和坑点

最近做的游戏里,需要先播放一段几秒钟的工作室LOGO片头,拿到的视频是AVI格式,以前没在U3D里用到过视频,本以为很简单,没想到都2022年了,U3D播放视频还这么烂。。。 插件最好用的是AVPro,除非你有大量的视频要播放,否则没必要用插件,一个是贵,另一个插件很大。 首先…

Python爬虫从入门到进阶

前言 董伟明,国内某知名Python应用网站高级产品开发工程师,《 Python Web 开发实战》作者,本书目前已经售出 17k 余本,另外也已经在台湾地区上市。在 2012 和 2014 年分别通过 2 个爬虫免试获得 2 个业界知名公司 offer&#xff…

MyBatis缓存机制之一级缓存

MyBatis缓存机制之一级缓存 前言 MyBatis内部封装了JDBC,简化了加载驱动、创建连接、创建statement等繁杂的过程,是我们常见的持久性框架。缓存是在计算机内存中保存的临时数据,读取时无需再从磁盘中读取,从而减少数据库的查询次…

Node.js 入门教程 1 Node.js 简介

Node.js 入门教程 Node.js官方入门教程 Node.js中文网 本文仅用于学习记录,不存在任何商业用途,如侵删 文章目录Node.js 入门教程1 Node.js 简介1.1 大量的库1.2 Node.js 应用程序的示例1.3 Node.js框架和工具1 Node.js 简介 Node.js 是一个开源和跨平台…

子矩形计数(冬季每日一题 17)

给定一个长度为 nnn 的数组 aaa 和一个长度为 mmm 的数组 bbb。 两个数组均只包含 000 和 111。 利用两个给定数组生成一个 nmnmnm 的矩阵 ccc,其中 cijaibjc_{ij}a_ib_jcij​ai​bj​。 显然,矩阵 ccc 中也只包含 000 和 111。 请问,矩阵…