如何与同一父母的子女交换位置?
我解决了使用这种代码模式。
有没有更简单的方法?例如:$("#id1").exchange($("#id2"));
<!DOCTYPE html>
<html>
<head>
<style>
button { display:block; margin:3px; color:red; width:200px; }
</style>
<script src="http://code.jquery.com/jquery-latest.min.js"></script>
</head>
<body>
<h1>Exchange places</h1>
<ul>
<li id="a">a</li>
<li id="b">b</li>
<li id="c">c</li>
<li id="d">d</li>
</ul>
<button>exchange 1st,2nd</button>
<button>exchange 1st,4th</button>
<button>exchange 2nd,3rd</button>
<script>
$("button:first").click(function () {
var cp = $("li:eq(0)").clone();
$("li:eq(0)").replaceWith($("li:eq(1)").clone());
$("li:eq(1)").replaceWith(cp);
});
$("button:eq(1)").click(function () {
var cp = $("li:eq(0)").clone();
$("li:eq(0)").replaceWith($("li:eq(3)").clone());
$("li:eq(3)").replaceWith(cp);
});
$("button:last").click(function () {
var cp = $("li:eq(1)").clone();
$("li:eq(1)").replaceWith($("li:eq(2)").clone());
$("li:eq(2)").replaceWith(cp);
});
</script>
</body>
</html>
答案 0 :(得分:1)
您应该考虑将.sortable()
与Jquery UI一起使用。
没有无用的按钮,更容易操作。
答案 1 :(得分:0)
看看SO question 698301。 This answer不需要克隆甚至jQuery;只是本机DOM操作。