Создайте экземпляр Vue с внутренним html - PullRequest
0 голосов
/ 08 июля 2020

Как я могу инициализировать новый экземпляр Vue, подключить его к существующему элементу dom и использовать html этого элемента в качестве содержимого компонента (или приложения)?

Вот пример проекта https://codesandbox.io/s/white-darkness-f3v80

<div id="app">
   <p>This is slot text from index.html</p>
   <template slot="foo">Also should be parsed as named slot</template>
</div>

Элемент div # app (index. html) может содержать слот по умолчанию или другие типы слотов (с областью действия c). И приложение vue должно проанализировать это html в соответствующие слоты.

1 Ответ

1 голос
/ 08 июля 2020

Попробуйте что-то вроде этого:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  </head>
  <body>
    <div id="app">
      <div>
        <any-component>
          <p>This is slot text from index.html</p>
          <template v-slot:foo>
            Also should be parsed as named slot
          </template>
        </any-component>
      </div>
    </div>
    <script>
      Vue.component('any-component', {
        template: `
          <div>
            <slot name="default"></slot>
            <slot name="foo"></slot>
          </div>`,
      });

      new Vue({
        el: '#app',
        data() {
          return {};
        },
      });
    </script>
  </body>
</html>

Вы его ищете?

...