html文件的ref,Vue.js中ref ($refs)用法举例总结及应注意的坑
一、根据官方文档总结的用法:看Vue.js文档中的ref部分,自己总结了下ref的使用方法以便后面查阅。1、ref使用在外面的组件上HTML 部分ref在外面的组件上js部分var refoutsidecomponentTem={template:"我是子组件"};varrefoutsidecomponent=new Vue({el:"#ref-outside-component",compo..
一、根据官方文档总结的用法:
看Vue.js文档中的ref部分,自己总结了下ref的使用方法以便后面查阅。
1、ref使用在外面的组件上
HTML 部分
ref在外面的组件上
js部分
var refoutsidecomponentTem={
template:"
我是子组件
};
var refoutsidecomponent=new Vue({
el:"#ref-outside-component",
components:{
"component-father":refoutsidecomponentTem
},
methods:{
consoleRef:function () {
console.log(this); // #ref-outside-component vue实例
console.log(this.$refs.outsideComponentRef); // div.childComp vue实例
}
}
});
2、ref使用在外面的元素上
HTML部分
ref在外面的元素上
JS部分
var refoutsidedomTem={
template:"
我是子组件
};
var refoutsidedom=new Vue({
el:"#ref-outside-dom",
components:{
"component-father":refoutsidedomTem
},
methods:{
consoleRef:function () {
console.log(this); // #ref-outside-dom vue实例
console.log(this.$refs.outsideDomRef); //
ref在外面的元素上
}
}
});
3、ref使用在里面的元素上---局部注册组件
HTML部分
ref在里面的元素上
JS部分
var refinsidedomTem={
template:"
"
我是子组件
" +"
methods:{
consoleRef:function () {
console.log(this); // div.childComp vue实例
console.log(this.$refs.insideDomRef); //
我是子组件
}
}
};
var refinsidedom=new Vue({
el:"#ref-inside-dom",
components:{
"component-father":refinsidedomTem
}
});
4、ref使用在里面的元素上---全局注册组件
HTML部分
JS部分
Vue.component("ref-inside-dom-quanjv",{
template:"
"" +
"
ref在里面的元素上--全局注册
" +"
methods:{
showinsideDomRef:function () {
console.log(this); //这里的this其实还是div.insideFather
console.log(this.$refs.insideDomRefAll); //
}
}
});
var refinsidedomall=new Vue({
el:"#ref-inside-dom-all"
});
二、应注意的坑
1、如果通过v-for 遍历想加不同的ref时记得加 :号,即 :ref =某变量 ;
这点和其他属性一样,如果是固定值就不需要加 :号,如果是变量记得加 :号
image.png
2、通过 :ref =某变量 添加ref(即加了:号) ,如果想获取该ref时需要加 [0],如this.$refs[refsArrayItem] [0];如果不是:ref =某变量的方式而是 ref =某字符串时则不需要加,如this.$refs[refsArrayItem]
加和不加[0]的区别--未展开
加和不加[0]的区别--展开了
3、想在element ui 对话框打开后取dom时,应该使用$nextTick,而不是直接使用this.$refs. imgLocal2:
console.log('this.$refs.imgLocal2外面', this.$refs.imgLocal2);
setTimeout(() => {
console.log('this.$refs.imgLocal2 setTimeout', this.$refs.imgLocal2);
}, 500); // 不推荐
this.$nextTick(() => {
console.log('this.$refs.imgLocal2 $nextTick', this.$refs.imgLocal2);
});
结果
**本文版权归本人即简书笔名:该账户已被查封 所有,如需转载请注明出处。谢谢! *
更多推荐
所有评论(0)