TypeScript 回车触发聚焦 @keyup.enter.native

1.vue登录界面输入用户名回车自动聚焦密码框

 

用户框里放:@keyup.enter.native="submitForm('formInline')";

密码框里放::ref="password"

登录数据:

formInline: {
   userName: '',
   password: '',
}

回车绑定事件:

submitForm(formName: string): void {
      if (this.formInline.userName !== '' && this.formInline.password === '') {
        // 聚焦密码
        (this.$refs as HTMLFormElement).password.focus();
      }
      if (this.formInline.userName === '' && this.formInline.password !== '') {
        // 聚焦用户名
        (this.$refs as HTMLFormElement).userName.focus();
      }

      // 数据验证
      (this.$refs[formName] as HTMLFormElement).validate((valid: boolean) => {
        if (valid) {
          retrn true;
        }
      });
    },

2.@keyup.enter.native跟@keyup.enter区别

直接在根元素上绑定可以用@keyup.enter

如果使用的封装组件,例如element的el-input就必须使用@keyup.enter.native

posted @ 2020-12-19 10:47  潇潇mini  阅读(965)  评论(0编辑  收藏  举报