0

我有一个简单的 VueJS 应用程序,它循环以下 DOM 示例:

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

所以它生成divs与类重复.topSites

使用 vanilla JS,我无法访问 VueJS 生成的 DOM。例如:

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

它确实有效,即该querySelectorAll方法找不到元素。但是,从浏览器的控制台运行上面的示例可以正常工作。

在声明了 Vue 对象之后,我试图放置上面的代码。IE:

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

有什么方法可以从 Vue 外部访问 Vue 生成的 DOM?

4

1 回答 1

1

您应该在mountedupdated生命周期挂钩中执行 DOM 自定义操作:

<!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>
于 2020-04-12T12:10:10.810 回答