javascript - 无效 Prop : type check failed for prop

标签 javascript vue.js vuejs2 vue-component

我用 Vue.js 创建了一个倒计时,但我无法显示我得到的值。我有两个组件,我已经阅读了 Vue 的单文件组件指南,但我似乎不明白我做错了什么。在控制台中,我收到以下错误:

[Vue warn]: Invalid prop: type check failed for prop "date". Expected Number, got String.

尽管在我的代码中它被定义为一个数字。

app.js

import './bootstrap.js';

import Echo from 'laravel-echo';
import Vue from 'vue';

import CurrentTime from './components/CurrentTime';
import Bitbucket from './components/Bitbucket';
import InternetConnection from './components/InternetConnection';
import LastFm from './components/LastFm';
import PackagistStatistics from './components/PackagistStatistics';
import RainForecast from './components/RainForecast';
import Placeholder from './components/Placeholder';
import Youtube from './components/Youtube';
import ProjectCountdown from './components/ProjectCountdown';
import Countdown from './components/Countdown';


Vue.component('countdown', Countdown);

new Vue({

el: '#dashboard',

components: {
    CurrentTime,
    InternetConnection,
    Bitbucket,
    LastFm,
    PackagistStatistics,
    RainForecast,
    Placeholder,
    Youtube,
    ProjectCountdown,
    Countdown
},

created() {
    this.echo = new Echo({
        broadcaster: 'pusher',
        key: window.dashboard.pusherKey,
        cluster: 'eu',
        encrypted: true
    });
},
});

ProjectCountdown.vue

<template>
<div id="dashboard">
    <Countdown date="March 20, 2017 12:00"></Countdown>
    {{days}}
</div>
</template>

<script>
import Grid from './Grid';
import Vue from 'vue';
import Countdown from './Countdown';

export default {

components: {
    Grid,
    Countdown,
},

props: {
    grid: {
        type: String,
    },
},

data() {
    return {

    }
}
}



// Vue.filter('two_digits', function (value) {
//     if(value.toString().length <= 1)
//     {
//         return "0" + value.toString()
//     }
//     return value.toString();
// });
</script>

倒计时.vue

<template>
<div>
    {{ seconds }}
</div>
</template>


<script>
import Vue from 'vue';
export default {

props: {
    date: {
        type: Number,
        coerce: str => Math.trunc(Date.parse(str) / 1000)
    },
},
data() {
    return {
        now: Math.trunc((new Date()).getTime() / 1000)
    }
},
ready() {
    window.setInterval(() => {
        this.now = Math.trunc((new Date()).getTime() / 1000);
    },1000);


},
computed: {
    seconds() {
        return (this.date - this.now) % 60;
    },
    minutes() {
        return Math.trunc((this.date - this.now) / 60) % 60;
    },
    hours() {
        return Math.trunc((this.date - this.now) / 60 / 60) % 24;
    },
    days() {
        return Math.trunc((this.date - this.now) / 60 / 60 / 24);
    },
},
}
</script>

最佳答案

正如错误所说,它来自这一行:

<Countdown date="March 20, 2017 12:00"></Countdown>

您将 date 作为字符串传递,而在 props 中验证它是一个数字。这是您的验证:

props: {
    date: {
        type: Number,
        coerce: str => Math.trunc(Date.parse(str) / 1000)
    },
},

我认为在新项目中您使用的是 vuejs2,其中 coerce 选项是 removed .如前所述here您可以使用如下所示的计算属性:

props: {
    date: {
        type: Number
    },
},
computed: {
   modifiedDate: function(){
       return Math.trunc(Date.parse(this.date) / 1000)
   }
}

您现在可以使用 modifiedDate 而不是 date

关于javascript - 无效 Prop : type check failed for prop,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42715136/

相关文章:

javascript - 视觉 : How to use component prop inside mapFields

javascript - Vuejs/javascript 计算购物车中的商品

javascript - 如何在 VueJS 的 promise 中设置数组对象属性的值?

javascript - 如何定期更新 VueJS 中的组件

javascript - 当我发出 Ajax 请求时,为什么会收到 TypeError : $. ajax is not a function?

javascript - vuejs bool Prop watch 不会触发

javascript - 提前输入自动完成抛出错误

javascript - 从 laravel Controller 返回 json 时尝试获取非对象的属性 'id'

javascript - 不允许我调整 IFrame 窗口的大小

javascript - 改变被点击的元素并保存在cookies中