vue this.$refs input 获取焦点

 

1.html




 

     
     
   
 

2.js

var Main = {
  data() {
    return {
      data: [{
        label: '一级 1',
        children: [{
          label: '二级 1-1',
          children: [{
            label: '三级 1-1-1'
          }]
        }]
      }, {
        label: '一级 2',
        children: [{
          label: '二级 2-1',
          children: [{
            label: '三级 2-1-1'
          }]
        }, {
          label: '二级 2-2',
          children: [{
            label: '三级 2-2-1'
          }]
        }]
      }, {
        label: '一级 3',
        children: [{
          label: '二级 3-1',
          children: [{
            label: '三级 3-1-1'
          }]
        }, {
          label: '二级 3-2',
          children: [{
            label: '三级 3-2-1'
          }]
        }]
      }],
      defaultProps: {
        children: 'children',
        label: 'label'
      }
    };
  },
  methods: {
    edit(node, data) {
      console.log(node)
      this.$set(node, 'isEdit', true)
      this.$nextTick(() => {
        this.$refs[`editLabelInput-${node.id}`].focus()
      })
    },
    editLabel(node, data) {
      this.$set(node, 'isEdit', false)
    }
  }
};
var Ctor = Vue.extend(Main)
new Ctor().$mount('#app')
 

你可能感兴趣的:(前端,#,VUE)