2016-05-21 3 views
0

Ich versuche, das folgende zu implementieren.Erstellen Sie eine Tabelle aus einem Objekt jquery/javascript

Ein Benutzer gibt einen Satz in ein Textfeld ein, nach dem eine Tabelle erstellt wird. Ein Beispiel wäre das.

Eingang: "This is what I want to achieve"

Ergebnis:

enter image description here

Derzeit basiert auf dem Code, den ich dort habe, ist ein Objekt, das wie folgt aussieht:

{t: ["this", "to"], i: ["is", "i"], w: ["what", "want"], a: ["achieve"]}; 

Im Folgenden finden Sie die aktuelle Code habe ich (also see jsfiddle here).

Ich bin in der Lage, die Eingabezeichenfolge und erstellen Sie eine Tabelle mit einer Zeile, die den ersten Buchstaben jedes Wortes hat.

HTML

<textarea id="text-input" name="textarea" rows="5" cols="25">This is what I want to achieve</textarea> 
<button class="calculate">Calculate</button> 

<table> 
    <tbody> 
    <tr class="words-header"></tr> 
    </tbody> 
</table> 

Javascript

$(document).ready(function() { 
    $(".calculate").click(function() { 
    var result = {}, 
     arr = []; 
    var array = $("#text-input").val().toLowerCase().split(" "); 

    for (var i = 0; i < array.length; i++) { 
     if (typeof result[array[i][0]] == 'undefined') { 
     result[array[i][0]] = []; 
     } 
     result[array[i][0]].push(arr[i]); 
    } 
    for (var key in result) { 
     $(".words-header").append("<td>" + key.toUpperCase() + "</td>"); 
    } 
    }); 
}); 

Ich glaube, der Final Table sollte wie folgt aussehen, wenn es hilft:

<table> 
    <tr> 
     <td>A</td> 
     <td>I</td> 
     <td>T</td> 
     <td>W</td> 
    </tr> 
    <tr> 
     <td>achieve</td> 
     <td>is</td> 
     <td>this</td> 
     <td>what</td> 
    </tr> 
    <tr> 
     <td> </td> 
     <td>i</td> 
     <td>to</td> 
     <td>want</td> 
    </tr> 
</table> 
+0

Das ist nicht ein mehrdimensionales Array ist, das ist ein Objekt mit Eigenschaften, und sollte auch so geschrieben werden: '{t: [... ], ich: [...], ...} '. – blex

+0

'var $ = jQuery.noConflict();' ergibt keinen Sinn. Besiegt den Zweck von 'noConflict()', der $ $ alias entfernen soll – charlietfl

+0

@blex Ich habe die Frage aktualisiert. Hast du eine Idee, wie ich das umsetzen kann? –

Antwort

0

Sie es auf diese Weise tun können (Probieren Sie es mit clicki ng der Run Code Button) Snippet:

var app = app || {}; 
 
(function() { 
 
    "use strict"; 
 

 
    var result, arr; 
 

 
    app.initialize = { 
 
     init: function() { 
 
      app.splitWords.init(); 
 
     } 
 
    }; 
 

 
    app.splitWords = { 
 
     init: function() { 
 
      $(".calculate").click(function() { 
 
       result = []; 
 
       arr = $("#text-input").val().split(" "); 
 
       app.createMultiArray.init(arr); 
 
      }); 
 
     } 
 
    }; 
 

 
    app.createMultiArray = { 
 
     init: function(array) { 
 
      for (var i = 0; i < array.length; i++) { 
 
       var letter = array[i][0].toLowerCase(); 
 
       if (typeof result[letter] == 'undefined') { 
 
        result[letter] = []; 
 
       } 
 
       result[letter].push(array[i]); 
 
      } 
 
      // I added this method 
 
      app.buildTable.init(result); 
 
     } 
 
    }; 
 

 
    app.buildTable = { 
 
     init: function(result) { 
 
      var headers = Object.keys(result), 
 
       max_rows = 0, 
 
       rows_html = ''; 
 
      headers.sort(); 
 
      app.createHeaders.init(headers); 
 
      // Determine how many rows you'll need 
 
      for (var i = 0; i < headers.length; i++) { 
 
       if(result[headers[i]].length > max_rows) { max_rows = result[headers[i]].length; } 
 
      } 
 
      // Loop "max_rows" times 
 
      for (var i = 0; i < max_rows; i++) { 
 
       rows_html += '<tr>'; 
 
       // Loop through all letters 
 
       for(var j = 0; j < headers.length; j++) { 
 
        rows_html += '<td>'; 
 
        if(i < result[headers[j]].length) { 
 
         rows_html += result[headers[j]][i]; 
 
        } 
 
        rows_html += '</td>'; 
 
       } 
 
       rows_html += '</tr>'; 
 
      } 
 
      $(".words-header").after(rows_html); 
 
     } 
 
    }; 
 
    
 
    app.createHeaders = { 
 
     init: function(headers) { 
 
      // Empty the table in case of multiple tries 
 
      $(".words-header").parent().html('<tr class="words-header"></tr>'); 
 
      for (var i = 0; i < headers.length; i++) { 
 
       $(".words-header").append("<td>" + headers[i].toUpperCase() + "</td>"); 
 
      } 
 
     } 
 
    }; 
 

 
    app.docOnReady = { 
 
     init: function() { 
 
      app.initialize.init(); 
 
     } 
 
    }; 
 

 
    $(document).ready(app.docOnReady.init); 
 

 
})(jQuery);
#results-table table{ border-collapse: collapse; } #results-table td{ border: 1px solid #000; padding: .2em;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> 
 

 
<textarea id="text-input" name="textarea" rows="5" cols="25">This is what I want to achieve</textarea> 
 
<button class="calculate">Calculate</button> 
 

 
<div id="results-table"> 
 
    <table> 
 
    <tbody> 
 
     <tr class="words-header"></tr> 
 
    </tbody> 
 
    </table> 
 
</div>

+0

aktualisiert das ist erstaunlich @blex –