Home  >  Article  >  Web Front-end  >  How to get dom elements in vue

How to get dom elements in vue

亚连
亚连Original
2018-06-14 17:47:314560browse

This article mainly introduces the precautions for vue to obtain dom elements and the content of vue to obtain dom elements. Friends in need can refer to it

mounted(){
    setTimeout(()=>{
     this.contentToggle();
    },1000)
  },

methods:{
   contentToggle(){
    console.log(this.$refs.bodyFont.offsetHeight);
   }
  }

If vue wants to obtain the height of dom elements, generally we all We can think of writing it in the mounted function, that is, getting it after the dom is loaded, but the result is not what we thought. We also thought of using a

this.$nextTick(()=>{
   
    //函数
})

to get it, but found that it is useless at all/. .

So a good way is to use a setTimeout timer. The time can be set to 0, but sometimes it takes effect and sometimes it does not take effect. It is safer to add a small time value, so that you can ensure that you get It must be after the dom is loaded. This principle applies to many value transfer problems in Vue. If you cannot get the passed value at the beginning, just use a setTimeout.

ps: VUE gets the DOM element content

Get the dom element through ref

On the vue official website, check the ref Explanation

ref is used to register reference information to an element or subcomponent. Reference information will be registered on the $refs object of the parent component. If used on a normal DOM element, the reference points to the DOM element; if used on a subcomponent, the reference points to the component instance

When v-for is used on an element or component, the reference information will be Array containing DOM nodes or component instances

For example, the effect I want to achieve now is to click on the li generated with v-for and get the value of the element.

First, I need to get the currently clicked li element, what we have to do is

1. Add a click event and ref attribute to the dom

<li class="sidebar-list" v-for="(item, index) in meunList" @click="setPageMenu(index)" ref="menuItem">
  <router-link class="sidebar-a" :to="{ path: item.listLink }" >{{item.listTitle}}</router-link>
</li>

2. Then use ref

setPageMenu(index) {
//这个是获取当前menuItem值,用index来区分当前元素是v-for 产生的数组中的第几个数
  let getMenuText = this.$refs.menuItem[index].innerText;
}

in the click event method. The above is me I compiled it for everyone, I hope it will be helpful to everyone in the future.

Related articles:

Using devtool in webpack to explain in detail

How to use implicit calls in javascript?

How to build a large single-page application with vue.js

How to implement WeChat sharing in the circle of friends and send friends in vue

Details on how to implement vuex (detailed tutorial)

Implement WeChat payment through vue.js

The above is the detailed content of How to get dom elements in vue. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn