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

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统