vs程序集引用程序修改路径_H5小程序APP,带你跟上大前端时代

2024-01-26 14:20

本文主要是介绍vs程序集引用程序修改路径_H5小程序APP,带你跟上大前端时代,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

289336053c1409836fd97d2dcb05b0e3.png

大前端

场景

前两天在福建,朋友打麻将要求我提供可以麻将上使用的摇骰子小程序(PS:之前开发了喝酒摇骰子的小程序),于是决定将之前的小程序功能迭代一下。

之前的微信小程序《摇骰子辅助工具》,使用过的人数16万+,每月收益约1000元的广告费……关于这个小程序的功能就不细说了,真的有兴趣的小伙伴请自行点击看下,GitHub 也是开源的 https://github.com/ZweiZhao/DicePlay。

170af36d2b28a886c170c384c7443717.png

DicePlay


Uni

Uni-App 是数字天堂公司维护开发的多端整合大前端框架,不做广告,自行查阅,只是我用到这个技术栈而已。


之前技术

《摇骰子辅助工具》最早使用原生小程序开发,后面转了 mpvue + coffeescript + pug + sass 开发,所以从 mpvue 转到 uni 很简单,因为 uni 官网有相关教程,按照方法走就行了。我这里遇到点恶心的事情,就是 cs、pug 与 sass 的抉择问题。最终结论就是手动(肯定用工具啦)把 cs、pug 与 sass 转换回了 js、html 与 css,原因很简单,那三个用着爽但是在新工具或框架下,未必完美支持,换回基础语言就可以保证换平台的便捷性

b59b2df5dcaa694f038f233a4aca63c2.png

mpvue

之前 mpvue 的一个页面或组件的结构是这样的,因为那时候 mpvue 对 cs 的支持很差,只能这样丑陋的外部引入了(现在 mpvue 好像凉了)。


Uni Ver

f000983eb4b96adc19405fd45d1b5796.png

uni ver

uni 版本的结构会相对简单一点,官网也限制了你想不简单的路子……


条件编译

这个是真填坑神器……

总之这个简单的修改项目,我要做到全平台(APP,H5,微信小程序),目前唯一遇到的坑,就是文件引用路径问题。

  1. 小程序引用 mp3 文件,使用本地路径不播放
  2. h5 打包发布使用 GitHub Pages 时候,换相对路径
  3. APP 使用绝对根路径

上面三点把我坑惨了,换代码半小时,搞路径,快两小时。有想玩这个 uni 的,这一块务必注意啊!


上面问题的解决方案如下:

mp3 文件直接挂在小程序云开发的腾讯云上面

点击上面的云开发,进去授权,并上传到储存管理即可。

4712327968ab4e9c6a48f0c2d5f6ab24.png

云开发位置

35967d5af87838cb0b815df3858ef414.png

存储管理

获取存储后的地址然后小程序调用即可。

注意,注意!这个链接是 cloud:// 协议,所以其他平台不能用!!!

因此要用到条件编译来区分这个地址是小程序专用的,具体条件编译下面统一贴图。


H5 打包引用路径处理

比如我放在 GitHub Pages,依赖项目是 DicePlay,那么 Pages 给的地址就是(我绑定了域名):http://www.zweizhao.com/DicePlay/,结合这边打包后,生成的最后路径就是:http://www.zweizhao.com/DicePlay/unpackage/dist/build/h5/。

可是,uni 默认是打包静态文件引用路径是:/static,那么这样引用就炸了,肯定获取不到。

所以要去 manifest.json 里面源码修改添加这样:

e89a5f6a732b0956f47cc613110a4795.png

manifest

把文件包指定到这个地方。

呵呵,你以为这就完了?

js 文件里面引用的文件也要修改是相对路径,比如:"./"。

所以……又要条件编译,同样等下面统一。

这个问题,如果你项目丢在链接根目录就不用操心。


APP 根路径

这个我是试出来的,起码 iOS 是设置根路径获取,安卓就不是很清楚了,如果不是,那就再加一个条件变编译吧。

于是当前就有了三个条件编译(APP,H5,微信小程序),如下:

c28b842f64f1a25113218b73aacb3341.png

条件编译

为什么我写的这么不优雅?

还不是因为 uni 只提供了条件编译 || 判断,没有提供 && 判断……


成果

其他的暂时也不知道说啥,直接看成果吧,从左到右依次:H5,小程序,APP。

55276d2b3a10ddf30169a7d1d4f15d24.png

成果

恩,看到这里,我觉得坑一点还是值得的……撒花。

希望大家能够从文章里学到一点东西,谢谢。

这篇关于vs程序集引用程序修改路径_H5小程序APP,带你跟上大前端时代的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/647070

相关文章

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n = 1005; // n根据题目中节点数量而定,一般比节点数量大一点就好vector<int> father = vector<int> (n, 0); // C++里的一种数组结构// 并查集初始化void init() {for (int i = 0; i < n; ++i) {father[i] = i;}

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

Java面试八股之怎么通过Java程序判断JVM是32位还是64位

怎么通过Java程序判断JVM是32位还是64位 可以通过Java程序内部检查系统属性来判断当前运行的JVM是32位还是64位。以下是一个简单的方法: public class JvmBitCheck {public static void main(String[] args) {String arch = System.getProperty("os.arch");String dataM

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

Windwos +vs 2022 编译openssl 1.0.2 库

一 前言 先说 结论,编译64位报错,查了一圈没找到解决方案,最后换了32位的。 使用qt访问web接口,因为是https,没有openssl库会报错 QNetworkReply* reply = qobject_cast<QNetworkReply*>(sender());if (reply){if (reply->error() == QNetworkReply::NoError

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页:

vue+el国际化-东抄西鉴组合拳

vue-i18n 国际化参考 https://blog.csdn.net/zuorishu/article/details/81708585 说得比较详细。 另外做点补充,比如这里cn下的可以以项目模块加公共模块来细分。 import zhLocale from 'element-ui/lib/locale/lang/zh-CN' //引入element语言包const cn = {mess