vue 自动获取输入框的焦点(ref / 自定义指令)

9 篇文章 0 订阅

一、ref

1.给要操作的dom元素设置ref属性(属性值可以随便起)

<input type="text" ref="input">

2.在选项mounted获取要操作的dom元素this.$refs.ref属性值
(mounted :页面加载完成后自动调用)

var vm = new Vue({
	el:"#app",
	data:{
	},
	methods:{
	},
	mounted(){
		this.$refs.input.focus();
	}
	
}); 

二、自定义指令

1.全局自定义指令

// 注册一个全局自定义指令 `v-focus`
Vue.directive('focus', {
  // 当被绑定的元素插入到 DOM 中时……
  // 指使用 v-focus 的元素
  	inserted: function (el) {
    // 聚焦元素
    el.focus()
  }
})

1.如果想注册局部指令,组件中也接受一个 directives 的选项:

directives: {
  focus: {
    // 指令的定义
    inserted: function (el) {
      el.focus()
    }
  }
}

2.然后你可以在模板中任何元素上使用新的 v-focus property,如下:

<input v-focus>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Vue中创建一个自定义指令,让输入框获取焦点,你需要在Vue实例的directives属性中定义一个名为"focus"的指令,并在inserted方法中使用原生的focus()方法将焦点设置为当前元素。具体代码如下: ``` export default { directives: { focus: { inserted(el) { el.focus(); } } } } ``` 然后,在需要获取焦点输入框上使用v-focus指令即可。在App.vue的模板中,你可以将v-focus指令添加到<input type="text">元素上,如下所示: ``` <template> <div> <input type="text" v-focus> </div> </template> ``` 这样,当组件渲染完成后,该输入框自动获取焦点。请注意,这个自定义指令只在当前组件的作用域内有效。如果你希望在全局范围内使用这个指令,你需要在全局注册它。可以使用Vue.directive方法实现全局注册,如下所示: ``` Vue.directive("focus", { inserted(el) { el.focus(); } }); ``` 这样,无论在哪个组件中,你都可以在输入框上使用v-focus指令,以获取焦点。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Vue 自定义指令 自动获取焦点](https://blog.csdn.net/laoli360/article/details/120555899)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值