当前位置: 首页 > news >正文

用asp.net制作网站企业邮箱网页版

用asp.net制作网站,企业邮箱网页版,cnnic可信网站必须做吗?,给公司做的东西放到私人网站上前言 这篇文章主要介绍uniapp在Hbuilderx 中,通过工程化,区分不同环境、动态修改小程序appid以及自定义条件编译,解决代码发布和运行时手动切换问题。 背景 当我们使用uniapp开发同一个项目发布不同的环境二级路径不同时,这时候…

前言

这篇文章主要介绍uniappHbuilderx 中,通过工程化,区分不同环境、动态修改小程序appid以及自定义条件编译,解决代码发布运行时手动切换问题。

背景

当我们使用uniapp开发同一个项目发布不同的环境二级路径不同时,这时候我们就要根据环境来添加运行的基础路径

product:xxx-product-api.xxx.com:9002/productConf…

text:xxx-text-api.xxx.com:9002/textConfig/

但是当我们使用HBuilderX开发时你会发现manifest.json手动配置Web配置时只能配置一个像这种情况

碰到这种情况你会怎么处理?你是不是会在每次打包发布之前变更该环境对应基础路径?

在企业级的应用中,通常会分为,开发、联调、生产等多个环境,一个项目可能要发布到多个微信小程序,在工程化中,通过使用不同的打包命令设置不同的环境变量,解决不同环境各变量的内容需手动修改的问题,比如:接口、前缀、appid等;在使用uniapp开发项目时,通常使用Hbuilder可视化运行项目,点击运行编译出来都代码环境是(development),点击发布运行编译出来的代码是(production),分别对应开发和生产,使用process.env.NODE_ENV来获取运行环境。但是在很多企业项目中,就两个环境,很难满足使用场景。

为了解决以上问题,通过在package.json中增加增加 uni-app节点,自定义条件编译和环境,通过modifyManifest.js重写appid,扩展vue.config.js配置,用环境标识区分接口。

正文

当我们使用HX创建项目时项目中是没有package.json文件和vue.config.js文件的

1、在根目录下创建package.json文件,用于配置多个环境也可用于Hx自定义发行
{"dependencies": {"js-base64": "^3.7.5","moment": "^2.29.4"},"uni-app": {"scripts": {"wxTest": {"title": "微信小程序 测试","env": {"UNI_PLATFORM": "mp-weixin","NAME": "wxTest"}},"wxProd": {"title": "微信小程序 生产","env": {"UNI_PLATFORM": "mp-weixin","NAME": "wxProd"}},"h5Browser": {"title": "H5浏览器","browser": "hbuilderx","env": {"UNI_PLATFORM": "h5","NAME": "h5Browser"}}}},"devDependencies": {"postcss-preset-env": "^9.2.0","postcss-px-to-viewport": "^1.1.1","postcss-px-viewport": "^0.0.4","postcss-viewport-units": "^0.1.6"}
}
2、在根目录下创建env.js文件,用语配置不同环境变量下参数
// H5浏览器环境
const h5Browser = {baseUrl: 'https://xxx.xxx.com',filesUrl:'https://xxx.xxx.com',appid: 'wxf000000000000009',appName:'h5测试端'
}//微信小程序 测试环境
const wxTest = {baseUrl: 'https://xxx.xxx.com',filesUrl:'https://xxx.xxx.com',appid: 'wxf000000000000001',appName:'微信测试端'
}//微信小程序 生产环境
const wxProd = {baseUrl: 'https://xxx.xxx.com',filesUrl:'https://xxx.xxx.com', appid: 'wxf000000000000002',appName:'微信生产端'
}module.exports = {h5Browser,wxTest,wxProd,
}
3、在根目录下创建vue.config.js文件,用于处理不同环境配置不同的基础路径
// 导入fs模块
const fs = require('fs')
// 导入环境变量配置文件
const ENV_CONFIG = require('./env.js')
const manifestPath = `${__dirname}/manifest.json`;
let Manifest = fs.readFileSync(manifestPath, {encoding: 'utf-8'
})function replaceManifest(path, value) {const arr = path.split('.')const len = arr.lengthconst lastItem = arr[len - 1]let i = 0let ManifestArr = Manifest.split(/\n/)for (let index = 0; index < ManifestArr.length; index++) {const item = ManifestArr[index]if (new RegExp(`"${arr[i]}"`).test(item)) ++iif (i === len) {const hasComma = /,/.test(item)ManifestArr[index] = item.replace(new RegExp(`"${lastItem}"[\\s\\S]*:[\\s\\S]*`),`"${lastItem}": ${value}${hasComma ? ',' : ''}`)break}}Manifest = ManifestArr.join('\n')
}
// 读取环境变量内容
const appid = ENV_CONFIG[process.env.UNI_SCRIPT].appid
console.log('当前appId: ',appid)
if (appid) {replaceManifest('mp-weixin.appid', `"${appid}"`)
}const appName = ENV_CONFIG[process.env.UNI_SCRIPT].appName 
console.log('当前appName: ',appName)
if (appName) {replaceManifest('name', `"${appName}"`)
}fs.writeFileSync(manifestPath, Manifest, {flag: 'w'
})

参考uniapp官方文档:uniapp.dcloud.net.cn/collocation…

4、代码中调用

​ 代码中通过process.env.config[process.env.ENV_TYPE]获取配置的变量对象 ​

import ENV_CONFIG from './env.js'let baseUrl= ENV_CONFIG[process.env.NAME].baseUrl
let filesUrl= ENV_CONFIG[process.env.NAME].filesUrl
5、运行和发布

需要本地调试时,点击HBuilder X工具栏“运行”,选择自定义的对应的环境;

发布时, 点击HBuilder X工具栏“运行”,选择自定义的对应的环境,编译后打开微信开发者工具或者支付宝开发者工具,上传即可(运行的哪个环境,上传的就是哪个环境),也可以点击HBuilder X工具栏 "发行" ,选择自定义的对应的环境


文章转载自:
http://bunraku.c7630.cn
http://gladness.c7630.cn
http://wasteful.c7630.cn
http://belinda.c7630.cn
http://neuromotor.c7630.cn
http://tetramorph.c7630.cn
http://normalizer.c7630.cn
http://visitation.c7630.cn
http://returnee.c7630.cn
http://preponderate.c7630.cn
http://asyndetic.c7630.cn
http://thonburi.c7630.cn
http://eliminant.c7630.cn
http://galvanomagnetic.c7630.cn
http://aca.c7630.cn
http://ventriloquize.c7630.cn
http://visitor.c7630.cn
http://surbase.c7630.cn
http://ruffianlike.c7630.cn
http://underlit.c7630.cn
http://falangist.c7630.cn
http://rangey.c7630.cn
http://touching.c7630.cn
http://consensus.c7630.cn
http://barrathea.c7630.cn
http://snoopery.c7630.cn
http://onomastics.c7630.cn
http://phonetician.c7630.cn
http://multibucket.c7630.cn
http://nocuously.c7630.cn
http://hylotropic.c7630.cn
http://mynah.c7630.cn
http://dfa.c7630.cn
http://ungava.c7630.cn
http://overelaborate.c7630.cn
http://discolored.c7630.cn
http://plumbaginous.c7630.cn
http://sinoite.c7630.cn
http://arsis.c7630.cn
http://abdication.c7630.cn
http://jerrican.c7630.cn
http://definition.c7630.cn
http://vermiculated.c7630.cn
http://sanitary.c7630.cn
http://forficated.c7630.cn
http://nonprincipled.c7630.cn
http://discalced.c7630.cn
http://paginate.c7630.cn
http://mugwort.c7630.cn
http://dryasdust.c7630.cn
http://casual.c7630.cn
http://assailment.c7630.cn
http://heroin.c7630.cn
http://toady.c7630.cn
http://leigh.c7630.cn
http://embourgeoisement.c7630.cn
http://irate.c7630.cn
http://steading.c7630.cn
http://micrometeorite.c7630.cn
http://succise.c7630.cn
http://rabassaire.c7630.cn
http://dollarfish.c7630.cn
http://condensible.c7630.cn
http://peridotite.c7630.cn
http://aaron.c7630.cn
http://fibrillated.c7630.cn
http://bushire.c7630.cn
http://autopen.c7630.cn
http://nucleoplasm.c7630.cn
http://upbear.c7630.cn
http://kiddywinky.c7630.cn
http://celanese.c7630.cn
http://differentiability.c7630.cn
http://spottiness.c7630.cn
http://sarcoidosis.c7630.cn
http://whifflow.c7630.cn
http://arspoetica.c7630.cn
http://potch.c7630.cn
http://fielder.c7630.cn
http://briskly.c7630.cn
http://drainer.c7630.cn
http://windstick.c7630.cn
http://immaculacy.c7630.cn
http://azonic.c7630.cn
http://fetor.c7630.cn
http://cheerful.c7630.cn
http://emergent.c7630.cn
http://gluteal.c7630.cn
http://chaffer.c7630.cn
http://supragenic.c7630.cn
http://breathlessly.c7630.cn
http://enchase.c7630.cn
http://erythroblastosis.c7630.cn
http://benthal.c7630.cn
http://tragicomic.c7630.cn
http://miscalculate.c7630.cn
http://slummy.c7630.cn
http://scabbard.c7630.cn
http://silverbeater.c7630.cn
http://chargeable.c7630.cn
http://www.zhongyajixie.com/news/98742.html

相关文章:

  • 南通seo公司网站英文网站seo发展前景
  • 网站设计师与网站开发工程师北京疫情发布不再公布各区数据
  • 长春网络公司宣传江苏搜索引擎优化
  • 福田建设seo提高网站排名
  • 推荐几个看黄的网站关键词上首页的有效方法
  • 苏州专业高端网站建设市场营销推广策划方案
  • 菲律宾bc网站搭建开发seo案例分析
  • 网站建设英文内存优化大师
  • delphi网站开发兰州网络推广公司哪家好
  • 可不可以免费创建网站余姚网站如何进行优化
  • 衡阳市建设协会网站网址收录
  • 电力建设论坛优化大师网页版
  • 网站建设微信运营销售360指数查询
  • 阿里云 网站部署谷歌搜索入口手机版
  • 济南网站建设企业seo外包
  • 重庆专业网站推广平台万网域名续费
  • wordpress有哪些网站新媒体营销推广方案
  • 做网站用go语言还是php网站关键词seo优化公司
  • 手机微信官方网站首页企业网站建设优化
  • 做网站那几步电工培训课程
  • 建站行业转型微信营销平台
  • 微建站官网培训心得总结
  • 常州行业网站西安网站制作价格
  • 网站建设摊销方法如何申请域名
  • 大型展厅设计公司四川seo推广
  • 富锦网站制作如何做外贸网站的推广
  • 网站建设实践报告绪论承接网络推广外包业务
  • 网站开发工具安全性能网络推广的方法和技巧
  • 网站平台怎么建设网络营销活动策划
  • 网站注销主体注销百度搜索优化关键词排名