У меня есть следующий HTML VueJS пример кода:
<div v-for="site in topSites" ref="ts"><a :href="site.url">
...
</div>
Обновление:
полный код div:
<div v-for="site in topSites" class="col text-center topSites resBoo" ref="ts"><a :href="site.url"><img :src="site.favicon ? site.favicon : app.noFavicon" :alt="site.title" />
<br>
<span>{{site.title ? site.title : site.url | trim(16)}}</span>
</a>
</div>
JS
function getTopSites(ops){
var gettingTopSites = browser.topSites.get({ includeFavicon: true, newtab: true, limit: Number(ops.maxTopSitesNum) });
gettingTopSites.then((ops) => {
app.topSites = ops;
})
}
function getOptions(opsKeys){
var gettingItems = browser.storage.sync.get(Object.keys(defOptions));
gettingItems.then((res) => {
stylerOut(res)
gSearchEngines(res)
getTopSites(res)
});
}
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!',
topSites: [],
noFavicon: '',
searchEngines: [],
selectedSearch: undefined,
searchQuery: undefined,
defaultSearch: undefined,
recentBookmarks: undefined,
recentVisited: undefined
},
methods: {
doSearch(event) {
var id = null;
browser.tabs.getCurrent().then((res) => {
id = res.id;
browser.search.search({
query: this.searchQuery,
engine: this.selectedSearch,
tabId: id
});
})
}
},
/* created: function(){
//this.$refs.ts.forEach(el => el.style.backgroundColor='blue')
getOptions(Object.keys(defOptions));
//console.log(this.$refs)//['topSites'].forEach(el => el.style.backgroundColor = '#fc00fc')
//stylerIn('',this)
console.log(this.$refs['ts'])
},*/
mounted: function() {
getOptions(Object.keys(defOptions));
console.log(this.$refs['ts'],'jjj')
}
})
Я попытался проверить вывод console.log(this.$refs)
в обоих mounted
и created
хуках:
mounted: function() {
console.log(this.$refs);
}
К сожалению, вывод журнала очень странный, это возвращает Object { }
, но его можно расширять, чтобы он выглядел как:
{}
ts: Array(16) [ div.col.text-center.topSites.resBoo, div.col.text-center.topSites.resBoo, div.col.text-center.topSites.resBoo
, … ]
<prototype>: Object { … }
Я не знаю, почему это происходит и как это исправить?