其他分享
首页 > 其他分享> > div模拟textarea文本框,输入文字高度自适应,且实现字数统计和限制

div模拟textarea文本框,输入文字高度自适应,且实现字数统计和限制

作者:互联网

需求:

文本框可根据输入内容高度自适应,不带滚动条,高度可变的那种,我搜索了很多,发现textarea无法实现我的需求,scrollHeigh这个无法获取实际内容的高度(我用的是那种简单的,可能我写的哪里不对吧;那种代码很多的,我又不想那么去做,麻烦。。。),所以只能div模拟textarea文本框了。

使用div模拟textarea文本框,输入文字高度自适应,且实现字数统计和限制,输入字数超出65时,统计数字会变红,作为提示,当div失去焦点时,字数会剪切为最大限制字数65。

// 可实现div模仿文本框进行编辑
contenteditable="true"

其实,本来实时限制用户输入字数,也就是当用户输入字数达到65时,不允许再次输入,体验会更好。但是当我这样做时,div里的光标会跑到div的最前面,再次输入时导致后面字被剪切掉,我无法获取和定位光标,所以只能设置当blur,失去焦点时,再剪切字数(当然,光标的获取和定位应该可以实现,有需求的小伙伴,可以自己试试 ^_^)。

效果图:

               

HTML:

<div class="add-doss-retpl">
    <div>意向备注 
        <span class="c-gy">
            <span :class="addTotal > 65 ? 'hx-red' : ''" > {{addTotal}}</span>
            /65
        </span>
    </div>
    <div class="add-doss-foremark" id="add-doss-foremark" @input="addDossInput($event)" 
     @blur="addDossBlur($event)" contenteditable="true"></div>
</div>

CSS: 

 .add-doss-retpl{
    background-color: #fff;
    padding: 10px;
    .add-doss-foremark{
      width:100%;
      margin: 10px 0;
      border:#e1e1e1 solid 1px;
      padding: 10px 8px;
    }
    .hx-red{
      color:red;
    }
  }

 VUE.js:

<script>
  export default {
    data:function(){
      return {
        addInremark:'', // 意向备注
        addTotal:0, // 统计输入框里的字数
      }
    },

    activated:function () {
      this.addInremark = (JSON.parse(sessionStorage.getItem('customerComments')) || JSON.parse(sessionStorage.getItem('customerComments'))=='') ? JSON.parse(sessionStorage.getItem('customerComments')) : (this.$route.query.customerComments?this.$route.query.customerComments:'');
     // 输入框赋初始值
     document.getElementById('add-doss-foremark').innerHTML = this.addInremark;
      this.getAddTotal();  // 字数统计
    },

    watch:{
       // 监听意向备注(统计字数&&存储)
      'addInremark'(){
         this.getAddTotal();
         sessionStorage.setItem('customerComments', JSON.stringify(this.addInremark));
       },
    },

    beforeRouteEnter(to, from, next){
      if (from.name == "dossCustomer" || from.name == "clientDetail" ) {
         sessionStorage.removeItem('customerComments');    
      }
      next();
    },

    methods:{
      // 监听意向备注输入
      addDossInput(e){this.addInremark = e.target.innerHTML;},
    
      // 监听意向备注失去焦点
      addDossBlur(e){
        if(e.target.innerHTML.length > 65){
          this.addInremark = e.target.innerHTML.slice(0,65);
          let addRe = document.getElementById('add-doss-foremark');
          addRe.innerHTML = this.addInremark;
        }else {
          this.addInremark = e.target.innerHTML;
         }
      },
      // 字数统计
      getAddTotal(){
        this.addTotal = this.addInremark.length;
      }
    }
  }
</script>

      

 

标签:字数统计,textarea,innerHTML,文本框,addInremark,65,div,输入,customerComments
来源: https://blog.csdn.net/qq_33242126/article/details/90240184