Vue:Vue中操作DOM方法

作者: Mr_Treasure | 来源:发表于2017-01-11 21:23 被阅读8428次

jQuery的杰出的DOM操作能力相信已经深入每一个前端Coder,在使用Vue之前我并不能习惯数据驱动的概念,仍然幻想着把jQuery引入到Vue中,直到深入使用Vue以后才发现,原来许多jQ操作DOM的方法都不需要,数据驱动比手工操作DOM方便快捷许多。尽管如此,Vue仍然给了我们原生DOM控制的能力。

环境是由Vue-Cli搭建的webpack模板,省略CSS部分

HTML部分

<div id="app">
    <div class="box-wrapper" >
      <div class="box" ref="box1"></div>
      <div class="box" ref="box2"></div>
      <div class="box" ref="box3"></div>
      <div class="box" ref="box4"></div>
      <div class="control">
        <button @click="changeBlack">变黑色</button>
        <button @click="changeBlue">变蓝色</button>
      </div>
    </div>

  </div>

我们在html中建立了四个盒子,并且用ref属性标注,这个就是我们查找DOM元素的钩子。
Vue1.x中使用v-el标记DOM元素,v-ref标记组件元素,2.0以后统一使用ref标记

JavaScript部分

export default {
  name: 'app',
  components: {
    Hello
  },
  methods:{
    changeBlack(){
      console.log(this.$refs.box1);
      this.$refs.box1.style.background="black";
    },
    changeBlue(){
      this.$refs.box1.style.background="skyblue";
    }
  }
}

我们用两个button绑定了两个事件,分别是从DOM的角度去操作盒子变黑色,变蓝色。使用this.$refs.box1去取得我们的DOM元素,并且在控制台打印出了元素

打印出的元素
可见,这个就是我们常见的DOM对象,注意在1.X中分别使用$els$refs获取DOM对象和组件的集合,2.0以后统一使用$refs

2.x中的坑

我们知道HTML中是不区分大小写的,因此在JS中使用的驼峰命名法,在HTML中应该改为短横线命名法。比如
boxAlpha=>box-alpha
但是,使用ref标注的钩子不能使用短横线命名法,boxAlpha不等于box-alpha,在JS中用box-alpha也会报非法。所以,
ref属性统一使用驼峰命名法
ref属性统一使用驼峰命名法
ref属性统一使用驼峰命名法

小结

在我们获取到对象以后,便能便捷的使用getElmentByXXX方法,也能通过原生方法去修改,获得DOM对象属性,这样jQ是不是就显得不再必要了呢?
但是Vue并不推荐使用手动操作DOM对象,获取DOM对象也最好用于获取对象的属性,如clientHeight等,当你真正领会数据驱动的时候,你就会发现你看到了一片新的天地。
就是这样:)

相关文章

网友评论

  • LikeDebug:你好,我是初学vue,想请教一下如何在vue里使用canvas呢?是获取canvas的dom然后调用方法吗?
    Mr_Treasure:@daybreakcold $ref 有限制,必须是组件内部的 DOM(或者父子级),原生方法没有这个限制
    daybreakcold:@Mr_Treasure 直接操作dom 和 $ref哪个更推荐呢
    Mr_Treasure:mounted钩子里获取到了DOM以后进行操作, 你可以先把canvas操作封装为一个库,然后mounted里面使用

本文标题:Vue:Vue中操作DOM方法

本文链接:https://www.haomeiwen.com/subject/mbbrbttx.html