为什么我的子组件Property or method "phoneFormRules" is not defined on the instance but referenced during render.

来源:3-6 手机验证码登录组件编写(2)

慕粉3396878

2020-09-27 15:37

父组件

<phone-login :rule-form="phoneForm"></phone-login>

子组件

<template>

 <div>

   <el-form :model="ruleForm"

            :rules="phoneFormRules"

            ref="ruleForm">

     <el-form-item prop="phone">

       <el-input placeholder="请输入手机号"

                 v-model="ruleForm.phone">

         <i slot="prefix"

            class="el-icon-phone"></i>

       </el-input>

     </el-form-item>

     <el-form-item prop="code">

       <el-row :gutter='18'>

         <el-col :span="18">

           <el-input placeholder="请输入验证码"

                     v-model="ruleForm.code">

             <i slot="prefix"

                class="el-icon-tickets"></i>

           </el-input>

         </el-col>

         <el-col :span="6">

           <el-button>发送验证码</el-button>

         </el-col>

       </el-row>

     </el-form-item>

     <el-form-item>

       <el-button type="primary"

                  style="width:100%">登录</el-button>

     </el-form-item>

   </el-form>

 </div>

</template>

<script>

export default {

 name: 'PhoneLogin',

 props: {

   ruleForm: {

     type: Object,

     require: true

   },

   countDown: {

     type: Number,

     default: 60

   },

   data () {

     const checkPhone = (rule, value, callback) => {

       if (!value) {

         return callback(new Error('手机号不能为空'))

       } else {

         const reg = /^1[3|4|5|7|8][0-9]\d{8}$/

         if (reg.test(value)) {

           callback()

         } else {

           return callback(new Error('请输入正确的手机号'))

         }

       }

     }

     return {

       phoneFormRules: {

         phone: [{ validator: checkPhone, trigger: 'change' }],

         code: [{ require: true, message: '验证码不能为空', trigger: 'blur' }]

       }

     }

   }

 }

}

</script>




写回答 关注

1回答

  • 慕粉3396878
    2020-09-27 15:48:56

    data位置错误

基于Element-UI二次封装业务组件

基于element-ui二次封装业务组件

11544 学习 · 30 问题

查看课程

相似问题