Heim >Web-Frontend >js-Tutorial >JQuery -Ausgangsarray in zufälliger Reihenfolge
Folgendes sind einige Code -Snippets, mit denen JQuery nach dem Zufallsprinzip Elemente sortiert.
Sortiercode -Snippet
Die folgenden Funktionen verwenden Objektliteralformat:
shuffleAds: function(arr) { for (var j, x, i = arr.length; i; j = parseInt(Math.random() * i), x = arr[--i], arr[i] = arr[j], arr[j] = x); return arr; }
Die Demo anzeigen Sie eine andere Funktion, die dieselbe Funktion implementiert:
function randsort(c) { var o = new Array(); for (var i = 0; i < c; i++) { var n = Math.floor(Math.random() * c); if (jQuery.inArray(n, o) > 0) --i; else o.push(n); } return o; }
Ich denke auch, dass dieses JQuery Shuffle -Plugin es wert ist, einschließlich:
/* * jQuery shuffle * * Copyright (c) 2008 Ca-Phun Ung * Dual licensed under the MIT (MIT-LICENSE.txt) * and GPL (GPL-LICENSE.txt) licenses. * * http://yelotofu.com/labs/jquery/snippets/shuffle/ * * Shuffles an array or the children of a element container. * This uses the Fisher-Yates shuffle algorithm */ (function($) { $.fn.shuffle = function() { return this.each(function() { var items = $(this).children().clone(true); return (items.length) ? $(this).html($.shuffle(items)) : this; }); } $.shuffle = function(arr) { for (var j, x, i = arr.length; i; j = parseInt(Math.random() * i), x = arr[--i], arr[i] = arr[j], arr[j] = x); return arr; } })(jQuery);
FAQs über die zufällige Sortierung von JQuery -Arrays (FAQ)
Ohne JQuery können Sie Arrays im JavaScript mit Fisher-Yates (auch als Knuth) Shuffle-Algorithmus zufällig sortieren. Dieser Algorithmus funktioniert, indem er vom letzten Element zum ersten Element iteriert und jedes Element mit einem Element an einem zufälligen Index von weniger als dem aktuellen Index ausgetauscht wird. Dies ist eine einfache Implementierung:
function shuffleArray(array) { for (let i = array.length - 1; i > 0; i--) { let j = Math.floor(Math.random() * (i + 1)); [array[i], array[j]] = [array[j], array[i]]; } }
Während technisch die Arrays in JavaScript mit der Methode .sort () randomisiert, wird dies nicht empfohlen. Die .sort () -Methode soll keine zufällige Sortierung erzeugen und es führt auf diese Weise zu verzerrten Ergebnissen. Der Fisher-Yates Shuffle-Algorithmus ist eine bessere Wahl für diese Aufgabe.
Die Reihenfolge der Divelelemente kann randomisiert werden, indem JQuery's .get () -Methode verwendet wird, um JQuery -Objekte in ein Array umzuwandeln und dann das Array zufällig zu sortieren und die Elemente an das übergeordnete Element zurückzukehren. Hier ist ein Beispiel:
var parent = $("#parent"); var divs = parent.children(); divs.sort(function() { return Math.random() - 0.5; }); divs.detach().appendTo(parent);
Fisher-yates-Mischalgorithmus hat eine zeitliche Komplexität von O (n), wobei n die Anzahl der Elemente im Array ist. Dies macht es zu einer effektiven Wahl, um große Arrays zufällig zu sortieren.
Ja, der Fisher-Yates-Shuffle-Algorithmus kann verwendet werden, um Arrays von Elementen jeglicher Art, einschließlich Objekte, zufällig zu sortieren. Der Algorithmus behandelt jedes Element als einzelne Einheit, unabhängig davon, welche Daten er enthält.
jQuery hat keine integrierte Methode, um Arrays zufällig zu sortieren, aber JavaScripts Fisher-Yates-Mischungsalgorithmus kann in Verbindung mit JQuery verwendet werden. Hier ist ein Beispiel:
$.fn.shuffle = function() { var allElems = this.get(), getRandom = function(max) { return Math.floor(Math.random() * max); }, shuffled = $.map(allElems, function() { var random = getRandom(allElems.length), randEl = $(allElems[random]).clone(true)[0]; allElems.splice(random, 1); return randEl; }); this.each(function(i) { $(this).replaceWith($(shuffled[i])); }); return $(shuffled); };
Ja, Sie können Kopien von Arrays erstellen und zufällig sortieren. Dies kann verwendet werden, um eine Replik mit der Methode .slice () zu erstellen und dann den Fisher-Yates-Shuffle-Algorithmus auf die Replik.
Ja, Sie können Strings in JavaScript zufällig sortieren, indem Sie Strings in Zeichen -Arrays konvertieren, zufällig sortieren und dann die Arrays in Saiten in Einklang bringen. Hier ist ein Beispiel:
shuffleAds: function(arr) { for (var j, x, i = arr.length; i; j = parseInt(Math.random() * i), x = arr[--i], arr[i] = arr[j], arr[j] = x); return arr; }
zufällig sortieren Arrays in einer bestimmten Reihenfolge ein ambivalenter Begriff, da zufällige Sortierungen zufällige Reihenfolge bedeutet. Wenn Sie das Array in einer bestimmten nicht zufälligen Reihenfolge anordnen müssen, müssen Sie einen Sortieralgorithmus anstelle eines zufälligen Sortieralgorithmus verwenden.
Ja, Sie können den Fisher-Yates-Shuffle-Algorithmus verwenden, um die Liste in JQuery zufällig zu sortieren. Sie können die Methode .get () verwenden, um Listenelemente in ein Array umzuwandeln, das Array zufällig zu sortieren und dann die Elemente wieder an die Liste anzuhängen.
Diese überarbeitete Reaktion behält das Originalbild bei und liefert eher präzise und verbesserte Erklärungen.
Das obige ist der detaillierte Inhalt vonJQuery -Ausgangsarray in zufälliger Reihenfolge. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!