Вью-3. Установите модель данных компонента с неизвестной структурой, используя опцию API

Мой дочерний компонент должен быть создан с моделью данных, которую я получаю извне, используя выборку. Структура этой модели не предопределена (своего рода черный ящик). Важно то, что я работаю с подробным представлением какой-то сущности, а не со списком (массивом). У меня есть несколько вариантов, как это сделать, но мне не нравится ни один. Может быть, есть лучшее решение.

  1. Используйте свойство $data. А вот vue документация не нравится:

Добавление новых свойств к this.$data возможно, но не рекомендуемые

<script>
    export default {
        data() {
            return {
                showDialog: false   // some predefined prop
            };
        },
        methods: {
            async fetch() {
                // fetch from external resource
            }
        },
        async created() {
            let model = await this.fetch();
            Object.assign(this.$data, model);
        }
    };
</script>
<template>
    <p>{{ Name }}</p> <!-- Name is part of model -->
</template>
  1. Установите свойство model заранее. Этот подход скрывает все содержимое модели. Так что в этом случае я должен использовать this.model.Name вместо this.Name ..

Например:

<script>
    export default {
        data() {
            return {
                model: {},
                showDialog: false
            };
        },
        methods: {
            async fetch() {
                // fetch from external resource
            }
        },
        async created() {
            let model = await this.fetch();
            Object.assign(this.$data.model, model);
        }
    };
</script>
<template>
    <p>{{ model.Name }}</p>
</template>

3. Родительский компонент предоставляет модель дочернему элементу с помощью props. Но я думаю, что лучше, когда ребенок отвечает за получение модели и, как следствие, держит всю логику внутри.

<script>
    export default {
        props: ['initialModel'],
        data() {
            let data = {
                showDialog: false
            };
            return Object.assign(data, this.initialModel);
        }
    };
</script>
<template>
    <p>{{ Name }}</p>  <!-- Name is part of model -->
</template>
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
50
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Если вы спрашиваете, какое решение лучше, я бы рекомендовал использовать ваш второй вариант, когда вы связываете все настраиваемые свойства с моделями или любым другим соглашением об именах, которое у вас есть. Таким образом, становится более явным, какие свойства являются динамическими, и вы можете хранить и получать доступ ко всем из них в одном свойстве, когда вы работаете с ними.

data() {
    return {
        models: {},
    }
},
async created() {
    this.models = await this.fetchData()
},

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

const { property1, property2 } = this.models

Спасибо за ответ. Никаких других решений мне в голову не приходит. Так что, возможно, я выберу второй вариант.

Martin 16.04.2023 18:09

Другие вопросы по теме