将项目放在动画和 inserbefore 函数混乱之后
Place items right after the animation and inserbefore function mess
这是我的小提琴
我有一个动画,必须重新排列列表中的项目,我们在左侧的幻灯片上单击并变为活动状态,右侧的活动元素幻灯片和活动类从中删除。但是,我在插入之前函数有一些问题。即使动画做对了,它也会把一切都搞砸。我试图弄清楚如何让一切看起来都到位这是我的脚本,但您可以使用小提琴
$(document).ready(function(){
console.log("it started");
swapsies();
});
function swapsies()
{
$('.lang').on('click', function() {
// console.log("here");
//.when(
var $dist = 27;
var $diststr="+="+$dist;
var $diststr2="-="+$dist*2
var $clicked=$(this);
var $mcb= $clicked.css('margin-left');
var $mnb=$clicked.css('margin-left');
var $mab=$('.active').css('margin-left');
$.when(
$(this).animate({ "margin-left": $diststr2 }, 500),
$(this).next().animate({ "margin-left": $diststr }, 500),
$('.active').animate({ "margin-left": $diststr }, 500)
).done(function(){
$clicked.insertBefore('.active');
$(this).css('margin-left', "-54")
$(this).next().css('margin-left', "27");
$('.active').css('margin-left', "27");
$('.active').removeClass('active');
$clicked.addClass('active');
});
});
}
我不确定它应该如何重新排列项目。 但一种方法是这样的。
http://jsfiddle.net/7o6uuf0f/
对 done 函数中的代码进行微小更改
$clicked.insertBefore('.active');
$("#swapthis li").css("margin-left", "0");
$('.active').removeClass('active');
$clicked.addClass('active');
但是,您也可以考虑不重新发明轮子,并使用它。http://jqueryui.com/sortable/#display-grid
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Node.js v6.2.0类扩展不是函数错误
- 比较从函数和生成的日期对象
- jQuery中是否内置了任何字符串格式化函数
- 将项目放在动画和 inserbefore 函数混乱之后