jQuery - 交换元素的位置

时间:2010-08-08 22:09:19

标签: jquery clone location

如何与同一父母的子女交换位置?
我解决了使用这种代码模式。 有没有更简单的方法?例如:$("#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>

2 个答案:

答案 0 :(得分:1)

您应该考虑将.sortable()与Jquery UI一起使用。  没有无用的按钮,更容易操作。

Take a look

答案 1 :(得分:0)

看看SO question 698301This answer不需要克隆甚至jQuery;只是本机DOM操作。