小程序Behavior+form构建复可配置表单

背景描述

由于公司项目的需求,项目中会遇到各种各样的表单,但是表单样式几乎都是统一的,考虑将所有的样式输入或者展示组件封装入自定义form组件内,form组件自己处理是否全部的必填项填写完毕,生成对应的respontBody,检验用户的输入负责是否符合规范,具体每个子页面的展示和单独的数据源处理是单独的js去处理。由于之前做移动端开发,做过类似的封装所以做了一下封装尝试,效果还错。


Aug-19-2020 11-10-41.gif

代码思路讲解

1.先构建自己的form组件

通过Behavior共用代码路由到配置项js文件
        {
            'title': '车系', // 标题
            'require': true, //是否必填项
            'value': -1,//组件的值后面会转为数据
            'type': 'picker', //组件类型,标识时那种组件
            'subType': 'seclector', //组件的次级分类
            'placeholder': '请选择',
            'regular': '',//校验规则
            'error': '',//错误提示
            'apiKey': 'dartment',//上传接口时候的key
            'index': 5,//在表单中的下标
            'hidden': false,//是否隐藏
            'options': [
            ],//数据源
        },
//当个picker组件form.wxml的样式示例
    <!-- picker组件分为date和配置项选择 -->
    <view wx:elif="{{item.type === 'picker'}}">
        <view wx:if="{{item.subType === 'date'}}">
            <picker mode="date" start="{{item.startDate}}" end="{{item.endDate}}" bindchange="pickerVauleChange" id="{{index}}">
                <view class="picker-back {{item.value ? 'normal-font' : 'gray-font'}}">
                    <view class="we-picker-flex">
                        <text class="cell-title">{{item.title}}</text>
                        <i class="red-font-picker" hidden="{{item.require}}">*</I>
                    </view>
                    <view class="picker {{item.value ? 'normal-font' : 'gray-font'}}">{{item.value ? item.value :item.placeholder}}
                        <i class="csyfont csyxiayiye i"></I>
                    </view>
                </view>
            </picker>
        </view>
        <view wx:else>
            <picker mode="selector" range="{{item.options}}" bindchange="pickerVauleChange" range-key="label" id="{{index}}" value="{{item.value}}">
                <view class="picker-back">
                    <view class="we-picker-flex">
                        <text class="cell-title">{{item.title}}</text>
                        <i class="red-font-picker" hidden="{{item.require}}">*</I>
                    </view>
                    <view class="picker {{item.value > -1 ? 'normal-font' : 'gray-font'}}">{{item.options[item.value] ? item.options[item.value].label :item.placeholder}}
                        <i class="csyfont csyxiayiye i"></I>
                    </view>
                </view>
            </picker>
        </view>
    </view>

效果如下:


截屏2020-08-19 上午11.21.20.png

2.通过behaviors引入共用的代码和共用属性

代码示例:

Component({
    options: {
        addGlobalClass: true // 等价于styleIsolation: 'apply-shared'
    },
    behaviors: [require('../../behavior/route/route.js')], // 引入公共代码
    externalClasses: ['my-class'],
    properties: {
        extraData: {
            type: Object,
            value: {}, //其他的子页面需要的数据类型
            observer: '__extraData'
        },
        saveData: {
            type: Boolean,
            value: false,
            observer: '__saveRequest'//父类发起了保存操作,会顺序讲item.value和item.apiKey相结合并触发提交
        },
        extraInput: {
            type: Array,
            value: [],
            observer: '__exraInput'
        }
    },
    data: {
        datasource: [],//数据源
        emptyAry: [], //所有重要的下标
        allInput: false,//是否全部填写完毕
        ativeIndex: 0,
        vaild: [],//需要校验规则,输入是否合法
        requestData: {} //需要默认传的值
    },
}

3.rout.js到底做了什么?

module.exports = Behavior({
    properties:{
        // 指定单独操作组件的数据源的文件夹名称
        behaviorCode:String,
        // 文件名称
        behaviorModel:{
            type:String,
            value:''
        }
    },
    data:{
        behaviorSite:''
    },
    attached:function(){
        let code = this.data.behaviorCode || this.data.behaviorModel
        this.setData({
            behaviorSite: require('../../behavior/' + this.data.behaviorModel + '/' + code + '.js')//引入指定文件
        })
    },
    methods:{

    }
})

4.引用自定form的时候,通过behaviorCode和behaviorModel绑定操作当前的form的js文件

<cs-form  behaviorModel="repectionnew" behaviorCode="repectionnew" bind:allInput="allslected" saveData="{{saveData}}" ></cs-form>

5.在form里面对绑定的js操作

5.1 获取数据源

             this.data.behaviorSite.datasource(this, function (res) {
                if (res) {
                    if (!util.isNull(that.data.datasource)) {
                        util.log("form:" + 'behaviorSite.datasource')
                        that.getEmptyAry(that.data.datasource)
                    }
                } else {
                    that.getEmptyAry(that.data.datasource)
                }
            })

5.2面对需要调的单独方法

只需要调用指定的js暴露出来的方法就好

如果有小伙伴比较感兴趣的也可以留言,我也会发出对应的脱离项目的demo!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容

  • 0、杂记 0.1、在实际的开发中,图片资源不会存储在小程序的目录中,因为小程序的大小不能超过1MB(现在改为2M)...
    it筱竹阅读 5,327评论 0 10
  • Taro 是一套遵循React语法规范的多端开发解决方案,可以快速开发微信小程序,并且支持多端开发转化,喜欢Rea...
    buer一w阅读 1,858评论 0 0
  • 写在前面 微信小程序出来也蛮久了,经过了市场的考验,已经站稳脚跟,融入到了各行各业,市场需求激增打来的是开发人员的...
    月梦佳期阅读 1,684评论 1 1
  • web端开发的童鞋知道,前端视图层和服务端交互都是通过form表单进行的,在小程序中也不例外。 认识form表单 ...
    睿丶清阅读 2,200评论 0 1
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,515评论 16 22