@ufffff

Вопрос: window.Event = new Vue() это только название или нечто большее?

Недавно начала изучение Vue и в обучающем видео увидела то, что меня смутило: "window.Event = new Vue()". Пожалуйста, помогите понять:
1) что представляет собой window.Event,
2) для чего создаётся новый корневой элемент, почему у него нет el
3) для чего нужно прослушивание? В данном случае для обеспечения взаимодействия между родительским и дочерним компонентами? Почему прослушивание в родительском компоненте?
Далее представлен код.
<!DOCTYPE html>
<head>
  <title></title>
  <link rel='stylesheet' href = "https://cdnjs.cloudflare.com/ajax/libs/bulma/0.2.3/css/bulma.css">
  <style type="text/css"> body { padding-top: 40px; }
  </style>
</head>

<body>
  <div id="root" class = 'container'>
    <coupon @applied="onCouponApplied"></coupon>
    <h1 v-if="couponApplied">You used a coupon!</h1>
  </div>
  <script src ="https://unpkg.com/vue@2.6.11/dist/vue.js"></script>
  <script>
  window.Event = new Vue();

  Vue.component('coupon', {
    template: `
    <input placeholder = "Enter your coupon code." @blur="onCouponApplied">
    `,

    methods: {
      onCouponApplied() {
        this.$emit('applied');
      }
    }
  });

  new Vue({
    el: '#root',

    data: {
      couponApplied: false
    },

  created() {
    Event.$on('applied', () => alert('Handling it!'));
  }
  });
  </script>
  </body>
  </html>
  • Вопрос задан
  • 59 просмотров
Решения вопроса 1
Aetae
@Aetae Куратор тега JavaScript
Тлен
С точки зрения функционала - это просто глобальная переменная, в которую положили пустой экземпляр Vue, чтобы использовать встроенную в Vue возможность создавать и обрабатывать события, получая таким образом глобальную шину данных, которую можно задействовать для обмена событиями между несколькими компонентами.

С точки зрения же выбора имени Event для глобально переменной - это провал и некомпетентность, потому что в window.Event лежит у нас собственно класс-родитель для всех javascript событий, который может использоваться сторонними библиотеками.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 19:51
15000 руб./за проект
22 нояб. 2024, в 19:15
200000 руб./за проект
22 нояб. 2024, в 18:50
30000 руб./за проект