前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue:Vue中操作DOM方法

Vue:Vue中操作DOM方法

作者头像
MrTreasure
发布2018-05-10 11:05:54
3.3K0
发布2018-05-10 11:05:54
举报
文章被收录于专栏:不止是前端

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

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

HTML部分

代码语言:javascript
复制
<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部分

代码语言: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等,当你真正领会数据驱动的时候,你就会发现你看到了一片新的天地。 就是这样:)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.01.11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • HTML部分
  • JavaScript部分
  • 2.x中的坑
  • 小结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档