Can I get a Javascript event from the selection of text outside of text or textarea?

前端 未结 3 1785
爱一瞬间的悲伤
爱一瞬间的悲伤 2021-01-15 19:42

I would like to know when a user selects text in an html page using Javascript. The text should not be editable. The onselect event seems to be only applicabl

相关标签:
3条回答
  • 2021-01-15 19:57

    You could capture the mouseUp event, and check if some text is selected using window.getSelection().

    This method may however not be cross-browser compatible (the window.getSelection()).

    EDIT: here is a pretty complete example with mouseUp binding : http://mark.koli.ch/2009/09/use-javascript-and-jquery-to-get-user-selected-text.html

    0 讨论(0)
  • 2021-01-15 20:04

    This is not easy to do in a cross-browser way. In IE only the select event applies to body text as well as form inputs so would do what you want, but to detect when the user has made a selection in a cross-browser way you will need to handle both keyup and mouseup events. Even then you won't be detecting selection events such as the user using the "Select all" menu option (usually found in the Edit and right click context menus). So you're down to polling at regular intervals and checking properties of the selection object (obtained via window.getSelection() or document.selection in IE).

    0 讨论(0)
  • 2021-01-15 20:09

    Sure, an example exists here: http://www.codetoad.com/javascript_get_selected_text.asp

    Using what you see here, you could bind events to the click/release events of the document body, and check to see if there is a selection, and how long the selection is to determine if they've selected any text.

    StackOverflow Archive:

    1. What's the event fired when a user selects text on a page?
    2. Javascript to get Paragraph of Selected Text in WebPage
    0 讨论(0)
提交回复
热议问题