如上图,小程序api中的switch组件只能自定义颜色,不能自定义宽高,因此就开始了本身写switch组件。小程序
自定义组件样式api
switch组件样式大体如图,样式思路:未选中时为一个长方形有圆角按钮,和一个半径为长方形【(长方形高度/2)-1】的圆圈,当状态为选中时,圆圈向右滚动,滚动距离为【长方形宽度-长方形高度-1】,动画效果经过过渡属性来赋予的,控制圆圈的left值。ide
自定义组件构思工具
从父组件传来值有:高度height,宽度width,选中时背景bgColor,未选中背景unBgColor,是否选中的状态值checked,宽高单位为rpx。动画
定义了一个组件方法,点击时触发该方法执行,执行后要作的事情交给父组件来处理,而且传给父组件一个状态值,考虑到在真实状况下会进行http请求,因此传了一个请求成功时的回调和失败时的回调。spa
组件使用code
在写demo时发现一个问题:当checked值直接在wxml中写入false或者是true时状态都为true,只有在js中定义data值为false,才使得状态为false,具体缘由不造,哪位大大要是知道缘由,烦请告知。xml
!!!项目demo!!!
附连接:wechatide://minicode/ZErlcKmG79Em 在开发者工具中预览blog