嘿伙计们,我正在尝试使用向上和向下箭头交换两个元素。
JSFiddle解决方案会很棒! :)
HTML标记就像:
<div class="item">
<div class="content">Some text</div>
<div class="move">
<div class="move-down">down</div>
</div>
</div>
<div class="item">
<div class="content">Some other text</div>
<div class="move">
<div class="move-up">up</div>
<div class="move-down">down</div>
</div>
</div>
<div class="item">
<div class="content">Some text</div>
<div class="move">
<div class="move-up">up</div>
<div class="move-down">down</div>
</div>
</div>
<div class="item">
<div class="content">Some other text</div>
<div class="move">
<div class="move-up">up</div>
</div>
</div>
我的最后一次尝试是:
// el is the clicked one.
jQuery('.move').children().click(function(el){
if(jQuery(el).hasClass('move-down') === true) {
el = jQuery(el).parent().parent();
el.prependTo(el.after(el));
} else {
el = jQuery(el).parent().parent();
el.appendTo(el.before(el));
}
});
我尝试了很多不同的方法来改变物品。我曾尝试在()之后使用replaceWith(),但没有任何效果。
注意: 我已经编写了一个显示正确上/下div的函数。所以第一个和最后一个只能向一个方向移动。那已经解决了。我也不能使用任何现有的jquery插件。
答案 0 :(得分:5)
您可以这样做 - 您需要使用class = move
检查e.target而不是divjQuery('.move').children().click(function (e) { // <-- argument passed in is the event not an element
var $div = $(this).closest('.item'); // get closest item div
if (jQuery(e.target).is('.move-down')) { // check if clicked is movedown
$div.next('.item').after($div); // if it is move after next
} else {
$div.prev('.item').before($div);// else move it before previous
}
});
答案 1 :(得分:3)
我可能会这样做:
$(document).ready(function () {
$('.move-down').click(function (e) {
var self = $(this),
item = self.parents('div.item'),
swapWith = item.next();
item.before(swapWith.detach());
});
$('.move-up').click(function (e) {
var self = $(this),
item = self.parents('div.item'),
swapWith = item.prev();
item.after(swapWith.detach());
});
});
以下是一个有效的例子:http://jsfiddle.net/a6Se4/
答案 2 :(得分:2)
尝试:
jQuery('.move > div').on('click', function(event) {
var item = jQuery(this).closest('div.item');
if(jQuery(this).hasClass('move-down')) {
item.prev('div.item').before(item);
} else {
item.next('div.item').after(item);
}
});
答案 3 :(得分:2)
我知道它已经解决但我只是想在我寻找同一问题的答案时偶然发现这个解决方案:
Is there a native jQuery function to switch elements?
jQuery("#element1").before(jQuery("#element2"));
or
jQuery("#element1").after(jQuery("#element2"));
实际上,这只是Derek所建议的。