一、使用$ref特性获取DOM元素

  代码示例如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app"></div>
<script type="text/javascript" src="./vue.js"></script>
<script type="text/javascript">
// 全域组件
Vue.component('subComp',{
template:`<div></div>`
}); var App={ // 局部组件创建
template:`<div>
<subComp ref="subc"></subComp>
<button ref="btn">我是按钮</button>
<p ref="sb">alex</p>
</div>`,
beforeCreate(){ // 在当前组件创建之前调用
console.log(this.$refs.btn); // 输出:undefined
},
created(){ // 在当前组件创建之后调用
console.log(this.$refs.btn); // 输出:undefined,此时this对象已经有refs属性,但是DOM还没有渲染进App组件中
},
beforeMount(){ // 装载数据到DOM之前会调用
console.log(this.$refs.btn); // 输出:undefined
},
mounted(){ // 装载数据到DOM之后会调用
console.log(this); // this是一个对象,包含refs属性$refs: {btn: button, sb: p}
console.log(this.$refs.btn); // <button>我是按钮</button>
// 如果是给组件绑定的ref=""属性那么this.$refs.subc取到的是组件对象
console.log(this.$refs.subc); var op = this.$refs.sb;
this.$refs.btn.onclick = function () {
console.log(op.innerHTML); // 点击按钮控制台输出:alex
}
},
}; new Vue({
el:'#app',
data(){
return{ }
},
template:`<App/>`,
components:{
App
}
}) </script>
</body>
</html>

1、ref特性为子组件赋予ID引用

  尽管存在 prop 和事件,有的时候你仍可能需要在 JavaScript 里直接访问一个子组件。

  为了达到这个目的,你可以通过 ref 特性为这个子组件赋予一个 ID 引用,如下所示:

<button ref="btn">我是按钮</button>
<p ref="sb">alex</p>

2、通过this.$refs.btn访问 <button> 实例

  ref 被用来给元素或子组件注册引用信息。引用信息将会注册在父组件的 $refs 对象上。如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例。

  beforeCreate在当前组件创建之前调用,此时输出肯定为undefined。但是后面created方法是在组件创建之后调用,此时打印this可以发现里面也已经有了refss属性,但是这个时候DOM还没有渲染进App组件中,这里涉及到了一个虚拟DOM的概念。直到mounted方法,装载数据到DOM之后才会正常显示出this.$refs.btn内容。

mounted(){   // 装载数据到DOM之后会调用
console.log(this); // this是一个对象,包含refs属性$refs: {btn: button, sb: p}
console.log(this.$refs.btn); // <button>我是按钮</button>

3、给组件绑定的ref属性

// 全域组件
Vue.component('subComp',{
template:`<div></div>`
}); var App={ // 局部组件创建
template:`<div>
<subComp ref="subc"></subComp>
<button ref="btn">我是按钮</button>
<p ref="sb">alex</p>
</div>`,
// 省略代码
mounted(){ // 装载数据到DOM之后会调用
console.log(this); // this是一个对象,包含refs属性$refs: {btn: button, sb: p}
console.log(this.$refs.btn); // <button>我是按钮</button> // 如果是给组件绑定的ref属性那么this.$refs.subc取到的是组件对象
console.log(this.$refs.subc); var op = this.$refs.sb;
this.$refs.btn.onclick = function () {
console.log(op.innerHTML); // 点击按钮控制台输出:alex
}
},
};

  如果是给组件绑定的ref属性,那么this.$refs.subc取到的是组件对象。

4、输出效果  

  

二、常用$属性

$refs:获取组件内的元素

$parent:获取当前组件的父组件

$children:获取当前组件的子组件

$root:获取New Vue的实例化对象

$el:获取组件对象的DOM元素

三、获取更新之后的DOM添加事件的特殊情况

1、DOM更新策略

  vue实现响应式并不是数据发生变化后DOM立刻发生变化,而是按照一定的策略进行DOM的更新。

(1)配置v-if数据属性显示focus(焦点)

  在页面上制作一个input输入框,在页面加载时就让该输入框获取焦点

<body>
<div id="app"></div>
<script type="text/javascript" src="./vue.js"></script>
<script type="text/javascript"> var App={ // 局部组件创建
data(){
return{
isShow:true
}
},
template:`<div>
<input type="text" v-if="isShow" ref="fos"/>
</div>`,
mounted(){ // 装载数据到DOM之后会调用
// focus()方法用于给予该元素焦点
this.$refs.fos.focus();
}
}; new Vue({
el:'#app',
data(){
return{ }
},
template:`<App/>`,
components:{
App
}
})
</script>
</body>

  页面加载时就让该输入框获取焦点,显示效果如下:

  

(2)修改v-if数据属性看DOM是否发生变化

<body>
<div id="app"></div>
<script type="text/javascript" src="./vue.js"></script>
<script type="text/javascript"> var App={ // 局部组件创建
data(){
return{
isShow:false
}
},
template:`<div>
<input type="text" v-if="isShow" ref="fos"/>
</div>`,
mounted(){ // 装载数据到DOM之后会调用
// vue实现响应式并不是数据发生变化后DOM立刻发生变化,而是按照一定的策略进行DOM的更新。 // $nextTick是在下次DOM更新循环结束之后执行的延迟回调,在修改数据之后使用这个方法则可以在回调中获取更新之后的DOM this.isShow = true;
console.log(this.$refs.fos); // 输出undefined
// focus()
this.$refs.fos.focus(); // focus() 方法用于给予该元素焦点。 }
}; new Vue({
el:'#app',
data(){
return{ }
},
template:`<App/>`,
components:{
App
}
}) </script>
</body>

  显示效果如下:

  

2、$nextTick方法

  $nextTick是在下次DOM更新循环结束之后执行的延迟回调,在修改数据之后使用这个方法则可以在回调中获取更新之后的DOM。

<body>
<div id="app"></div>
<script type="text/javascript" src="./vue.js"></script>
<script type="text/javascript"> var App={ // 局部组件创建
data(){
return{
isShow:false
}
},
template:`<div>
<input type="text" v-if="isShow" ref="fos"/>
</div>`,
mounted(){ // 装载数据到DOM之后会调用
// vue实现响应式并不是数据发生变化后DOM立刻发生变化,而是按照一定的策略进行DOM的更新。 // $nextTick:
// 是在下次DOM更新循环结束之后执行的延迟回调,在修改数据之后使用这个方法则可以在回调中获取更新之后的DOM this.isShow = true;
console.log(this.$refs.fos); // 输出undefined
// focus()
// this.$refs.fos.focus(); // focus() 方法用于给予该元素焦点。
this.$nextTick(function () {
// 回调函数中获取更新之后真实的DOM
this.$refs.fos.focus();
})
}
}; new Vue({
el:'#app',
data(){
return{ }
},
template:`<App/>`,
components:{
App
}
}) </script>
</body>

  显示效果如下所示:

  

vue的一些特殊特性的更多相关文章

  1. vue 3.0 体验,vue 3.0新特性

    前言 昨天不是尤雨溪 不是刚在B站 直播玩了,分享了vue-next v3.0.0-beta.1 版本 哈哈, 不要太刺激哦 6大亮点 Performance:性能更比Vue 2.0强. Tree s ...

  2. 详解vue组件的is特性:限制元素&动态组件

    在vue.js组件教程的一开始提及到了is特性 意思就是有些元素,比如 ul 里面只能直接包含 li元素,像这样: <ul> <li></li> </ul&g ...

  3. vue总结 01基础特性

    最近有时间来总结一下vue的知识: 一.vue.js 被定义成一个开发web界面的前端库,是一个非常轻量的工具.vue.js本身具有响应式和组件化的特点. 我们不需要在维护视图和数据的统一上花费大量的 ...

  4. vue组件的is特性

    组件功能是vue项目的一大特色.组件可以扩展html元素,可以封装可重用的代码,可以增加开发效率.它是自定义元素,vue.js的编译器为它添加特殊功能.有些情况,组件也可以是原生HTML元素的形式,以 ...

  5. vue中的重要特性

    一.vue中的自定义组件 html的代码: <!DOCTYPE html> <html lang="en"> <head> <meta c ...

  6. vue.js用法和特性详解

      前  言 最近用Vue.js做了一个数据查询平台,还做了一个拼图游戏,突然深深的感到了vue的强大. Vue.js是一套构建用户界面(user interface)的渐进式框架.与其他重量级框架不 ...

  7. vue 组件属性props,特性驼峰命名,连接线使用

    网址:https://www.cnblogs.com/alasq/p/6363160.html 总结如下:vue的组件的props属性支持驼峰命名,不支持连接线命名,使用是用连接线进行赋值或者数据绑定 ...

  8. vue 3.0新特性

    参考:  https://www.cnblogs.com/Highdoudou/p/9993870.html https://www.cnblogs.com/ljx20180807/p/9987822 ...

  9. VUE学习,is 特性,转载来源:https://segmentfault.com/q/1010000007205176/

随机推荐

  1. luogu3703 [SDOI2017]树点涂色(线段树+树链剖分+动态树)

    link 你谷的第一篇题解没用写LCT,然后没观察懂,但是自己YY了一种不用LCT的做法 我们考虑对于每个点,维护一个fa,代表以1为根时候这个点的父亲 再维护一个bel,由于一个颜色相同的段一定是一 ...

  2. Ntrip协议使用流程及服务器实现架构

    Ntrip协议 在RTK接收机中,有多种方式获取到差分数据:电台.挂外串口.网络等.其中网络方式适合在有网络基准站的地区,省掉携带多一台RTK接收机来完成工作. CORS是网络基准站,通过网络收发GP ...

  3. elementtaryos root密码更改

    在elementtaryos 终端中使用root 账户但不幸忘记密码怎么办?请进行如下操作...... 1.进入高级选项选中recovery mode 2.按e编辑,找到recovery nomode ...

  4. 洛谷 P4859 && BZOJ3622: 已经没有什么好害怕的了

    题目描述 给出 \(n\) 个数 \(a_i\)​ ,以及 \(n\) 个数 \(b_i\)​ ,要求两两配对使得 \(a>b\) 的对数减去 \(a<b\) 的对数等于 \(k\) . ...

  5. 深入理解promise

    如今promise大行其道,关于异步方面的几乎都有它的影子,新的fetch api返回的是promise对象,generator中的yield后面一般也会跟promise对象,async的await后 ...

  6. hbuilder设置自动px 转换成rem

    hbuilder里面有自动换算的 需要设置一下:工具–>选项–>Hbuilder–>代码助手设置.里面有个px自动转rem设置,按自己的实际情况设置就可以在每次输入px的时候有提示了 ...

  7. [转] docker save与docker export的区别

    [From]http://cnodejs.org/topic/59a2304f7aeedce818249eeb 很久没有写博客了,坟头草都长了老高了.写博客要靠惯性,一旦停下来时间长了,就很难再坚持下 ...

  8. 有用的 Angular CLI 命令参数

    这是一些有用的 Angular 5 CLI 命令参数,注意参数前面的-和--的不同... 1. 指定build的输出为production version,合并优化css and js files. ...

  9. jackson工具类有动态属性过虑功能

    在业务应用中经常会有指定属性序列化json的需求,C#中这个功能很容易就可以解决:使用lambda重新构造一下匿名对象就可以了.一行代码搞定.java是这样解决的. public JsonMapper ...

  10. mysql 显示树结构表的节点全路径

    SELECT TYPEID AS TYPEID, pTYPEID AS 父TYPEID, levels AS 父到子之间级数, concat(paths, ',', TYPEID) AS 父到子路径, ...