初识微信小程序的form

想创造一个报名页面,对form没有概念,在官网找到form的组件说明,总结出经验:

 

想用form,只要:

1、在wxml页面收尾加上

<form bindsubmit="formSubmit" bindreset="formReset">

......

</form>

2、在其中的各个输入组件的属性中加入name属性

3、在button组件的属性加入formType="submit"

就行了。

 点击按键后,会触发bindsubmit="formSubmit"函数:

formSubmit: function (e) {
    console.log('form发生了submit事件,携带数据为:', e.detail.value)
  }

e.detail.value返回值自动编写成js对象:

{switch: false, slider: "", input: "", radio-group: "radio2", checkbox: Array(2)}

 

用这个套路可以快速改写weui中的form例子,为我所用。

 

<!--pages/weui/login.wxml-->
<form bindsubmit="formSubmit" bindreset="formReset">
<view class="page">
    <view class="weui-form">
      <view class="weui-form__text-area">
        <view class="weui-form__title">表单标题</view>
        <view class="weui-form__desc">表单描述示意</view>
      </view>
      <view class="weui-form__control-area">
        <view class="weui-cells__group weui-cells__group_form">
            
            <view class="weui-cells weui-cells_form">
              <view class="weui-cell">
                <view class="weui-cell__hd"><label class="weui-label">姓名</label></view>
                <view class="weui-cell__bd">
                    <input class="weui-input" type="text" name="name" placeholder="请输入姓名"/>
                </view>
              </view>

              <view class="weui-cell">
                <view class="weui-cell__hd"><label class="weui-label">手机号</label></view>
                <view class="weui-cell__bd">
                    <input class="weui-input" type="number" pattern="[0-9]*" name="phone" placeholder="请输入手机号"/>
                </view>
              </view>
            </view>



        </view>
      </view>
      <view class="weui-form__tips-area">
        <label for="weuiAgree" class="weui-agree">
          <input id="weuiAgree" type="checkbox" class="weui-agree__checkbox"/><span class="weui-agree__text">阅读并同意<a href="javascript:void(0);">《相关条款》</a>
          </span>
        </label>
      </view>
      <view class="weui-form__opr-area">
        <button type="primary" formType="submit">确定</button>
      </view>
      <view class="weui-form__tips-area">
        <view class="weui-form__tips">
          点击下一步即表示<navigator href="javascript:;">同意用户协议</navigator>
        </view>
      </view>
      <view class="weui-form__extra-area">
        <view class="weui-footer">
          <view class="weui-footer__links">
            <navigator href="javascript:void(0);" class="weui-footer__link">底部链接文本</navigator>
          </view>
          <view class="weui-footer__text">Copyright © 2008-2019 weui.io</view>
        </view>
      </view>
    </view>
</view>
</form>
// pages/weui/login.js
Page({

  /**
   * 页面的初始数据
   */
  data: {

  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  },
  formSubmit: function (e) {
    console.log('form发生了submit事件,携带数据为:', e.detail.value)
    const db = wx.cloud.database()
    db.collection('counters').add({
      data: e.detail.value,
      success: res => {
        // 在返回结果中会包含新创建的记录的 _id
        this.setData({
          counterId: res._id,
          count: 1
        })
        wx.showToast({
          title: '新增记录成功',
        })
        console.log('[数据库] [新增记录] 成功,记录 _id: ', res._id)
      },
      fail: err => {
        wx.showToast({
          icon: 'none',
          title: '新增记录失败'
        })
        console.error('[数据库] [新增记录] 失败:', err)
      }
    })
  },
  formReset: function () {
    console.log('form发生了reset事件')
  }

})

 这个例子结合了小程序云数据库,weui,和form。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值