search
HomeWeb Front-endJS TutorialDetailed explanation of drag method example of jquery sortable_jquery

All event callback functions have two parameters: event and ui, the browser's own event object, and the encapsulated ui object
ui.helper - a JQuery object representing the sortable element, usually a clone of the current element
ui.position - represents the coordinate value object {top,left} of the mouse relative to the current object
ui.offset - represents the coordinate value object {top,left} of the mouse relative to the current page
ui.item - Represents the currently dragged element
ui.placeholder - Placeholder (if defined)
ui.sender - The sortable object to which the currently dragged element belongs (only if the element is passed from another sortable object Useful when needed)

·Parameter (Parameter name: Parameter type: Default value)
appendTo : String : 'parent'
Defines where the helper that moves with the mouse is being appended to during the drag (for example, to resolve overlap/zIndex issues).
Initial: $('.selector').sortable({ appendTo: 'body' });
Get: var appendTo = $('.selector' ).sortable('option', 'appendTo');
Settings: $('.selector').sortable('option', 'appendTo', 'body');

axis : String : false
If set, the element can only be dragged horizontally or vertically. Optional values: 'x', 'y'
Initial: $('.selector').sortable({ axis: 'x' });
Get: var axis = $('.selector') .sortable('option', 'axis');
Settings: $('.selector').sortable('option', 'axis', 'x');

cancel : Selector : ':input,button'
Prevents sorting actions from happening on matching elements.
Initial: $('.selector').sortable({ cancel: 'button' });
Get: var cancel = $('.selector').sortable('option', 'cancel') ;
Settings: $('.selector').sortable('option', 'cancel', 'button');

connectWith : Selector : false
Allows a sortable object to connect to another sortable Object, item elements can be dragged into another.
Initial: $('.selector').sortable({ connectWith: '.otherlist' });
Get: var connectWith = $('.selector').sortable('option', 'connectWith' );
Settings: $('.selector').sortable('option', 'connectWith', '.otherlist');

containment : Element, String, Selector : false
Constraint Sorting actions can only occur within a specified range. Optional values: DOM object, 'parent', 'document', 'window', or jQuery object
Initial: $('.selector').sortable({ containment: 'parent' });
Get :var containment = $('.selector').sortable('option', 'containment');
Setting: $('.selector').sortable('option', 'containment', 'parent') ;

cursor : String : 'auto'
Define the style if when starting the sorting action.
Initial: $('.selector').sortable({ cursor: 'crosshair' });
Get: var cursor = $('.selector').sortable('option', 'cursor') ;
Settings: $('.selector').sortable('option', 'cursor', 'crosshair');

cursorAt : Object : false
Mouse positioning when starting to move at a certain position (up to two directions). Optional values: { top, left, right, bottom }.
Initial: $('.selector').sortable({ cursorAt: 'top' });
Get: var cursorAt = $('. selector').sortable('option', 'cursorAt');
Settings: $('.selector').sortable('option', 'cursorAt', 'top');

delay : Integer : 0
In milliseconds, set the delay before activating the sorting action. This parameter prevents accidental clicks.
Initial: $('.selector').sortable({ delay: 500 });
Get: var delay = $('.selector').sortable('option', 'delay');
Settings: $('.selector').sortable('option', 'delay', 500);

distance : Integer : 1
After deciding at least how many pixels to drag above the element , the sorting action is officially triggered.
Initial: $('.selector').sortable({ distance: 30 });
Get: var distance = $('.selector').sortable('option', 'distance');
Settings: $('.selector').sortable('option', 'distance', 30);

dropOnEmpty: Boolean: true
Whether dragging into an empty sortable object is allowed .
Initial: $('.selector').sortable({ dropOnEmpty: false });
Get: var dropOnEmpty = $('.selector').sortable('option', 'dropOnEmpty');
Settings: $('.selector').sortable('option', 'dropOnEmpty', false);

forceHelperSize : Boolean : false
If true, forces the helper to have a size.
Initial: $('.selector').sortable({ forceHelperSize: true });
Get: var forceHelperSize = $('.selector').sortable('option', 'forceHelperSize');
Settings: $('.selector').sortable('option', 'forceHelperSize', true);

forcePlaceholderSize : Boolean : false
If true, forces the placeholder to have a size.
Initial: $('.selector').sortable({ forcePlaceholderSize: true });
Get: var forcePlaceholderSize = $('.selector').sortable('option', 'forcePlaceholderSize');
Settings: $('.selector').sortable('option', 'forcePlaceholderSize', true);

grid : Array : false
Treat the item element of the sorted object as a grid. , each move moves by one grid size, array value: [x, y]
Initial: $('.selector').sortable({ grid: [50, 20] });
Get: var grid = $('.selector').sortable('option', 'grid');
Settings: $('.selector').sortable('option', 'grid', [50, 20] );

handle : Selector, Element : false
Limit the sorting action to only start on a certain element in the item element.
Initial: $('.selector').sortable({ handle: 'h2' });
Get: var handle = $('.selector').sortable('option', 'handle') ;
Settings: $('.selector').sortable('option', 'handle', 'h2');

helper : String, Function : 'original'
Whether the setting is When an element is dragged, an auxiliary element is displayed. Optional values: 'original', 'clone'
Initial: $('.selector').sortable({ helper: 'clone' });
Get: var helper = $('.selector') .sortable('option', 'helper');
Settings: $('.selector').sortable('option', 'helper', 'clone');

items : Selector : '> *'
Specifies which elements in the sorting object can be dragged and sorted.
Initial: $('.selector').sortable({ items: 'li' });
Get: var items = $('.selector').sortable('option', 'items') ;
Settings: $('.selector').sortable('option', 'items', 'li');

opacity : Float : false
Define the auxiliary element when sorting (helper) Display transparency.
Initial: $('.selector').sortable({ opacity: 0.6 });
Get: var opacity = $('.selector').sortable('option', 'opacity');
Settings: $('.selector').sortable('option', 'opacity', 0.6);

placeholderType: StringDefault: false
Set the blank placeholder when the sorting action occurs CSS styles.
Initial: $('.selector').sortable({ placeholder: 'ui-state-highlight' });
Get: var placeholder = $('.selector').sortable('option', 'placeholder');
Settings: $('.selector').sortable('option', 'placeholder', 'ui-state-highlight');

revert : Boolean : false
If set to true, the dragged element will have an animation effect when it returns to its new position.
Initial: $('.selector').sortable({ revert: true });
Get: var revert = $('.selector').sortable('option', 'revert');
Settings: $('.selector').sortable('option', 'revert', true);

scroll : Boolean : true
If set to true, the element is dragged to It will automatically scroll when you reach the edge of the page.
Initial: $('.selector').sortable({ scroll: false });
Get: var scroll = $('.selector').sortable('option', 'scroll');
Settings: $('.selector').sortable('option', 'scroll', false);

scrollSensitivity : Integer : 20
Set how many pixels the element moves to the edge. Start scrolling the page.
Initial: $('.selector').sortable({ scrollSensitivity: 40 });
Get: var scrollSensitivity = $('.selector').sortable('option', 'scrollSensitivity');
Settings: $('.selector').sortable('option', 'scrollSensitivity', 40);

scrollSpeed ​​: Integer : 20
Set the speed of page scrolling.
Initial: $('.selector').sortable({ scrollSpeed: 40 });
Get: var scrollSpeed ​​= $('.selector').sortable('option', 'scrollSpeed');
Settings: $('.selector').sortable('option', 'scrollSpeed', 40);

tolerance : String : 'intersect'
Set how much the dragged element exceeds other elements elements are reordered. Optional values: 'intersect', 'pointer'
intersect: overlap at least 50%
pointer: mouse pointer overlaps elements
Initial: $('.selector').sortable({ tolerance: 'pointer' });
Get: var tolerance = $('.selector').sortable('option', 'tolerance');
Set: $('.selector').sortable('option', ' tolerance', 'pointer');

zIndex : Integer : 1000
Set the z-index value of the element when the sorting action occurs.
Initial: $('.selector').sortable({ zIndex: 5 });
Get: var zIndex = $('.selector').sortable('option', 'zIndex');
Settings: $('.selector').sortable('option', 'zIndex', 5);


·Event

start
When the sorting action starts This event is triggered when.
Definition: $('.selector').sortable({ start: function(event, ui) { ... } });
Binding: $('.selector').bind('sortstart ', function(event, ui) { ... });

sort
This event is triggered when elements are sorted.
Definition: $('.selector').sortable({ sort: function(event, ui) { ... } });
Binding: $('.selector').bind('sort ', function(event, ui) { ... });

change
This event is triggered when the elements are sorted and the coordinates have changed.
Definition: $('.selector').sortable({ change: function(event, ui) { ... } });
Binding: $('.selector').bind('sortchange ', function(event, ui) { ... });

beforeStop
This event is triggered before the sorting action ends. Placeholder elements and helper elements are still valid at this time.
Definition: $('.selector').sortable({ beforeStop: function(event, ui) { ... } });
Binding: $('.selector').bind('sortbeforeStop ', function(event, ui) { ... });

stop
This event is triggered when the sorting action ends.
Definition: $('.selector').sortable({ stop: function(event, ui) { ... } });
Binding: $('.selector').bind('sortstop ', function(event, ui) { ... });

update
This event is triggered when the sorting action ends and the element coordinates have changed.
Definition: $('.selector').sortable({ update: function(event, ui) { ... } });
Binding: $('.selector').bind('sortupdate ', function(event, ui) { ... });

receive
This event is triggered when a connected sortable object receives an element from another sortable object.
Definition: $('.selector').sortable({ receive: function(event, ui) { ... } });
Binding: $('.selector').bind('sortreceive ', function(event, ui) { ... });

over
This event is triggered when an element is dragged and moved into another sortable object.
Definition: $('.selector').sortable({ over: function(event, ui) { ... } });
Binding: $('.selector').bind('sortover ', function(event, ui) { ... });

out
This event is triggered when an element is dragged out of the sortable object and into another sortable object.
Definition: $('.selector').sortable({ out: function(event, ui) { ... } });
Binding: $('.selector').bind('sortout ', function(event, ui) { ... });

activate
When a sortable object with a connection starts sorting action, all allowed sortables trigger this event.
Definition: $('.selector').sortable({ activate: function(event, ui) { ... } });
Binding: $('.selector').bind('sortactivate ', function(event, ui) { ... });

deactivate
When a connected sortable object ends the sorting action, all allowed sortables trigger this event.
Definition: $('.selector').sortable({ deactivate: function(event, ui) { ... } });
Binding: $('.selector').bind('sortdeactivate ', function(event, ui) { ... });


·Method
destory
Remove drag functionality from the element.
Usage: .sortable( 'destroy' )

disable
Disable the dragging function of the element.
Usage: .sortable( 'disable' )

enable
Enable the dragging function of the element.
Usage: .sortable( 'enable' )

option
Gets or sets the parameters of the element.
Usage: .sortable( 'option' , optionName , [value] )

serialize
Get or set the id attribute of each item element after serialization.
Usage: .sortable( 'serialize' , [options] )

toArray
Get the array of the id attribute of each item element after serialization.
Usage: .sortable( 'toArray' )

refresh
Manually refresh the sorting of the item elements of the current sortable object.
Usage: .sortable( 'refresh' )

refreshPositions
Manually refresh the coordinates of the item element of the current sortable object. This method may reduce performance.
Usage: .sortable( 'refreshPositions' )

cancel
Cancel the sorting change of item elements in the current sortable object.
Usage: .sortable( 'cancel' )


There are two ways to save after sorting, one is cookie, the other is database configuration file, etc.

The following is part of the code of the database. Original work:

Copy code The code is as follows:

$(function() {
var show = $(".loader");
var orderlist = $(".orderlist");
var listleft = $("div [id = 'column_left']");
var listcenter = $("div[id = 'column_center']");
var listright = $("div[id = 'column_right']");
$( ".column" ).sortable({
opacity: 0.5,//Drag transparency
revert: true, //Buffering effect
cursor: 'move', //Drag Mouse style when moving
connectWith: ".column",
//Start using update and execute the result twice, which is a waste of resources. Now change it to stop
//But stop also works when the element has not changed its position. It will be executed,
//There will be problems with other js using update, ^_^
stop: function(){
var new_order_left = []; //Left column layout
var new_order_center = [] ;//Middle column layout
var new_order_right = [];//Right column layout
listleft.children(".portlet").each(function() {
new_order_left.push(this.title) ;
});
listcenter.children(".portlet").each(function() {
new_order_center.push(this.title);
});
listright.children (".portlet").each(function() {
new_order_right.push(this.title);
});
var newleftid = new_order_left.join(',');
var newcenterid = new_order_center.join(',');
var newrightid = new_order_right.join(',');
$.ajax({
type: "post",
url: jsonUrl, //Server-side handler
data: { leftid: newleftid, centerid: newcenterid, rightid:newrightid}, //id: ID corresponding to the new arrangement, order: original arrangement order
// beforeSend: function( ) {
// show.html("Updating");
// },
success: function(msg) {
//alert(msg);
show.html ("");
}
});
}
});
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
jquery实现多少秒后隐藏图片jquery实现多少秒后隐藏图片Apr 20, 2022 pm 05:33 PM

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

jquery怎么修改min-height样式jquery怎么修改min-height样式Apr 20, 2022 pm 12:19 PM

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

axios与jquery的区别是什么axios与jquery的区别是什么Apr 20, 2022 pm 06:18 PM

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

jquery怎么在body中增加元素jquery怎么在body中增加元素Apr 22, 2022 am 11:13 AM

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

jquery中apply()方法怎么用jquery中apply()方法怎么用Apr 24, 2022 pm 05:35 PM

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

jquery怎么删除div内所有子元素jquery怎么删除div内所有子元素Apr 21, 2022 pm 07:08 PM

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

jquery on()有几个参数jquery on()有几个参数Apr 21, 2022 am 11:29 AM

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。

jquery怎么去掉只读属性jquery怎么去掉只读属性Apr 20, 2022 pm 07:55 PM

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor