热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

链接转小程序码,原生小程序转uniapp

众所周知,微信小程序的语法和uniapp的语法接近,一个是Vue的近亲,一个完全兼容Vue,所以他们相互之间转换应该也是不难的。微信小程序的语法,其实是vue.js语法的裁剪定制版


众所周知,微信小程序的语法与uniapp的语法相近,一个是Vue的近亲,另一个与Vue完全兼容,所以他们互相转换应该也不难。 微信小程序的语法实际上是vue.js语法的定制版,在数据绑定、定制组件等很多方面都有相似之处。


以下是小程序的源代码转换步骤指南。


在客户端中创建新的uni-app项目,将以前的app.js和app.wxss代码移动到app.vue中,并分别放在script和style节点下。 将app.json转换为pages.json,检索每个小程序的page目录中的index.json (或与页面名称对应的json )的排列,并将其放在pages.json的style下。 将vue空文件模板放在pages下的每个页面目录中。 将上一页中wxss的内容复制到vue文件的样式中,不需要进行更改。 将上一页中的js内容复制到vue文件的脚本中,并将进行以下更改之前js中的data放在新data return下: 在那之前


page { data : { show 1: false } }之后


scriptexportdefault { data } { return { show 1: false } }/script之前js中的定制方法放在新method下。 上一个page({toggleactionsheet1) this.setdata ) (show1:true ); }}当前,scriptexportdefault { methods : } toggleactionsheet1({ this.show1=true } )/script之前js中的生命周期函数onLoad,on } )当前,scriptexportdefault(onload ) (console.log ) ' pageload ); } }/script setdata的处理方式1 :从1:this.setdata(loading:false,area list : response.data.data )到this.loading=ff idata 方式二:重写setdata方法。 如下所示setdata:function(obj ) { let that=this; let keys=[]; let val,data; object.keys(obj ).Foreach ) function ) key ) ) { keys=key.split ) '.'; val=obj[key]; data=that.$data; kys.foreach(function(key2,index ) if ) index1==keys.length ) that.$set ) data,key2,val; (else ) if (! data [ key2] data,key2,{}; } } data=data[key2]; (); }将上一页wxml的内容复制到vue文件的template下的view下,并将属性绑定从attr='{{ a }} '更改为:attr='a'title='复选框{{ item }} 将' :title=' '复选框' item '事件绑定从bind : click=' toggleactionsheet1'更改为@ click=' toggleactionshem 将阻止事件从catch3360taatable中起泡的xx'wx:if更改为v-ifwx 3360 for=' { { list } } ' wx : key=' { { index } ',并更改为` v


以前部署的定制组件必须放在wxcomponents下,然后在pages.json中注册。 请注意,如果此处有js,并将其引入其他代码中,请修复引用代码的路径导向。 { 'pages': [ //pages数组中的第一项表示APP应用程序的启动页

,参考:https://uniapp.dcloud.io/collocation/pages {"path": "pages/dashboard/dashboard"}, { "path": "pages/action-sheet/action-sheet", "style":{ "navigationBarTitleText":"ActionSheet 上拉菜单", "usingComponents":{ //这里单页面引入action-sheet组件 "van-action-sheet": "/wxcomponents/vant/action-sheet/index" } } } ], "globalStyle": { "navigationBarTitleText": "Vant For Uni-app", "usingComponents": { //这里给所有页面全局引入了如下组件 "demo-block": "/wxcomponents/vant/demo-block/index", "van-button": "/wxcomponents/vant/button/index", "van-cell": "/wxcomponents/vant/cell/index", "van-cell-group": "/wxcomponents/vant/cell-group/index", "van-icon": "/wxcomponents/vant/icon/index", "van-loading": "/wxcomponents/vant/loading/index", "van-toast": "/wxcomponents/vant/toast/index" } }} 辅助工具 str = str.replace(/bindtap/g, '@onclick');str = str.replace(/wx:if/g, 'v-show');str = str.replace(/src=\'\{\{/g, ":src='");str = str.replace(/wx\:key=\"\*this\"/g, ' ');str = str.replace(/wx\:key\=\"index\"/g, ' ');str = str.replace(/wx:for="{{/g, v-for= "(item,index) in ');str = str.replace(/bindinput/g, '@input'); wx.是否要替换为uni.?

关于js api中的wx.,不要全局替换为uni.。因为有的wx的api是微信独有的,替换为uni后,反而在微信下没法用了。

同时uni-app编译器提供了把wx.编译为不同平台的机制,所以直接使用wx.的api完全可以正常在各端运行。

所以对于老代码,替不替换不重要,不影响运行,只影响语法提示和转到定义。

但是新写的代码,还是要用uni.的api,在代码提示、转到定义方面更强大。

服务相关代码转换

登陆、支付、推送、定位、地图等服务都是联网服务,它们不止是客户端代码转换就可以直接运行的。涉及服务器接口和配置两方面的工作。

uni-app在客户端侧提供了统一的代码,比如uni.login、uni.requestPayment,在不同端均可以实现登陆、支付。

但服务器端的接口不一样,比如微信的App支付和小程序支付的申请开通、服务器接口都不一样,所以配置和服务器接口仍需单独处理。

比如把小程序转换uni-app后,需要打包发布为app,则需要向微信申请app支付的资质,拿到appkey等信息,填写到uni-app工程的 manifest-app -> sdk配置 -> 微信支付 下面,然后打包才能成效(如果是离线打包,参考离线打包的文件)。同时服务器需要按照微信的App支付的接口再开发对接。

同样微信小程序里内置的定位、地图,在app上,需要单独向高德等三方服务商申请,否则无法在app里使用这些服务。

这些sdk申请方式在 manifest -> app sdk配置 下有教程链接。

其他注意

文章来源: https://yq.aliyun.com/articles/703548


推荐阅读
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • switch语句的一些用法及注意事项
    本文介绍了使用switch语句时的一些用法和注意事项,包括如何实现"fall through"、default语句的作用、在case语句中定义变量时可能出现的问题以及解决方法。同时也提到了C#严格控制switch分支不允许贯穿的规定。通过本文的介绍,读者可以更好地理解和使用switch语句。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
author-avatar
宛岸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有