1

I have the following HTML VueJS code sample:

<div v-for="site in topSites" ref="ts"><a :href="site.url">
   ...
</div>

Update:

the full div code:

<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')
  }
  

})

I have tried to checkout the output of console.log(this.$refs) in both mounted and created hooks:

mounted: function() {
    console.log(this.$refs);
 }

Unfortunately, the log output is very strange, it returns Object { } but it is expandable to be looked like:

{}
​
ts: Array(16) [ div.col.text-center.topSites.resBoo, div.col.text-center.topSites.resBoo, div.col.text-center.topSites.resBoo
, … ]
​
<prototype>: Object { … }

enter image description here

I don't know, why do this happen and how to fix it?

15
  • This is absolutely correct. The $refs is an object contains all components with a ref attribute where a key in this object will be a value that is indicated in a ref and a value will be a component or an array of components (in case of v-for) itself/themselves. Commented Apr 12, 2020 at 20:57
  • @Anatoly Both this.$refs.ts and this.$refs['ts'] return undefined! Commented Apr 12, 2020 at 21:08
  • You should look at this.$refs in the mounted hook or later. Commented Apr 12, 2020 at 21:11
  • I have the two hooks in the same Vue object and I'm trying this.$refs.ts in both of them but they are undefined too. Commented Apr 12, 2020 at 21:15
  • If topSites is a prop that is passed from outside of this component in is populated asynchronously then you cannot look this.$refs.ts in the mounted hook it's too early. Commented Apr 12, 2020 at 21:19

1 Answer 1

4

According to the official docs :

When ref is used together with v-for, the ref you get will be an array containing the child components mirroring the data source.

Also in official docs they say $refs are only populated after the component has been rendered, so they cannot be accessed in the created hook since the DOM has not be rendered yet, you could access them in mounted hook.

Sign up to request clarification or add additional context in comments.

3 Comments

Both this.$refs.ts and this.$refs['ts'] return undefined!
you're getting this in the created hook?
in official docs they say $refs are only populated after the component has been rendered, so they cannot be accessed in the created hook since the DOM has not rendered yet, you could access them in mounted hook

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.