mpvue & 小程序开发过程中的坑-阿里云开发者社区

开发者社区> 我是管理员> 正文

mpvue & 小程序开发过程中的坑

简介:
+关注继续查看

业务需要,最近开始做小程序开发,使用的是mpvue,做的过程中踩了一些坑,小程序的也有,mpvue的也有。感觉小程序中textarea巨多坑,还有许多找不到原因的,莫名其妙的坑。总得来说小程序并不适合做复杂的表单页面。

踩坑记录

1.mpvue将元素设置display属性,然后v-show控制显隐,不生效,元素始终以css中的display属性为准

  在css中设置display属性,使用v-show不生效,在mpvue中使用原生小程序的:hidden也是这样的效果,元素以css中的display属性为准,目前可以用:class绑定。

测试代码:



<template>
  <div class="container">
    <div class="box" :hidden="!isShow">原生hidden
    </div>
    <div class="box" v-show="isShow">v-show
    </div>
    <div class="box" :class="{'hidden':!isShow}">:class绑定
    </div>
    <button @tap="showUser">点我</button>
  </div>
</template>
<script>
export default {
    data() {
        return {
            isShow: false
        };
    },
    methods: {
        showUser() {
            this.isShow = !this.isShow;
        }
    }
};

</script>

<style scoped>
.box {
    display: block;
    width: 100rpx;
    height: 200rpx;
    background: yellow;
    margin:0 auto;
}
.hidden{
  display:none;
}

</style>



2.textarea层级最高问题

  一个长页面表单,提交按钮使用fixed固定在底部是很常见的场景,由于textarea层级最高,无法被其他元素遮盖,所以textarea的value部分会透出,并且在底部按钮点击时也可以触发focus事件。(同理在有textarea的页面上覆盖弹层,也同样情况)

7ea57c6484470799eff08851ba5d7315e02e6c7c
fa471f07aae36a63c3e3a79556faf6915505cf86

查了文档,可以用组件cover-view,此组件可以覆盖在原生组件之上的文本视图,可覆盖的原生组件包括map、video、canvas、camera、live-player、live-pusher。将底部按钮放在cover-view中,解决了层级问题,但在手机上测试是,长页面滚动时,发现底部的cover-view会发生抖动,说明小程序的一些原生组件实现的还不是特别好。

  最终用的方案是将textarea做在弹窗中,作为一个公共的编辑器组件,触发时才显示,层级最高。避免出现覆盖其他元素的情况。

3.小程序中使用fixed自定义弹窗时,如何使底部长页面禁止滚动

  这个场景也非常常见,解决方案有:

   1.底部长页面使用scroll-view,当弹窗显示时,将scroll-y设置为false,弹窗关闭时,将scroll-y设置为true。

   2.原生小程序中可以在弹层上使用catchtouchmove,此事件会阻止向父元素冒泡,mpvue中使用@touchmove.stop="一个空函数"。

4.mpvue代码中有异常时,小程序开发者工具有时候不会抛出异常报错,除了缺少文件会报错外,控制台大部分时间都是安静的,难以调试 。

  经查找,正常情况下代码错误时开发者工具是有错误提示的,而promise中的代码异常时不会有错误抛出。原因:mpvue中的promise被替换为 core-js polyfill 的 Promise 对象,global上没有全局错误处理。

  解决方案:在src下的main.js中添加一行require('core-js/library/modules/_global.js').console = console或者require('core-js/library/modules/_global.js').onunhandledrejection = console.errror

5.textarea写在组件中时,ios下绑定@input事件失败

  这个错误有点摸不着头脑,事情是这样的,我们把textarea做在弹层中作为一个公共编辑器组件,点击可编辑区域触发显示弹层。差不多长这样:

9e20dc08a9c86cbb869b8cbb9285c5634738a652
输入框需要实时统计字数,于是绑定了input事件。弹层使用v-show控制显隐,在开发者工具上正常,安卓下也正常,ios下有异常,提示@input绑定的事件找不到,同时绑定其他事件如bindblur就是正常的。
82f45e041d636ddc743c4bb76e6251ae6d705afb


75efc91cf3b843ffce7683a2ef7c8fdbd653816b

最终把v-show改成v-if就好了,原因还没找到。

6.引用第三方库报错TypeError: Cannot assign to read only property 'exports' of object '#<Object>'。

  引用第三方库时,我并未使用npm包的方式,而是直接将第三方库中的dist下的文件拷贝放到项目中libs下,然而webpack报错了,这个并非mpvue的问题,而是webpack不能混用import以及module.exports。因此需要将ES6的模块语法转换为AMD、CommonJS、UMD之类的模块化标准语法。


 1.使用transform-es2015-modules-commonjs插件

3215d7d7e0a22fad464d80d4cb19a2cbab7cbda8
 2.将babelrc下preset中的modules设置成"commonjs"

30267a4dba050df9acf1c4de206521027653a395

tips

1.小程序数字输入框键盘在ios下没有完成按钮,交互体验差。使用普通输入框。

2.textarea不能放到scroll-view里面使用。

3.textarea 的 blur 事件会晚于页面上的 tap 事件,如果需要在 button 的点击事件获取 textarea,可以使用 form 的 bindsubmit。


原文发布时间为:2018年06月27日
作者:花卷爱学习
本文来源:掘金     如需转载请联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9534 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,大概有三种登录方式:
2932 0
使用mpvue开发小程序教程(三)
【注意事项】由于mpvue也在不断的开发演进,大家在不同时间段使用的时候,可能会遇到和文中的做法不一样的地方。请关注文章的评论区中大家的讨论,寻找解决方案,或者及时查阅官方文档,避免陷入版本更新的坑里哦。
1049 0
微信小程序开发之picker
一、绑定简单数组 通过bindChange控制index,使得当前选择值发生改变 示例1 data: { Data: ['A','B'], Index: 0, }, 当前选择:{{Data[Index]}}  二、绑定多维数组 通过bindChange控制index,使得当前选择值发生改变,value是真正想得到值,选择后通过index可获取并设置,name只是想显示的值,这里的id其实是index值。
958 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
10846 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
6939 0
【小程序】微信小程序开发实践
帐号相关流程 注册范围 企业 政府 媒体 其他组织 换句话讲就是不让个人开发者注册。 填写企业信息 不能使用和之前的公众号账户相同的邮箱,也就是说小程序是和微信公众号一个层级的。
1170 0
+关注
我是管理员
社区管理员
46
文章
381
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载