微信小程序开发爬坑汇总指南

简介: 微信小程序开发爬坑汇总指南

 image.gif编辑

       小程序开发过程会遇到许许多多的坑,有的是因为语法不熟悉,有的是因为框架不完善,导致在实际公司项目中会卡住,这里博主将自己小程序开发过程中遇到的坑汇总起来,给到后面的同志以提醒,少走弯路,多走高速公路~


1 微信小程序之动态获取元素宽高 var obj=wx.createSelectorQuery();

2 微信小程序图片自适应 <image class="themeImg" :src="themeImg" mode="widthFix" /> mode设置为widthFix 宽度100%

3.小程序上拉加载 下拉刷新

4.通过 this.$root.$mp.query 进行获取小程序在 page onLoad 时候传递的 options。通过 this.$root.$mp.appOptions 进行获取小程序在 app onLaunch/onShow 时候传递的 options。

5 style 支持的语法:

动态给生成节点赋样式

<p v-bind:style="{ color: activeColor, fontSize: fontSize + 'px' }">666</p>

<p v-bind:style="[{ color: activeColor, fontSize: fontSize + 'px' }]">777</p>

6 微信小程序地图markers 动态数据渲染的坑

由于异步设置值的过程,组件已经渲染。但是map变量没有预定义是undefined状态,map初始化拿不到数据直接报错了,而异步过来又变成动态更新导致了wxml需要重新渲染map组件的情况导致的。因为官方文档有提到:

地图组件的经纬度必填, 如果不填经纬度则默认值是北京的经纬度。 标记点markers只能在初始化的时候设置,不支持动态更新。

只能初始化一次,因此导致每次都是显示的初始化信息。

wx:if会渲染一下组件,那我们按照这个思路给他加个if就行了

<map markers="{{markers}}" style="width: 375px; height: 200px;" wx:if="{{map}}"></map>

默认map是false,就是加载时不渲染map组件,等ajax回来后把map设置为true,这样就动态渲染成你要的地址了

7.小程序显示弹窗时禁止下层的内容滚动

用 catchtouchmove="return"

//此处为弹窗内容
<view  catchtouchmove="return"> //外层加 catchtouchmove="return"仅触摸背景区域时不穿透底部.
    <view  catchtouchmove="return"></view> //在每个小的区域内加 catchtouchmove="return"
    <view> // 有需要滚动的列表区域位置不要加 catchtouchmove="return", 否则列表无法滚动
        <view>滚动列表1</view>
        <view>滚动列表2</view>
        <view>滚动列表3</view>
        <view>滚动列表4</view>
    </view>
</view>

image.gif

8.小程序使用地图导航功能进行地图导航

wx.getLocation({//获取当前经纬度
      type: 'wgs84', //返回可以用于wx.openLocation的经纬度,官方提示bug: iOS 6.3.30 type 参数不生效,只会返回 wgs84 类型的坐标信息  
      success: function (res) {
        wx.openLocation({//使用微信内置地图查看位置。
          latitude: 22.5542080000,//要去的纬度-地址
          longitude: 113.8878770000,//要去的经度-地址
          name: "宝安中心A地铁口",
          address:'宝安中心A地铁口'
        })
      }
    })

image.gif

image.gif编辑

image.gif编辑

wx.getLocation({//获取当前经纬度
      type: 'wgs84', //返回可以用于wx.openLocation的经纬度,官方提示bug: iOS 6.3.30 type 参数不生效,只会返回 wgs84 类型的坐标信息  
      success: function (res) {
        wx.openLocation({//使用微信内置地图查看位置。
          latitude: 22.5542080000,//要去的纬度-地址
          longitude: 113.8878770000,//要去的经度-地址
          name: "宝安中心A地铁口",
          address:'宝安中心A地铁口'
        })
      }
    })

image.gif

9.隐藏canvas的情况下不能导出图片?

现在需要做一个图片处理的功能 但是又不需要canvas显示在页面上,

我尝试了很多隐藏的方法 结果都是两种:

    1. canvas始终显示而且显示在最上层 比debug的页面都高
    2. canvas display:none 但是无法通过canvasToTemoFilePath导出图片
    3. 父级宽高0,overflow:hidden 无效 ,canvas很霸道...

    解决方案: 把canvas定位到了屏幕外

    10. 很多时候小程序生成海报下载图片 在编辑器上下载的是好的但是在真机上不显示图片 ,原因大部分是因为 下载域名的白名单那里没有配置,配置一下就好了。

    image.gif编辑

    image.gif编辑

    image.gif编辑

    11  小程序绘制海报时候 绘制图片 网络图片一定要先把图片下载后 再去绘制.

    image.gif编辑

    12. cover-view需要使用position:fixed  才能实现效果

    13 在做轮播图图层换装的时候,每个轮播的图片是可以切换 ,那么就需要管理三个数据源, 数据源状态管理的时候,多次切换的时候 出现了数据状态异常的bug 在排查了各种问题后 原来发现 操作修改数据状态的时候没有使用深拷贝,

    用的浅拷贝 ,最后使得数据源 状态被更新了,最后使用深拷贝后就好了

    image.gif编辑

    14 小程序九月份登录新规定 ,对用户信息的获取有了更加严格的要求 ,虽然吐槽声一篇,还是需要按照指导规范 让用户能够初步了解小程序功能后再去让用户登录注册

    15、未完待续


    总结

          最后小程序更新迭代很快 ,建议多去看看小程序官方api文档,后续有新的记录也会一一记录在这个指南下面,有其他遇到坑的朋友们,也可以在评论区下方互相留言~

    image.gif编辑


    目录
    相关文章
    预约按摩小程序开发,为什么很多上门按摩平台根本招聘不到优秀技师?
    上门按摩平台面临招不到优秀技师的问题,主要原因是平台众多,技师选择多样。为解决此问题,平台可引入技师等级制度,根据订单数量和好评率划分高、低等级技师。高等级技师可享受70%-90%的高提成及首页推荐,这不仅能激励技师的积极性,还能帮助平台筛选出优质技师,提升服务质量和口碑,形成良性循环。
    |
    9天前
    |
    人工智能 小程序
    【一步步开发AI运动小程序】十五、AI运动识别中,如何判断人体站位的远近?
    【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,无需后台支持,具有快速、体验好、易集成等特点。本文介绍如何利用插件判断人体与摄像头的远近,确保人体图像在帧内的比例适中,以优化识别效果。通过`whole`检测规则,分别实现人体过近和过远的判断,并给出相应示例代码。
    |
    3天前
    |
    人工智能 小程序 API
    【一步步开发AI运动小程序】十七、如何识别用户上传视频中的人体、运动、动作、姿态?
    【云智AI运动识别小程序插件】提供人体、运动、姿态检测的AI能力,支持本地原生识别,无需后台服务,具有速度快、体验好、易集成等优点。本文介绍如何使用该插件实现用户上传视频的运动识别,包括视频解码抽帧和人体识别的实现方法。
    |
    8天前
    |
    人工智能 小程序 UED
    【一步步开发AI运动小程序】十六、AI运动识别中,如何判断人体站位?
    【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,本地引擎无需后台支持,具备快速、体验好、易集成等优势。本文介绍如何利用插件的`camera-view`功能,通过检测人体站位视角(前、后、左、右),确保运动时的最佳识别率和用户体验。代码示例展示了如何实现视角检查,确保用户正或背对摄像头,为后续运动检测打下基础。
    |
    22天前
    |
    人工智能 小程序 IDE
    【一步步开发AI运动小程序】九、姿态辅助调试桌面工具的使用
    随着AI技术的发展,各大厂商推出的AI运动APP如“乐动力”、“天天跳绳”等,使云上运动会、线上健身等概念大热。本文将指导你如何利用“云智AI运动识别小程序插件”,在微信小程序中实现类似功能,包括工具搭建、服务启动及数据回传等步骤,助力开发者高效开发AI运动小程序。
    【一步步开发AI运动小程序】九、姿态辅助调试桌面工具的使用
    |
    14天前
    |
    人工智能 小程序 API
    【一步步开发AI运动小程序】十三、自定义一个运动分析器,实现计时计数02
    本文介绍如何利用“云智AI运动识别小程序插件”开发AI运动小程序,详细解析了俯卧撑动作的检测规则构建与执行流程,涵盖卧撑和撑卧两个姿态的识别规则,以及如何通过继承`sports.SportBase`类实现运动分析器,适用于小程序开发者。
    |
    14天前
    |
    人工智能 小程序 API
    【一步步开发AI运动小程序】十二、自定义一个运动分析器,实现计时计数01
    随着AI技术的发展,AI运动APP如雨后春笋般涌现,如“乐动力”、“天天跳绳”等,推动了云上运动会、线上健身等热潮。本文将指导你从零开始开发一个AI运动小程序,利用“云智AI运动识别小程序插件”,介绍运动识别原理、计量方式及运动分析器基类的使用,帮助你在小程序中实现运动计时和计数功能。下篇将继续探讨运动姿态检测规则的编写。
    |
    8天前
    |
    移动开发 小程序 PHP
    校园圈子论坛系统采取的PHP语音和uni账号开发的小程序APP公众号H5是否只需要4800元?是的,就是只需要4800元
    关于校园圈子论坛系统采用PHP语言和uni-app开发的小程序、APP、公众号和H5是否仅需4800元这个问题,实际上很难给出一个确定的答案。这个价格可能受到多种因素的影响
    39 8
    |
    25天前
    |
    人工智能 JSON 小程序
    【一步步开发AI运动小程序】八、利用body-calc进行姿态识别
    随着AI技术的发展,各大厂商推出的如“乐动力”、“天天跳绳”等AI运动APP,使得云上运动会、线上健身等概念风靡一时。本文将引导读者从零开始开发一个AI运动小程序,使用“云智AI运动识别小程序插件”,介绍人体姿态检测规则、规则编写语法、执行检测规则运算及姿态检测实战等内容,助力开发者轻松实现AI运动小程序的开发。
    【一步步开发AI运动小程序】八、利用body-calc进行姿态识别
    |
    4天前
    |
    人工智能 小程序 数据处理
    uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
    近期,多家康复机构咨询AI运动识别插件是否适用于肢力运动受限患者的康复锻炼。本文介绍该插件在康复锻炼中的应用场景,包括康复运动指导、运动记录、恢复程度记录及过程监测。插件集成了人体检测、姿态识别等功能,支持微信小程序平台,使用便捷,安全可靠,帮助康复治疗更加高效精准。