Maison >Applet WeChat >Développement de mini-programmes >Explication détaillée de MaterialDesign - composant d'entrée de l'applet WeChat

Explication détaillée de MaterialDesign - composant d'entrée de l'applet WeChat

高洛峰
高洛峰original
2017-02-18 11:52:061737parcourir

Cet article présente principalement l'explication détaillée du composant d'entrée MaterialDesign de l'applet WeChat. Il a une certaine valeur de référence et les amis intéressés peuvent s'y référer.

Cet effet est principalement obtenu grâce aux événements d'entrée et aux changements dynamiques de la transformation CSS.

Pendant le processus de débogage réel, l'objet détail rappelé après le déclenchement de l'événement bindinput du composant d'entrée contient l'attribut curseur dans le simulateur, mais n'a pas cet attribut dans l'appareil réel (testé sur Android, mais pas sur iOS). Enfin, sélectionnez la longueur de l'attribut value dans l'objet de détail pour synchroniser le nombre de chiffres saisis.

Il est préférable de ne pas ajouter de code qui modifie le CSS à l'événement bindfocus.

Image d'aperçu :

Explication détaillée de MaterialDesign - composant dentrée de lapplet WeChat

Explication détaillée de MaterialDesign - composant dentrée de lapplet WeChat

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
  })
 }
})

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. J'espère également que tout le monde soutiendra le site Web PHP chinois.

Pour des explications plus détaillées sur le composant d'entrée MaterialDesign de l'applet WeChat, veuillez faire attention au site Web PHP chinois !


Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn