zoukankan      html  css  js  c++  java
  • div模拟文本输入框做字数限制 用substr限制 当字数达到后光标会回到开头 用range对象限制但是删除

    <div class="textarea textareaplace" id="userinfo" contenteditable="true" onkeydown="keyD(this);" onkeyup="keyAction(this);" oncopy="keyCop();" onpaste="keyPas()"></div>

    js代码
    var textbox = document.getElementById('userinfo'),
    g_selectNum=0,
    sel = window.getSelection(),
    range = document.createRange();


    function keyD(obj){   //按下事件
      var a=textbox.innerHTML;

      var textA=textbox.innerText.substr(0,20);
      range.selectNodeContents(textbox);  //将div节点内容加进range内
      range.collapse(false);
      sel.removeAllRanges();
      sel.addRange(range);     //j将range对象加入文本域
    }


    function keyPas(){
      var textA=textbox.innerText.substr(0,20);
      setTimeout(function(){
        var a=textbox.innerHTML;
        textbox.innerText=a.replace(/<span.*">|</span>/g, "");   //将复制内容中span标签替换
        range.selectNodeContents(textbox);
        range.collapse(false);
        sel.removeAllRanges();
        sel.addRange(range);
      },300)
    };


    function keyCop(obj){
      var textA=textbox.innerText.substr(0,20);
      a_num=textA.length;
      var selectCon=sel.toString();
      g_selectNum=selectCon.length;
    }


    function keyAction(obj) {
      var textA=textbox.innerText.substr(0,20);
      a_num=textA.length;
      a_arr[1]=a_num;
      textbox.innerText=textA;
      range.selectNodeContents(textbox);
      range.collapse(false);
      sel.removeAllRanges();
      sel.addRange(range);
    }

  • 相关阅读:
    bzoj2733 永无乡 平衡树按秩合并
    bzoj2752 高速公路 线段树
    bzoj1052 覆盖问题 二分答案 dfs
    bzoj1584 打扫卫生 dp
    bzoj1854 游戏 二分图
    bzoj3316 JC loves Mkk 二分答案 单调队列
    bzoj3643 Phi的反函数 数学 搜索
    有一种恐怖,叫大爆搜
    BZOJ3566 概率充电器 概率dp
    一些奇奇怪怪的过题思路
  • 原文地址:https://www.cnblogs.com/BluceLee/p/12100034.html
Copyright © 2011-2022 走看看