VueJS DOM недоступен с JavaScript - PullRequest
0 голосов
/ 12 апреля 2020

У меня есть простое приложение VueJS, которое зацикливает следующий пример DOM:

<div v-for="site in topSites" class="col text-center topSites resBoo">...

Таким образом, оно генерирует повторные divs с классом .topSites.

Использование vanilla JS, я не смог получить доступ к сгенерированному DOM VueJS. Например:

document.body.querySelectorAll('.topSites').forEach(i => {i.style.background = 'blue'; console.log('aa',i)}) 

Это работает, то есть метод querySelectorAll не находит элементы. Однако, запуск приведенного выше примера из консоли браузера работает нормально.

Я попытался разместить приведенный выше код после объявления объекта Vue. то есть:

var app = new Vue({
  el: '#app',
  data: {...}
})  

Есть ли способ получить доступ к DOM, сгенерированному Vue извне Vue?

1 Ответ

0 голосов
/ 12 апреля 2020

Вы должны выполнять свои пользовательские операции DOM в mounted или updated хуках жизненного цикла:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.6.11/vue.common.dev.js"></script>
<body>
    <div id="app">
        <div v-for="site in topSites" class="col text-center topSites resBoo">{{site}}</div>
    </div>
</body>
<script>
    new Vue({
        el: "#app",
        data: {
            topSites: ["site 1", "site 2"],
        },
        mounted: function () {
            const elems = document.body.querySelectorAll('.topSites');
            elems.forEach(i => {i.style.background = 'blue'; console.log('aa',i)});
        }
    })    
</script>
</html>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...