Vue.js ready()方法不会在vue组件中调用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue.js ready()方法不会在vue组件中调用相关的知识,希望对你有一定的参考价值。

我正在使用Webpack bundler来提供基于Vue 2.0的前端。问题是组件中的方法ready没有被调用。我是否需要在组件上添加一些额外的手表或类似的东西?

我的路由器:

import Vue from 'vue'
import VueRouter from 'vue-router'
import VueResource from 'vue-resource'

import Register from './views/auth/register.vue'

Vue.use(VueRouter);
Vue.use(VueResource);

const routes = [
  { path: '/auth/register', component: Register } 
]

const router = new VueRouter({
  routes // short for routes: routes
})

export default router;

和我的样本组件:

<template>
    <div>
        <div class="message">{{ msg }}</div>
    </div>
</template>

<script>
export default {

    data: function () {
        return {
            msg: 'Hello from vue-loader!'
        }
    },

    ready: function() {
        console.log('test');
    }
}
</script>
答案

ready()生命周期钩子方法在VueJS 2.0.x中被删除。使用mounted()created()代替。

另一答案

如果您需要在100%加载图像和文件后运行代码,请在mounted()中测试:

document.onreadystatechange = () => {
  if (document.readyState == "complete") {
    console.log('Page completed with image and files!')
    // fetch
  }
}

更多信息:MDN Api onreadystatechange

以上是关于Vue.js ready()方法不会在vue组件中调用的主要内容,如果未能解决你的问题,请参考以下文章

物化表单在 vue.js 组件中不起作用

未触发 Vue js Ready 功能

准备好使用 Vue.js 访问子组件中的 api 数据

Vue.js 不会在屏幕上显示多个组件

Vue.js。子组件中的变异道具不会触发警告。想知道为啥

未在已安装的钩子中定义的方法,Vue JS