经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
element-ui vue input输入框自动获取焦点聚焦方式
来源:jb51  时间:2023/4/19 9:00:57  对本文有异议

element-ui vue input输入框自动获取焦点聚焦

在这里插入图片描述

有时候会遇到要输入框自动获取焦点的情况,解决如下: 

方法一

步骤:

1.在script中写directives,注册一个全局的自定义指定 v-focus

  1. directives: {
  2. focus: {
  3. inserted: function(el) {
  4. el.querySelector("input").focus();
  5. }
  6. }
  7. },

2.在input框直接使用

  1. <el-input
  2. ...
  3. v-focus
  4. >
  5. </el-input>

方法二

步骤:

1.给输入框设置一个ref

  1. <el-input
  2. ref="saveTagInput"
  3. >

2.在需要的时候操作ref获取焦点

  1. this.$refs.saveTagInput.focus();

vue输入框自动获取焦点的三种方式

方式一:原生JS操作DOM

  1. <template>
  2. ? <div class="focusDemo">
  3. ? ? <input type="text" v-model="username" id='inputId'/>
  4. ? </div>
  5. </template>
  6. <script>
  7. export default {
  8. ? data () {
  9. ? ? return {
  10. ? ? ? username: ''
  11. ? ? }
  12. ? },
  13. ? mounted () {
  14. ? ? document.getElementById('inputId').focus()
  15. ? }
  16. }
  17. </script>

方式二:ref方式实现

  1. <template>
  2. ? <div class="focusDemo">
  3. ? ? <input ref="inputName" type="text" v-model="username" />
  4. ? </div>
  5. </template>
  6. <script>
  7. export default {
  8. ? data () {
  9. ? ? return {
  10. ? ? ? username: ''
  11. ? ? }
  12. ? },
  13. ? mounted () {
  14. ? ? this.$nextTick(() => {
  15. ? ? ? this.$refs.inputName.focus()
  16. ? ? })
  17. ? }
  18. }
  19. </script>

方式三:使用自定义指令

main.js中

  1. // 注册一个全局自定义指令 `v-focus`
  2. Vue.directive('focus', {
  3. ? // 当被绑定的元素插入到 DOM 中时
  4. ? inserted: function (el) {
  5. ? ? // 聚焦元素
  6. ? ? el.focus()
  7. ? },
  8. ? update: function (el) {
  9. ? ? // 聚焦元素
  10. ? ? el.focus()
  11. ? }
  12. })

vue文件中

  1. <template>
  2. ? <div class="focusDemo">
  3. ? ? <input type="text" v-model="username" v-focus />
  4. ? </div>
  5. </template>
  6. <script>
  7. export default {
  8. ? data () {
  9. ? ? return {
  10. ? ? ? username: ''
  11. ? ? }
  12. ? }
  13. }
  14. </script>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号