小程序制作节点一:input文本框(1)

input文本框第一个攻克的小节点是:判断用户输入的内容长度,合格出现正确提示,不合格出现错误提示。

 

具体要求是,在input输入框失焦时判断是否输入了内容,手机号输入框要输入足够11位数,否则出现错误。

这里input是原生组件,所以我用原生事件处理'bindbulr',即输入框失去焦点时触发,基本代码如下:

WXML:

<view class="body-3">
    <view class="information">
        <text class="tittle buyerinformation">购买人信息</text>
        <view class="buyerName" vx:if="{{length > 10}}">
            <input class="buyerName1" type="text" value="" bindblur="ok1" placeholder="请输入姓名"/>
            <view class="yes" wx:if="{{isShowYes1}}">✔</view>
            <view class="no"wx:if="{{isShowNo1}}">✖</view>
        </view>
        <view class="buyerPhone">
            <input class="buyerPhone1" type="number" bindblur="ok2" placeholder="请输入手机号" maxlength="11" />
            <view class="yes" wx:if="{{isShowYes2}}">✔</view>
            <view class="no"wx:if="{{isShowNo2}}">✖</view>
        </view>
    </view>
</view>

 WXSS:

.body-3 {
    height: 100%;
    padding: 66rpx 50rpx 64rpx 50rpx;
    border-bottom: 40rpx solid #ededed;
    font-size: 28rpx;
}
.buyerinformation {
    margin-bottom: 0rpx;
}
.buyerName {
    display: flex;
    align-items:flex-end;
    justify-content: space-between;
    height: 100rpx;
    font-weight: 600;
    border-bottom: 6rpx solid #8e731b;
}
.buyerPhone {
    display: flex;
    align-items:flex-end;
    justify-content: space-between;
    height: 100rpx;
    font-weight: 600;
    border-bottom: 6rpx solid #8e731b;
}
.buyerName {
    position: relative;
}
.buyerName1 {
    margin: 0 0 18rpx 16rpx;
}
.buyerPhone {
    position: relative;
}
.buyerPhone1 {
    margin: 0 0 18rpx 16rpx;
}
.yes {
    position: absolute;
    right: 0;
    margin-bottom:18rpx;
    color: #8e731b;
}
.no {
    margin-bottom:18rpx;
    color: red;
}

JS :

Page({
  data: {
    isShowYes1: false,
    isShowNo1: false,
    isShowYes2: false,
    isShowNo2: false,
  },
  ok1(e) {
    let name = e.detail.value;
    if (name.length > 0) {
      this.setData({
        isShowYes1: true,
        isShowNo1:false
      })
      return false;
      }
    else if(name.length == 0) {
      this.setData({
        isShowNo1:true,
        isShowYes1:false
      })
      return false;
      }
  },
  ok2(e) {
    let name = e.detail.value;
    if (name.length == 11) {
      this.setData({
        isShowYes2: true,
        isShowNo2:false
      })
      return false;
      }
    else if(name.length !== 11) {
      this.setData({
        isShowNo2:true,
        isShowYes2:false
      })
      return false;
      }
  }
})

在JS 代码里 “OK”函数中“e.detail.value”这个属性是动态获取input的value值,可以在其下一行console.log输出一下name值验证。

这点玩意弄了半天才会,查了不少资料,灵感来源:input的bindblur事件验证问题 | 微信开放社区 (qq.com)

本人有点笨,希望大家不吝赐教。看到这篇文章就是缘分,可以点个赞支持下,谢谢。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值