实现输入框换行

应产品要求,实现输入框换行功能,但是传统的input不支持换行操作,故而使用其他方式进行实现。

方式一:contenteditable属性的使用

使用一个div,<div contenteditable="true" id="t"></div>

但是存在问题是如果配合vue的双向绑定会报错

方式二:使用textarea进行模拟,监听内容变化,动态改变其高度

html:

<textarea  class="input-item textarea-item"   placeholder="请输入详细地址"  
      rows="1"  ref="address" 
  @focus="showClearBtn('AddressDetail')" 
  @blur="hideCleanBtn('AddressDetail')"   
  v-model="resObj.address_detail">
</textarea>

JS:

watch: {
    'resObj.address_detail': function (newVal) {
      this.getHeight(this.$refs.address)
    },
  },// 详细地址输入框高度
getHeight (el) {
this.timer = setTimeout(() => {
el.style.height = 'auto' // 必须设置为auto
el.style.height = (el.scrollHeight) + 'px'
}, 20)
},