[Vue warn]: Invalid prop: custom validator check failed for prop "value" 的原因是什么

And*_*aev 8 vue.js nuxt.js vuejs-datepicker

我有 nuxt.js 应用程序,它使用vuejs-datepicker

<template>
<!-- ... -->

    <DatePicker :value="datePicker.value" />
 <!-- ... -->
 </template>
Run Code Online (Sandbox Code Playgroud)

和一堆日期变量:

<script>
import DatePicker from 'vuejs-datepicker'
import { DateTime } from 'luxon'

const moment = require('moment')

const date = new Date(2016, 8, 16)
const date2 = moment('2016-09-16').toDate()
const date3 = DateTime.local(2016, 9, 16).toJSDate()

export default {
  components: {
    DatePicker
  },
  data() {
    return {
      datePicker: {
        mondayFirst: true,
        format: 'dd.MM.yyyy',
        value: date
      }
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

当我将其“value”属性绑定到通常的日期变量“date”时,一切正常,但是当我选择 date2 或 date3 时,我收到这个恼人的警告

[Vue warn]: Invalid prop: custom validator check failed for prop "value".

found in

---> <DatePicker>
       <StaticPositionsTab> at components/StaticPositions.vue
         <BTab>
           <BTabs>
             <Pages/index.vue> at pages/index.vue
               <Nuxt>
                 <Layouts/default.vue> at layouts/default.vue
                   <Root>
Run Code Online (Sandbox Code Playgroud)

我找到了 value 属性的自定义验证器,它非常简单明了,并且在所有三种情况下都返回 true:

value: {
      validator: function (val) { return utils$1.validateDateInput(val); }
    }
Run Code Online (Sandbox Code Playgroud)

...

validateDateInput (val) {
    return val === null || val instanceof Date || typeof val === 'string' || typeof val === 'number'
  }
Run Code Online (Sandbox Code Playgroud)

但那有什么不同呢?难道是 Vue.js 本身的 bug?

itt*_*tus 3

date2date3是对象,而 value 需要 null | 日期 | 字符串| 数字

const date2 = moment('2016-09-16').toDate()
const date3 = DateTime.local(2016, 9, 16).toJSDate()

typeof date2 // object
typeof date3 // object
Run Code Online (Sandbox Code Playgroud)

您应该使用.toString()将它们转换为字符串

const date2 = moment('2016-09-16').toString()
const date2 = moment('2016-09-16').toISOString()
const date3 = DateTime.local(2016, 9, 16).toString()
Run Code Online (Sandbox Code Playgroud)

或使用unix时间戳

const date2 = moment('2016-09-16').unix()
const date3 = moment('2016-09-16').valueOf()
const date4 = moment('2016-09-16').getTime()
const date5 = DateTime.local(2016, 9, 16).valueOf()
Run Code Online (Sandbox Code Playgroud)