【问题标题】:Check the correct order of drag and drop list检查拖放列表的正确顺序
【发布时间】:2017-02-04 09:04:14
【问题描述】:

我正在制作一个带有服务器网络应用程序的语言学习网站。我是 javascript 的初学者,我似乎找不到解决方案。

这个特殊的应用程序由一些可拖动的列表项组成,这些项可以形成一个句子。列表项是随机列出的,目的是按正确的顺序对它们进行排序,以便句子有意义。

我需要的是一个函数,用户可以在他/她想要检查句子顺序是否正确时调用它。

$( function() {
   $( "#sortable" ).sortable();
   $( "#sortable" ).disableSelection();
});
  <!doctype html>
    <html lang="en">
    <head>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1">
      <title>jQuery UI Sortable - Default functionality</title>
      <link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
      <link rel="stylesheet" href="/resources/demos/style.css">
      <style>
      #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
      #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
      #sortable li span { position: absolute; margin-left: -1.3em; }
      </style>
      <script src="https://code.jquery.com/jquery-1.12.4.js"></script>
      <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
    </head>
    <body>
     
    <ul id="sortable">
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 1</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 2</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 3</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 4</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 5</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 6</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 7</li>
    </ul>
  </body>
    </html>

谢谢!

【问题讨论】:

    标签: javascript jquery html drag-and-drop jquery-ui-draggable


    【解决方案1】:

    给你:

    <!doctype html>
    <html lang="en">
    <head>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1">
      <title>jQuery UI Sortable - Default functionality</title>
      <link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
      <link rel="stylesheet" href="/resources/demos/style.css">
      <style>
      #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
      #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
      #sortable li span { position: absolute; margin-left: -1.3em; }
      </style>
      <script src="https://code.jquery.com/jquery-1.12.4.js"></script>
      <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
      <script>
        $( function() {
            $( "#sortable" ).sortable();
            $( "#sortable" ).disableSelection();
        });
        function sortItems() {
        var items = $('#sortable li').get();
        items.sort(function(a,b){
        var keyA = $(a).text();
        var keyB = $(b).text();    
        if (keyA < keyB) return -1;
        if (keyA > keyB) return 1;
        return 0;
        });
        var ul = $('#sortable');
        $.each(items, function(i, li){
          ul.append(li);
        });
    };
    function checkOrd() {
        var items = $('#sortable li').map(function(){
                   return $.trim($(this).text());
                }).get();
        var itsort = $('#sortable li').map(function(){
                   return $.trim($(this).text());
                }).get();
        itsort.sort();
        if (JSON.stringify(items) == JSON.stringify(itsort))
            alert("Right order!");
        else
            alert("Wrong order!");
    };
      </script>
    </head>
    <body>
    
    <ul id="sortable">
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 1</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 2</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 3</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 4</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 5</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 6</li>
      <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 7</li>
    </ul>
    
    <button onclick="sortItems();">Sort lists</button>
    <button onclick="checkOrd();">Check order</button>
    
    </body>
    </html>
    

    如果您需要不按文本分组,则可以使用按 id 分组:

    <!doctype html>
    <html lang="en">
    <head>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1">
      <title>jQuery UI Sortable - Default functionality</title>
      <link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
      <link rel="stylesheet" href="/resources/demos/style.css">
      <style>
      #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
      #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
      #sortable li span { position: absolute; margin-left: -1.3em; }
      </style>
      <script src="https://code.jquery.com/jquery-1.12.4.js"></script>
      <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
      <script>
        $( function() {
            $( "#sortable" ).sortable();
            $( "#sortable" ).disableSelection();
        });
        function sortItems() {
        var items = $('#sortable li').get();
        items.sort(function(a,b){
        return parseInt(a.id) > parseInt(b.id);
        });
        var ul = $('#sortable');
        $.each(items, function(i, li){
          ul.append(li);
        });
    };
    function checkOrd() {
        var items = $('#sortable li').map(function(){
                   return $.trim($(this).attr('id'));
                }).get();
        var itsort = $('#sortable li').map(function(){
                   return $.trim($(this).attr('id'));
                }).get();
        <!-- console.log(items); -->
        <!-- console.log(itsort); -->
        itsort.sort();
        if (JSON.stringify(items) == JSON.stringify(itsort))
            alert("Right order!");
        else
            alert("Wrong order!");
    };
      </script>
    </head>
    <body>
    
    <ul id="sortable">
      <li id="1" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Coockies</li>
      <li id="2" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Bread</li>
      <li id="3" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Letter</li>
      <li id="4" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Sun</li>
      <li id="5" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Rise</li>
      <li id="6" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Blank</li>
      <li id="7" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Site</li>
    </ul>
    
    <button onclick="sortItems();">Sort lists</button>
    <button onclick="checkOrd();">Check order</button>
    
    </body>
    </html>
    

    我添加了所有 li 的和 ID,我们将使用它们来获得正确的顺序,并更新了脚本来获取它而不是文本。

    【讨论】:

    • 这是正确的,但也许我不够清楚。我正在寻找订单是否正确的反馈。
    • 好的,等一下我会做的。
    • @Ariel.H 完成,看看。
    • 如果我将&lt;li&gt; 的内容更改为“Item n”以外的任何内容,则重新排序按钮不起作用。
    • @Ariel.H 是的,因为它使用文本作为正确顺序的检测,但您可以使用 ID 来检测正确顺序,请参阅我更新的答案。
    猜你喜欢
    • 1970-01-01
    • 2019-02-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-05-28
    • 1970-01-01
    • 2010-12-28
    • 1970-01-01
    相关资源
    最近更新 更多