首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Vue-Bootstrap b-form输入状态在模糊而不是负载上

Vue-Bootstrap b-form输入状态在模糊而不是负载上
EN

Stack Overflow用户
提问于 2021-05-05 19:02:16
回答 1查看 1.2K关注 0票数 1

我正在使用Vue-Bootstrap,我的组件中有一个b-form-input,它是一个密码。我检查此输入的验证是否密码至少有8个字符长:

代码语言:javascript
运行
复制
<b-form-group
        label="Password: (8 characters minimum)"
        minlength="8"
        class="text-left  mt-3"
      >
        <b-form-input
          v-model="form.password"
          type="password"
          name="password"
          placeholder="Enter Your Password"
          :state="passwordState"
          pattern=".{8,}"
          description="please enter a password "
          title="Password should be at least 8 characters long"
          required
        ></b-form-input>
        <b-form-invalid-feedback :state="passwordState">
          Your password must be at least 8 characters long.
        </b-form-invalid-feedback>
      </b-form-group>
      <b-form-group
        was-validated
        label="Confirm Password:"
        class="text-left  mt-3"
      >
        <b-form-input
          type="password"
          v-model="form.confirmpassword"
          placeholder="Confirm Your Password"
          required
          :state="confirmPasswordState"
          pattern=".{8,}"
        ></b-form-input>
        <b-form-invalid-feedback :state="confirmPasswordState">
          Your confirmed password must be exactly the same as your password
          field.
        </b-form-invalid-feedback>
      </b-form-group>
代码语言:javascript
运行
复制
 computed: {
    confirmPasswordState() {
      return this.form.password == this.form.confirmpassword &&
        this.form.confirmpassword != ""
        ? true
        : false;
    },
    passwordState() {
      return this.form.password.length >= 8 ? true : false;
    },
  },

我只想让这个状态验证出现在模糊上,而不是负载上。

EN

Stack Overflow用户

回答已采纳

发布于 2021-05-05 20:21:29

我认为最简单的方法是在数据中添加一个标志来跟踪输入是否模糊,然后根据该标志设置验证条件。

  1. passwordHasBlurred: false添加到data()
  2. @blur="passwordHasBlurred = true"添加到两个<b-form-input>s:中
    • 这告诉Bootstrap不显示验证状态。。
      • passwordState() {返回this.passwordHasBlurred?this.form.password.length >= 8?true : false : null;}

代码语言:javascript
运行
复制
-  confirmPasswordState() {   return this.passwordHasBlurred      ? this.form.password == this.form.confirmpassword &&      this.form.confirmpassword != ""       ? true       : false     : null; },

下面是一个可以运行的例子!(因其大小而隐藏):

代码语言:javascript
运行
复制
new Vue({
  el: '#app',
  data() {
    return {
      form: {
        password: '',
        confirmPassword: '',
      },
      passwordHasBlurred: false,
    }
  },
  computed: {
    confirmPasswordState() {
      return this.passwordHasBlurred 
        ? this.form.password == this.form.confirmpassword &&
         this.form.confirmpassword != "" 
         ? true 
         : false
        : null;
    },
    passwordState() {
      return this.passwordHasBlurred
        ? this.form.password.length >= 8
          ? true
          : false
        : null;
    },
  },
  methods: {
    reset() {
      this.form.password = '';
      this.form.confirmPassword = '';
      this.passwordHasBlurred = false;
    },
  },
});
代码语言:javascript
运行
复制
body {
  padding: 1rem;
}
代码语言:javascript
运行
复制
<!-- Add Vue and Bootstrap-Vue to snippet -->
<link type="text/css" rel="stylesheet" href="//unpkg.com/bootstrap/dist/css/bootstrap.min.css" /><link type="text/css" rel="stylesheet" href="//unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.min.css" /><script src="//polyfill.io/v3/polyfill.min.js?features=es2015%2CIntersectionObserver" crossorigin="anonymous"></script><script src="//unpkg.com/vue@2/dist/vue.min.js"></script><script src="//unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.min.js"></script>

<template id="app">
  <div>
    <b-form-group
      label="Password: (8 characters minimum)"
      minlength="8"
      class="text-left  mt-3"
    >
      <b-form-input
        v-model="form.password"
        type="password"
        name="password"
        placeholder="Enter Your Password"
        :state="passwordState"
        pattern=".{8,}"
        description="please enter a password "
        title="Password should be at least 8 characters long"
        required
        @blur="passwordHasBlurred = true"
      ></b-form-input>
      <b-form-invalid-feedback :state="passwordState">
        Your password must be at least 8 characters long.
      </b-form-invalid-feedback>
      </b-form-group>
      <b-form-group
        label="Confirm Password:"
        class="text-left  mt-3"
      >
      <b-form-input
        type="password"
        v-model="form.confirmpassword"
        placeholder="Confirm Your Password"
        required
        :state="confirmPasswordState"
        pattern=".{8,}"
        @blur="passwordHasBlurred = true"
      ></b-form-input>
      <b-form-invalid-feedback :state="confirmPasswordState">
        Your confirmed password must be exactly the same as your password
        field.
      </b-form-invalid-feedback>
    </b-form-group>
    <br>
    <b-btn variant="outline-secondary" @click="reset">
      Reset
    </b-btn>
  </div>
</template>

如果您希望或需要单独跟踪每个输入的模糊,只需将另一个属性添加到数据中,以便跟踪和相应地调整计算的属性和事件处理程序。

票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67407304

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档