微信小程序之MaterialDesign--input组件详解


Posted in Javascript onFebruary 15, 2017

主要通过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
  })
 }
})

源码地址:We-MaterialDesign_3water.rar

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
document.onreadystatechange事件的用法分析
Oct 17 Javascript
javascript 动态设置已知select的option的value值的代码
Dec 16 Javascript
Web跨浏览器进程通信(Web跨域)
Apr 17 Javascript
jquery实现页面图片等比例放大缩小功能
Feb 12 Javascript
jQuery遮罩层效果实例分析
Jan 14 Javascript
完美实现八种js焦点轮播图(上篇)
Jul 18 Javascript
Angular学习笔记之angular的$filter服务浅析
Nov 12 Javascript
js实现表格筛选功能
Jan 18 Javascript
使用ef6创建oracle数据库的实体模型遇到的问题及解决方案
Nov 09 Javascript
VueCli3构建TS项目的方法步骤
Nov 07 Javascript
AJAX学习笔记
May 18 Javascript
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 Vue.js
Bootstrap table简单使用总结
Feb 15 #Javascript
原生js轮播(仿慕课网)
Feb 15 #Javascript
微信小程序 image组件binderror使用例子与js中的onerror区别
Feb 15 #Javascript
Canvas实现放射线动画效果
Feb 15 #Javascript
微信小程序 开发经验整理
Feb 15 #Javascript
bootstrap table操作技巧分享
Feb 15 #Javascript
利用n 升级工具升级Node.js版本及在mac环境下的坑
Feb 15 #Javascript
You might like
上海牌131型七灯四波段四喇叭一级收音机
2021/03/02 无线电
PHP截取中文字符串的问题
2006/07/12 PHP
PHP开发的一些注意点总结
2010/10/12 PHP
PHP包含文件函数include、include_once、require、require_once区别总结
2014/04/05 PHP
PHP错误Allowed memory size of 67108864 bytes exhausted的3种解决办法
2014/07/28 PHP
php+ajax制作无刷新留言板
2015/10/27 PHP
php版银联支付接口开发简明教程
2016/10/14 PHP
JS是否可以跨文件同时控制多个iframe页面的应用技巧
2007/12/16 Javascript
JavaScript 变量命名规则
2009/09/23 Javascript
javascript 广告后加载,加载完页面再加载广告
2010/11/25 Javascript
jquery等宽输出文字插件使用介绍
2013/09/18 Javascript
Event altKey,ctrlKey,shiftKey属性解析
2013/12/18 Javascript
js去除输入框中所有的空格和禁止输入空格的方法
2014/06/09 Javascript
简述JavaScript的正则表达式中test()方法的使用
2015/06/16 Javascript
JavaScript实现简洁的俄罗斯方块完整实例
2016/03/01 Javascript
Django1.7+JQuery+Ajax验证用户注册集成小例子
2017/04/08 jQuery
vuejs如何配置less
2017/04/25 Javascript
详解vue.js下引入百度地图jsApi的两种方法
2018/07/27 Javascript
JavaScript引用类型Function实例详解
2018/08/09 Javascript
原生JS实现手动轮播图效果实例代码
2018/11/22 Javascript
js实现点赞效果
2020/03/16 Javascript
Webpack中SplitChunksPlugin 配置参数详解
2020/03/24 Javascript
小谈angular ng deploy的实现
2020/04/07 Javascript
浅谈vue项目利用Hbuilder打包成APP流程,以及遇到的坑
2020/09/12 Javascript
js正则表达式简单校验方法
2021/01/03 Javascript
[53:49]LGD vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
Python中使用item()方法遍历字典的例子
2014/08/26 Python
Python中用PIL库批量给图片加上序号的教程
2015/05/06 Python
Html5+JS实现手机摇一摇功能
2015/04/24 HTML / CSS
外包公司软件测试工程师
2014/11/01 面试题
应用数学自荐书范文
2013/11/24 职场文书
初婚未育未抱养证明
2014/01/12 职场文书
基层干部十八大感言
2014/01/19 职场文书
董事长秘书职责
2014/01/31 职场文书
python脚本框架webpy模板赋值实现
2021/11/20 Python
python数字图像处理之图像自动阈值分割示例
2022/06/28 Python