Core: Only use mousedown to prevent text selection in browsers that don't support selectstart. Fixes #6080 - Core: disableSelection() disables select elements in Chrome.

This commit is contained in:
Scott González 2010-09-20 11:53:51 -04:00
parent f04a25f9bf
commit 47e312b238

13
ui/jquery.ui.core.js vendored
View File

@ -118,9 +118,8 @@ $.fn.extend({
}, },
disableSelection: function() { disableSelection: function() {
return this.bind( return this.bind( $.support.selectstart ? "selectstart" : "mousedown" +
"mousedown.ui-disableSelection selectstart.ui-disableSelection", ".ui-disableSelection", function( event ) {
function( event ) {
event.preventDefault(); event.preventDefault();
}); });
}, },
@ -217,8 +216,8 @@ $.extend( $.expr[ ":" ], {
// support // support
$(function() { $(function() {
var div = document.createElement( "div" ), var body = document.body,
body = document.body; div = body.appendChild( div = document.createElement( "div" ) );
$.extend( div.style, { $.extend( div.style, {
minHeight: "100px", minHeight: "100px",
@ -227,7 +226,9 @@ $(function() {
borderWidth: 0 borderWidth: 0
}); });
$.support.minHeight = body.appendChild( div ).offsetHeight === 100; $.support.minHeight = div.offsetHeight === 100;
$.support.selectstart = "onselectstart" in div;
// set display to none to avoid a layout bug in IE // set display to none to avoid a layout bug in IE
// http://dev.jquery.com/ticket/4014 // http://dev.jquery.com/ticket/4014
body.removeChild( div ).style.display = "none"; body.removeChild( div ).style.display = "none";