小程序开发中注意的细节

简介: 1.绑定变量的语法,各不相同。//绑定style中的height变量 //绑定class中的变量 //事件绑定是不使用双花括号,事件中如果传递的值是变量却需要用双花括号 1) { ...

1.绑定变量的语法,各不相同。

//绑定style中的height变量

  <scroll-view scroll-y style="height:{{height}}px;">

//绑定class中的变量

  <view  class="tab-item{{curTab == 2 ? ' btnActive' : ''}}">

//事件绑定是不使用双花括号,事件中如果传递的值是变量却需要用双花括号

  <view @tap="doTab(2)" >
  <view @tap="onTag('{{item.name}}')"
  //组件传值也是不使用双花括号的
  <Bdmap :title="mapTitle"></Bdmap>
  // 循环绑定变量k也是是不需要花括号的
  <repeat for="{{list}}" key="index" index="index" item="item">
  1. 普通循环标签事件,外层容器加display:block,循环内容加display:inline-block.并且设置一个40rpx的高度。会有神奇的样式效果出现,文字出现在了块级元素下方。这个是什么鬼?这个问题是因为你使用了text的标签变成了inline-block,如果换成view就正常了。

     <view class='tag' style="display:block">
     <repeat for="{{tagList}}" key="index" index="index" item="item">
         <text @tap="onTag('{{item.name}}')" style='height:40rpx;display:inline-block'>
             {{item.name}}
         </text>
     </repeat>
     </view>
    

另外还有就还是在text标签中如果使用&nbsp的时候记得还要添加decode="{{true}}"属性。

3.canvas 在手机端适配有两个bug,第一个是苹果手机中默认screenScroll为false,当操作canvas 以后屏幕就没有办法再上下滚动了,出现了类似死机一般的效果。但是安卓手机操作很正常。解决方法是,需要你再苹果手机结束canvas绘图操作后,手动将属性screenScroll改为true。让屏幕可以继续除滑动了。如果你只是满屏显示不需要屏幕上下滑动的需求,就请忽略以上内容。
第二个坑就是苹果手机将canvas转换成二进制图片后,苹果手机转换后的图片居然是180度颠倒的,安卓手机是正常的。这个bug的解决方法是将苹果手机中生成的图片在上传到自己的服务器之前旋转180度,具体的做法如下。

      wx.canvasGetImageData({
                canvasId: 'canvas',
                x: 0,
                y: 0,
                width: 350,
                height: 200,
                success(res) {
                    let platform = wx.getSystemInfoSync().platform
                    if (platform == 'ios') {
                        // 兼容处理:ios获取的图片上下颠倒
                        let result = that.reversedata(res)
                    }
                    // 3. png编码
                    let pngData = upng.encode([res.data.buffer], res.width, res.height)
                    // 4. base64编码
                    let base64 = wx.arrayBufferToBase64(pngData)
                    let base64Image = "data:image/jpeg;base64," + base64
                    let sign = base64Image
                    let state = that.state

                    let pages = getCurrentPages();
                    if (pages.length > 1) {
                        //上一个页面实例对象
                        let prePage = pages[pages.length - 2];
                        //关键在这里,这里面是触发上个界面
                        prePage.changeData(state, sign) // 不同的人里面的值是不同的,这个数据是我的,具体的你们要根据自己的来查看所要传的参数
                    }
                    wx.navigateBack({
                        changed: true
                    })
                }
            })
          //图片翻转的方法
      reversedata(res) {
        var w = res.width;
        var h = res.height;
        let con = 0;
        for (var i = 0; i < h / 2; i++) {
            for (var j = 0; j < w * 4; j++) {
                con = res.data[(i * w * 4 + j) + ""];
                res.data[(i * w * 4 + j) + ""] = res.data[((h - i - 1) * w * 4 + j) + ""];
                res.data[((h - i - 1) * w * 4 + j) + ""] = con;
            }
        }
        return res;
    };

4.第四点是开发者需要注意的。微信登录的时候一定要先获取用户的code,再获取iv和encryptData的数组否则,要两次才能登录成功哦,文档中并没有强调,开发中如果不仔细阅读文档很容易忽略掉,造成不必要的时间浪费。具体方法如下可以在页面加载的时候获取code.点击登录的时候在获取iv和encryptData数据。

    <button class="btnwx" open-type="getPhoneNumber" bindgetphonenumber="doWxLogin">微信手机号快捷登录</button>     
     async doWxLogin(e) {
            let self = this;
            let login = await api.wxLogin({
                query: {
                    code: self.code,
                    iv: e.detail.iv,
                    encryptData: e.detail.encryptedData
                },
                method: 'POST'
            });
            if (login.data.code === 0) {
                wepy.setStorageSync('mobile', login.data.data.mobile);
                wepy.setStorageSync('userInfo', login.data.data);
                wepy.setStorageSync('token', login.data.data.token);
                await tip.success('登录成功').then(() => {
                    // goUrl(self.url || '/pages/mine/index')
                    wx.switchTab({
                        url: '/pages/mine/index'
                    })
                })
            } else {
                // tip.error(login.data.message)
            }
        }
  //页面加载的时候获取code
  async onShow() {
        let ret = await wepy.login();
        console.log(ret)
        this.code = ret.code
    }
相关文章
|
7天前
|
小程序 Android开发
|
22天前
|
人工智能 小程序
一步步开发AI运动小程序】二、引入插件
随着人工智能技术的发展,阿里体育等公司推出的“乐动力”、“天天跳绳”等AI运动APP广受欢迎。本文将引导您从零开始开发一个AI运动小程序,使用“云智AI运动识别小程序插件”。内容包括新建uni-app项目、配置插件、部署模型、安装依赖包、全局初始化和调用插件对象。
|
21天前
|
小程序 搜索推荐 数据挖掘
跳绳打卡小程序开发多钱费用
跳绳打卡小程序通过智能手机即可轻松使用,无需额外设备,只需一根跳绳即可开始您的健康之旅。它结合了便捷性、互动性和个性化设置,让跳绳这项运动变得更加有趣和高效
预约按摩小程序开发,为什么很多上门按摩平台根本招聘不到优秀技师?
上门按摩平台面临招不到优秀技师的问题,主要原因是平台众多,技师选择多样。为解决此问题,平台可引入技师等级制度,根据订单数量和好评率划分高、低等级技师。高等级技师可享受70%-90%的高提成及首页推荐,这不仅能激励技师的积极性,还能帮助平台筛选出优质技师,提升服务质量和口碑,形成良性循环。
|
2天前
|
小程序
|
3天前
|
小程序 数据安全/隐私保护
|
8天前
|
小程序
|
8天前
|
人工智能 小程序
【一步步开发AI运动小程序】五、帧图像人体识别
随着AI技术的发展,阿里体育等公司推出的AI运动APP,如“乐动力”和“天天跳绳”,使云上运动会、线上健身等概念广受欢迎。本文将引导您从零开始开发一个AI运动小程序,使用“云智AI运动识别小程序插件”。文章分为四部分:初始化人体识别功能、调用人体识别功能、人体识别结果处理以及识别结果旋转矫正。下篇将继续介绍人体骨骼图绘制。
|
9天前
|
人工智能 小程序 vr&ar
AI运动小程序开发常见问题集锦二
截至当前,我们的AI运动识别小程序插件已迭代至第23个版本,广泛应用于健身、体育、体测、AR互动等场景。本文针对近期用户咨询,汇总了常见问题,帮助用户减少开发成本,提高效率。主要涵盖计时与计数模式的区别、综合排行榜生成方法、全屏模式适配及无开发能力用户的解决方案。