将微信小程序转换uniapp进行迁移的步骤以及遇到的问题总结

news2025/1/18 17:06:08

目录

前言

一、迁移步骤

第一步:安装miniprogram-to-uniapp 插件

第二步:查看是否安装成功

第三步:使用插件进行转换

第四步:使用hbuilder X运行转换后的项目并在微信小程序编辑器查看

第五步:调试修改

二、处理迁移问题

js部分

templete

css部分

三、扩展

总结


前言

背景:由于历史原因,公司有个历史项目使用vue开发的公众号H5,原生开发的微信小程序。两端功能的完全一样,但是需要维护两个项目,最近客户提了需求需要修改部分功能,博主接到需求后,觉得维护两套代码不仅是重复开发,测试起来也麻烦,因为之前是两个人开发不同端的缘故,导致大部分的bug都是因为两端不一致产生的。为了节省时间和维护成本,提升开发测试效率,在反复对比调研,最终选择了uniapp技术框架融合两端进行重构。博主目前正在使用uniapp开发H5和小程序,这篇文章是和大家分享并记录一下原生小程序在迁移到uniapp的步骤和时遇到的问题。

一、迁移步骤

把微信小程序转成uni-app,这里推荐一款【miniprogram-to-uniapp】小程序转换工具插件

第一步:安装miniprogram-to-uniapp 插件

在命令行里,运行【 npm install miniprogram-to-uniapp -g 】进行安装,因为这个包是工具,要求全局都能使用,所以需要-g进行全局安装。
如果运行npm报错,请先安装Node.js,下载地址:https://nodejs.org/zh-cn/

 
  1. npm install miniprogram-to-uniapp -g

第二步:查看是否安装成功

继续在命令行里,运行【 wtu -V 】,执行结果如下

显示版本号,说明已经安装成功了

 

第三步:使用插件进行转换

在命令行里,输入【wtu -i "你的小程序项目路径"】

注意 -i 前面和后面都有空格!!!

注意 -i 前面和后面都有空格!!!

注意 -i 前面和后面都有空格!!!

如:【wtu -i "E:\zpWork\Project_self\miniprogram-to-uniapp\test\test-wx-to-uni"】 ,回车后即可以在源项目同及目录得到一个后缀为_uni的目录,即转换成功。

转换前

 

转换后

 

 

 

 

转换后的项目文件对比(左边是小程序项目,右边是Uni-app项目目录):

 

 

第四步:使用hbuilder X运行转换后的项目并在微信小程序编辑器查看

将转换后的xxx_uni项目导入到hbuilder X,
点击菜单 运行--> 运行到小程序模拟器-->微信开发者工具!(如果是使用了vant的项目,请运行到H5,vant项目转换后仅支持H5和app)
然后查看转换后的项目运行到小程序,是否可以正常运行无报错!

第五步:调试修改

运行项目,在小程序开发者工具调试迁移页面的报错信息

二、处理迁移问题

根据下方迁移内容,逐一更新页面方法,修复页面报错信息,页面显示、功能运行正常即迁移完成。

js部分

1,删除 const app = getApp();

2,以 wx. 开头的方法更新为 uni. 开头

3,数据绑定 this.setData({ a : 1 }) 更新为 this.a = 1

4,路由跳转 wx.navigateTo()  更新为uni.navigateTo()

5,onLoad(options)

  • 通过options或this.$Route.query获取页面传递参数

6、部分页面生命周期释义,详见页面生命周期

  • onPullDownRefresh:监听用户下拉动作,一般用于下拉刷新
  • onReachBottom:页面滚动到底部的事件(不是scroll-view滚到底),常用于下拉下一页数据
  • onShareAppMessage:用户点击右上角分享
  • onPageScroll:监听页面滚动

templete

以下几条不影响使用,改不改都行

  1. <block>标签可能是小程序<block>标签或templete模版转换生成的,有的页面转完后可能有多层<block>嵌套的情况,不影响使用,但是不代码太美观,修改的话<block> 标签替换为 <templete> 标签,样式估计也需要调整
  2. 页面事件 例如 <view @tap="clickBtn" data-id="id">点击</view> ,页面转换完使用没问题,但是和平常开发vue不一样,更新的话可以改为<view @click="clickBtn(id)">, 在修改对应方法即可
  3. 引入wxs的页面 <script module="utils" lang="wxs" src="./utils.wxs"></script> 大部分方法可改为 computed、watch,

css部分

  1. css转换可能失败,大部分是单位转换失败,原px乘2,改为rpx即可
  2. 盒子模型的问题(小程序默认content-box,uniapp默认样式border-box),修改box-sizing即可

三、扩展

习惯vue写法来处理router路由的同学,还可以集成一个uni-simple-router插件来管理路由。

1、使用vue-cli 创建一个新的项目,使用uni-simple-router管理路由。

 
  1. vue create -p dcloudio/uni-preset-vue xcxToUniapp

2、 打开该项目,新建页面,copy转换后的项目的代码

3、运行项目即可

总结

这篇文章记录了博主用使用uniapp集成H5和小程序两端的一些思路和解决方案。虽然很曲折,但还是很开心,故记录一下。希望这个记录能帮到看到这篇文章的小伙伴

参考:1、微信小程序转换uniapp的迁移步骤以及遇到的问题总结 / 张生荣 

2、微信小程序怎么转为Uniapp-百度经验 

3、微信小程序转uniapp的迁移步骤及遇到的问题_国服第二切图仔的博客-CSDN博客_微信小程序转uniapp

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

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

相关文章

黑马学ElasticSearch(九)

目录&#xff1a; &#xff08;1&#xff09;数据聚合-聚合的分类 &#xff08;2&#xff09;数据聚合-DSL实现Bucket聚合 &#xff08;3&#xff09; 数据聚合-DSL实现Metrics聚合 &#xff08;4&#xff09;数据聚合-RestClient实现聚合 &#xff08;5&#xff09;数据聚…

重复生成数据itertools.repeat()

【小白从小学Python、C、Java】【计算机等级考试500强双证书】 【Python-数据分析】 重复生成数据 itertools.repeat() [太阳]选择题 以下python代码结果错误的一项是? import itertools print("【执行】xitertools.repeat(abc,3)") xitertools.repeat(abc,3) print…

xml中xsd/xsi/xsl/xmlns的区别和联系

&#xff08;2023.01.13Fri才明白&#xff0c;具体解析xml文件的不是xml文件本身&#xff0c;xsi也不是在解析xml文件&#xff0c;只是检验xml文件是否符合标准&#xff0c;xsd是在限制xml文件的内容。而具体解析某个element究竟是什么样式、起到什么作用&#xff0c;是需要接收…

可信AI年度观察 | 生成式AI技术及产品快速迭代,生成内容质量及安全性仍需提升

自2021年起&#xff0c;生成式人工智能&#xff08;以下简称“生成式AI”&#xff09;连续两年入选Gartner《Hype Cycle for Artificial Intelligence》&#xff0c;被认为是未来重要的AI技术趋势。2022年以来&#xff0c;生成式AI产品不断涌现&#xff0c;生成内容模态多样&am…

Python机器学习:认识机器学习

&#x1f315; 机器学习是什么&#xff1f; ⭐️&#xff1a;机器学习是一门涉及数学、统计学、计算机科学等的学科。 ⭐️&#xff1a;机器学习是从一个大量的已知数据中&#xff0c;学习如何对未知的新数据进行预测&#xff0c;并且可以随着学习内容的增加&#xff0c;提高对…

让你彻彻底底理解“并发”以及“并行”

1. 前言 我们做后端的人&#xff0c;一般会遇到别人给你说高并发&#xff0c;那我们知道什么叫并发吗&#xff1f;&#xff1f;&#xff1f; 什么叫并行吗&#xff1f;&#xff1f;&#xff1f; 今天这篇文章的目的其实就是为了讲明白什么叫并发&#xff0c;并行。好了废话不多…

二维数组八个方向的判断--牛客刷题1023-病菌感染

铁子和顺溜上生物课的时候不小心将几滴超级病菌滴到了培养皿上&#xff0c;这可急坏了他们。 培养皿可以被看成一个n*n的方格&#xff0c;最初病菌滴在了这n*n的格子中的某些格子&#xff0c;病菌的传染方式是这样的&#xff0c;如果一个方格与两个或多个被感染的方格相邻(两个…

2023,数字政务潮水已至

城市是时代发展最鲜活的物理存在&#xff0c;政务是城市的“中枢系统”&#xff0c;将数字技术广泛应用于政府管理服务&#xff0c;既能提高政府公共服务的履约效能&#xff0c;亦顺应经济社会数字化转型的大趋势。 作者|子雨 出品|产业家 从集聚资源求增长&#xff0c;到…

Linux的文件系统和软硬链接

目录 文件系统 磁盘的物理结构&#xff1a; 磁盘的存储结构 磁盘的逻辑抽象结构 管理文件 那么文件如何与属于自己的内容关联起来&#xff1f; 创建一个文件&#xff0c;OS做了什么&#xff1f; 删除一个文件&#xff0c;OS做了什么&#xff1f; 软硬链接 硬链接 软连…

Python学习笔记——字典

字典是一种映射类型 &#xff0c;它是一个无序的集合。内部元素是键值对形式出现&#xff0c;即一个关键字&#xff08;key&#xff09;与一个值&#xff08;value&#xff09;的组合&#xff08;“键&#xff0d;值”对&#xff09;。字典是一种可变容器模型&#xff0c;且可存…

视频在线点播功能如何实现?

1. 视频点播需求分析1.1 需求描述视频点播需求如下&#xff1a;1、学生可以在windows浏览器上在线观看视频。2、播放器具有快进、快退、暂停等基本功能。1.2 视频点播解决方案1.2.1 流媒体详细参考&#xff1a;https://baike.baidu.com/item/%E6%B5%81%E5%AA%92%E4%BD%93/98740…

2023年网络安全比赛--网络安全应急响应中职组(超详细)

一、竞赛时间 180分钟 共计3小时 二、竞赛阶段 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 1.找出被黑客修改的系统别名,并将倒数第二个别名作为Flag值提交; 2.找出系统中被植入的后门用户删除掉,并将后门用户的账号作为Flag值提交(多个用户名之间以英文逗号分割,如:admi…

【项目】小帽教育(一)

小帽教育 第一章 项目开发环境搭建 一、项目背景 1.在线教育市场环境 在线教育行业是一个有着极强的广度和深度的行业&#xff0c;从校内到校外&#xff1b;从早幼教到职业培训&#xff1b;从教育工具到全信息化平台等等。 2020年的新冠疫情外生冲击&#xff0c;让在线教育…

Android 深入系统完全讲解(14)

2 如何定位编译问题 编译不出来&#xff0c;编译不生效&#xff0c;都是可以用比对的方式去处理。之前遇见只改资源单编译不生效&#xff0c;跟正常的一比较发现是系统编译机制是判断代码的时间戳&#xff0c;而不管资源目录&#xff0c;于是处理的方式就是单编配置强制&#…

过年了,我采集采集m3u8格式做做动态壁纸不过分吧

前言 嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! 首先澄清一下&#xff0c;我用Python收集这些视频&#xff0c;绝不是想做别的什么&#xff0c; 真的只是用来做动态壁纸&#xff0c;大家不要误会&#xff01;我不是那样的人~ 这样的不过份吧 &#x1f63b; 环境 Python…

二叉树的深度 | 分治 +回溯 + 迭代

二叉树的最大深度 leetcode https://leetcode.cn/problems/maximum-depth-of-binary-tree/ 回溯基本思路 二叉树的最大深度就是 : 从根节点到叶子节点的最大的深度 定义一个全局变量 int res 0 , 以及局部变量 depth 表示当前层的深度当我们访问到根节点的时候(前序位置), 就…

亿信华辰出席2022DAMA中国数据管理峰会,共话数据治理

2023年1月7日-8日&#xff0c;万众瞩目的2022DAMA中国数据管理峰会在上海成功举办&#xff0c;国内外知名行业领袖、业内优秀企业代表出席了会议。会上&#xff0c;围绕 “数据基础制度和数字化转型”主题&#xff0c;前沿观点高能碰撞、专家学者共话未来。亿信华辰首席运营官毛…

CTP开发(1)CTP开发的概述

CTP是上海期货交易所开发的一套程序化交易的API。这篇文章呢&#xff0c;是进行扫盲和引路的&#xff0c;让你在开发时可以少走弯路。1、如果你要进行CTP开发&#xff0c;那么先是在模拟环境下调试&#xff0c;这就需要去上期的仿真模拟网站simnow下载相应的API包。地址如下&am…

[数字信号处理]时域中的离散时间信号和系统

离散时间信号最基本的形式是定义在等间隔的时间离散值上&#xff0c;且在这些离散时间上的信号振幅值是连续的。离散时间系统则是输入为离散时间信号输出也是离散时间信号的系统。对于线性时不变&#xff08;LTI&#xff09;系统来说&#xff0c;我们可以发现LTI系统与该系统的…

【4】Kubesphere_多租户

目录 创建企业空间角色 邀请新成员 部门管理 准备工作 创建部门 分配用户至部门 从部门中移除用户 删除和编辑部门 进入访问控制 可以配置企业空间、用户和用户角色 企业空间角色页面列出了以下四个可用的内置角色。创建企业空间时&#xff0c;KubeSphere 会自动创建内…