Socket
Socket
Sign inDemoInstall

jquery-textrange

Package Overview
Dependencies
1
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    jquery-textrange

A jQuery plugin for getting, setting and replacing the selected text in input fields and textareas.


Version published
Weekly downloads
663
decreased by-16.29%
Maintainers
1
Install size
1.27 MB
Created
Weekly downloads
 

Readme

Source

This jQuery plugin is for easily finding the starting and ending positions of selected text in text fields and textareas. It can also be used to set the selection, and replace the selection with given text (or insert text wherever the cursor is in the text field or textarea).

  • jquery-textrange may not work with WYSIWYG editors. See issue #3 and this question.

Demo

Browser Support

  • Chrome
  • Firefox
  • Microsoft Edge
  • yes, even Internet Explorer 5.5+

Include

Include the file directly using <script> tags:

<script src="https://code.jquery.com/jquery-latest.min.js"></script>
<script src="jquery-plugins/jquery-textrange.js"></script>

:memo: note: jquery-textrange can be loaded through any UMD-compatible Javascript Module Loader.

Methods

You can use this method to get all the information on the selected text of an element or a specific bit of information.

'get'

Get everything
$('input[name="example"]').textrange('get');

or for short:

$('input[name="example"]').textrange();

This will return a JSON object with the following information:

{
   "position": // cursor location in the text field)
   "start": //starting position of the selected text in the text field
   "end": // ending position of the selected text in the text field
   "length": // the length of the selected text in the text field
   "text": // the text that is selected
}
Get a particular property

This function can also be used to get a particular property of the object.

For example, this will obtain the starting location of the selected text:

var start = $('input[name="example"]').textrange('get', 'start');

'set'

You can use this method to set the starting and ending locations of the selected text in an element.

It works much like PHP's substr(), so if you're familiar with that, it should be a breeze! Here are some examples, anyway.

For the following examples, let's say input[name="example"] contains the text abcdef.

$('input[name="example"]').textrange('set'); // selects "abcdef" (select all)
$('input[name="example"]').textrange('set', 2); // selects "cdef"
$('input[name="example"]').textrange('set', 2, 3); // selects "cde"
$('input[name="example"]').textrange('set', 2, -2); // selects "cd"
$('input[name="example"]').textrange('set', -3); // selects "def"
$('input[name="example"]').textrange('set', -2, 1); // selects "e"
$('input[name="example"]').textrange('set', -4, -1); // selects "cde"

If you're looking to set the cursor at one specific location, you can use 0 for length, or you can use $().textrange('setcursor') (see below).

'setcursor'

You can use this method to set the location of the cursor in your text field.

To set the cursor at the fifth character position:

$('input[name="example"]').textrange('setcursor', 5);

'replace'

You can use this method to replace the selection with given text.

$('input[name="example"]').textrange('replace', 'some text');

There is also an insert alias for replace if you're using this method to insert text at the cursor location. They work the same way.

Keywords

FAQs

Last updated on 29 Apr 2017

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc