Maison  >  Questions et réponses  >  le corps du texte

Pourquoi mon validateur element-ui-form ne peut-il pas être appelé ?

Le code est le suivant :

**validateCode:[{validator:(rule, value, callback)=>{
    if (!value) { 
      callback(new Error('you have to input code')) 
    } else if(this.radioValue=="mobile"){
      validatingCo(this.user.mobile,value).then((res)=>{
        if(!res.code==20000){
           return callback(new Error('the code is wrong or expired'))
         } else{
             callback()
         }
      })
    }
    else{
       validatingCo(this.user.email,value).then((res)=>{
         if(!res.code==20000){
           return  callback(new Error('the code is wrong or expired'))
         } else{
           callback()
         }
       })
    }
  }, trigger:'blur'}]

Malheureusement, il ne s'exécute pas et il n'y a aucune erreur. Je veux savoir comment y faire face.

P粉274161593P粉274161593205 Il y a quelques jours336

répondre à tous(1)je répondrai

  • P粉187677012

    P粉1876770122024-03-28 09:00:47

    Je pense que le problème pourrait être causé par cette ligne :

    if(!res.code==20000){
      // Some stuff here
    }

    Cela devrait probablement être :

    if(res.code!=20000){
      // Some stuff here
    }

    !res.code 将始终评估为 truefalse。所以 !res.code==20000 sera toujours faux. Peu importe ce qui est saisi, le rappel d'erreur suivant ne sera pas exécuté :

    return callback(new Error('the code is wrong or expired'))

    Voici une petite démo montrant que "bar" est toujours imprimé

    function simple_if(number) {
      if (!number == 20000) {
        return "foo"
      } else {
        return "bar"
      }
    }
    
    console.log(`res=20000. Expect 'bar': ${simple_if(2000)}`)
    console.log(`res=3. Expect 'foo': ${simple_if(3)}`)
    console.log(`res=0. Expect 'foo': ${simple_if(0)}`)

    répondre
    0
  • Annulerrépondre