原创:微信小程序之MaterialDesign--input组件

发布时间:2019-06-13 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了原创:微信小程序之MaterialDesign--input组件脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

作者:jeffer
来自:原文地址

主要通过input输入事件配合css的transform动态改变实现这种效果。

实际调试过程中,input组件bindinput事件触发后回调的detail对象,在模拟器中含有cursor属性,在真机中(测过安卓ios没测过)却没有该属性,最后选择detail对象中的value属性的值的长度来同步输入的位数。

binDFocus事件最好不要添加改变css的代码 。

预览图片:

原创:微信小程序之MaterialDesign--input组件

原创:微信小程序之MaterialDesign--input组件

JS:

//index.js
//获取应用实例
VAR app = getApp()
Page({
  data: {
    v_username_border:'', //用户输入框底部border样式
    v_pwd_border:'',  // 密码输入框底部border样式
    v_float_username:'', // 浮动文字字transform 样式
    v_float_pwd:'',
    num_current_un:0,  // 当前输入的文本位数
    sp_num_current_un:'', // 当前输入文本位数超过限制时的样式
    isPwdError:false  // 提交时 密码输入错误时的文本提示
  },
  onLoad: function () {
    console.log('onLoad')
  },
  // 用户名输入框获取焦点时事件回调
  usernameFocus:function(e){
    var that = this;
    console.log(e.detail)
  },
  // 用户名输入框输入时事件回调
  usernameinput:function(e){
    console.log(e.detail)
     this.setData({
      v_username_border:'border-bottom:1px solid red',
     num_current_un:e.detail.value.length
    })
    if(e.detail.value.length!=0){
       this.setData({
        v_float_username:'color:red ;transform: translateY(-18.5px)',
        sp_num_current_un:'color:lightseagreen;'
      })
      if(e.detail.value.length>20){
        this.setData({
          sp_num_current_un:'color:orangered;'
        })
      }
    }else{
      this.setData({
        v_float_username:'transform: translateY(0px)',
      })
    }
  },
  // // 用户名输入框失去焦点时回调
  usernameBlur:function(e){
    console.log("onBlur")
     this.setData({
      v_username_border:'border-bottom:1px solid grey'
    })
  },
  pwdFocus:function(e){
    console.log('onFocus')
  },
  pwdInput:function(e){
    this.setData({
      v_pwd_border:'border-bottom:1px solid red',
      isPwdError:false
    })
    console.log(e.detail)
    if(e.detail.value.length!=0){
      this.setData({
        v_float_pwd:'color:red ; transform: translateY(-18.5px)',
      })
    }else{
      this.setData({
        v_float_pwd:'transform: translateY(0px)',
      })
    }
  },
   pwdBlur:function(e){
    console.log("onBlur")
     this.setData({
      v_pwd_border:'border-bottom:1px solid grey; '
    })
  },
// 登录按钮模拟表单提交  可用form组件代替
  onLogin:function(e){
    this.setData({
      isPwdError:true
    })
  }
})

码地址https://github.com/jeffer0323...

脚本宝典总结

以上是脚本宝典为你收集整理的原创:微信小程序之MaterialDesign--input组件全部内容,希望文章能够帮你解决原创:微信小程序之MaterialDesign--input组件所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。