Подтвердить что ты не робот

Vue.js - использование родительских данных в компоненте

Как я могу получить доступ к родительской переменной данных (limitByNumber) в моем дочернем компоненте Post?

Я попытался использовать prop, но он не работает.

Родитель:

import Post from './components/Post.vue';

new Vue ({
    el: 'body',

    components: { Post },

    data: {
        limitByNumber: 4
    }
});

Сообщение компонента:

<template>
            <div class="Post" v-for="post in list | limitBy limitByNumber">
                <!-- Blog Post -->
....
</div>
</template>


<!-- script -->    
<script>
        export default {
            props: ['list', 'limitByNumber'],


            created() {
                this.list = JSON.parse(this.list);
            }

        }
</script>
4b9b3361

Ответ 1

Вариант 1

Используйте this.$parent.limitByNumber из дочернего компонента. Таким образом, ваш шаблон компонента будет таким образом

<template>
    <div class="Post" v-for="post in list | limitBy this.$parent.limitByNumber">                
    </div>
</template>

Вариант 2

Если вы хотите использовать реквизит, вы также можете достичь того, чего хотите. Вот так.

Родитель

<template>
   <post :limit="limitByNumber"></post>
</template>
<script>
export default {
    data () {
        return {
            limitByNumber: 4
        }
    }
}
</script>

Детские горшки

<template>
            <div class="Post" v-for="post in list | limitBy limit">
                <!-- Blog Post -->
....
</div>
</template>


<!-- script -->    
<script>
        export default {
            props: ['list', 'limit'],


            created() {
                this.list = JSON.parse(this.list);
            }

        }
</script>

Ответ 2

Если вы хотите получить доступ к определенному родителю, вы можете назвать все компоненты следующим образом:

export default {
  name: 'LayoutDefault'

А затем добавьте некоторую функцию (например, vue.prototype или Mixin, если она нужна во всех ваших компонентах). Примерно так должно это сделать:

getParent(name){
      let p = this.$parent;
      while(typeof p !== 'undefined'){
        if(p.$options.name == name) {
          return p;
        }else {
          p = p.$parent;
        }
      }
      return false;
    }

и использование может быть таким:

this.getParent('LayoutDefault').myVariableOrMethod