【问题标题】:Vue 3 Typescript unable to access method from refVue 3 Typescript 无法从 ref 访问方法
【发布时间】:2021-07-08 12:10:50
【问题描述】:

大家好,我是 Vue 3 和 Typescript 的新手,我很难在我的项目中解决 typescript 错误,下面是 typescript 错误。

它无法找到验证方法,但是当我尝试对其进行控制台时它会显示。

类型“字符串”上不存在属性“验证”。

我正在使用带有 typescript 和 Vue Element Plus 的 Vue 3 组合 API,下面是我的组件代码。

组件

    <template>
  <div class="w-full h-full absolute flex">
    <el-form
      class="w-4/5 sm:w-1/2 lg:w-1/3 xl:w-1/4 m-auto"
      :ref="formRef"
      :model="form"
      :rules="rules"
    >
      <h2>Login</h2>
      <el-form-item label="Email" prop="email">
        <el-input
          type="email"
          autocomplete="off"
          v-model="form.email"
        />
      </el-form-item>
      <el-form-item label="Password" prop="password">
        <el-input
          type="password"
          autocomplete="off"
          v-model="form.password"
        />
      </el-form-item>
      <el-form-item>
        <el-button
          type="success"
          class="w-full"
          @click="handleLogin"
        >Submit</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script lang="ts">
import { defineComponent, onBeforeMount, onMounted, reactive, ref } from "vue";
export default defineComponent({
  name: "Login",
  setup() {
    const form = reactive({
      email: "",
      password: ""
    });
    const rules = ref({
      email: [{
        required: true,
        message: "Email is required",
        trigger: "blur"
      }],
      password: [{
        required: true,
        message: "Password is required",
        trigger: "blur"
      }]
    });
    const formRef = ref("formRef");

    const handleLogin = () => {
      console.log(formRef)
      // Property 'validate' does not exist on type 'string'.
      formRef.value?.validate((valid: boolean) => {
        console.log(valid);
      });
    };

    onMounted(() => {
      console.log("Login mounted");
    });

    onBeforeMount(() => {
      console.log("Login onBeforeMount");
    });

    return {
      formRef,
      form,
      rules,
      handleLogin
    };
  }
});
</script>

【问题讨论】:

  • .value prop 是一个字符串。 formRef.validate 呢?

标签: javascript typescript vue.js vuejs3 element-plus


【解决方案1】:

有一些错误。 ref 接收原始类型字符串、布尔值等...对于使用响应式的对象。

所以你应该使用响应式而不是参考来定义规则。

const rules = reactive({
      email: [{
        required: true,
        message: "Email is required",
        trigger: "blur"
      }],
      password: [{
        required: true,
        message: "Password is required",
        trigger: "blur"
      }]
    });

你不需要绑定你的 ref 所以这样做:

 <el-form
          class="w-4/5 sm:w-1/2 lg:w-1/3 xl:w-1/4 m-auto"
          ref="formRef"
          :model="form"
          :rules="rules"
        >

我建议您使用 html 转换对象声明您的 formRef。

像这样:

const formRef = ref<HTMLFormElement>();

希望对你有帮助=)

【讨论】:

    猜你喜欢
    • 2021-03-12
    • 2021-10-19
    • 2021-03-26
    • 1970-01-01
    • 2022-01-05
    • 1970-01-01
    • 2017-06-28
    • 2021-11-19
    相关资源
    最近更新 更多