How to use JQuery InsertAtCaret Function

后端 未结 1 857
攒了一身酷
攒了一身酷 2021-02-10 04:13

I have found JQuery InsertAtCaret Function Here But there is no detail given how to use it. I have tried a lot to understand that how it can be used, but could not find any way.

相关标签:
1条回答
  • 2021-02-10 05:06

    Here is modified version of above plugin:

    jQuery.fn.extend({
    insertAtCaret: function(myValue){
      return this.each(function(i) {
        if (document.selection) {
          //For browsers like Internet Explorer
          this.focus();
          sel = document.selection.createRange();
          sel.text = myValue;
          this.focus();
        }
        else if (this.selectionStart || this.selectionStart == '0') {
          //For browsers like Firefox and Webkit based
          var startPos = this.selectionStart;
          var endPos = this.selectionEnd;
          var scrollTop = this.scrollTop;
          this.value = this.value.substring(0, startPos)+myValue+this.value.substring(endPos,this.value.length);
          this.focus();
          this.selectionStart = startPos + myValue.length;
          this.selectionEnd = startPos + myValue.length;
          this.scrollTop = scrollTop;
        } else {
          this.value += myValue;
          this.focus();
        }
      })
    }
    });
    

    Basically, this plugin allows you to insert a piece of text at caret of multiple textbox or textarea . You can use it like this:

     $('#element1, #element2, #element3, .class-of-elements').insertAtCaret('text');
    

    Working Demo

    0 讨论(0)
提交回复
热议问题