検索
ホームページウェブフロントエンドjsチュートリアルjavascript 配列 (uniq) 内の重複アイテムを削除_javascript スキル

直接利用できるコード:スクリプトハウス改訂版


[Ctrl A すべて選択 注: 外部 Js を導入する必要がある場合は、更新して実行する必要があります
]

以下は高度なチュートリアルであり、詳しく知りたい友人は参照してください。
まず、YUI がどのように処理するかを見てみましょう: コードは次のとおりです:


var toObject = function(a) {
var o = {};
for (var i = 0; i o[a [i ]] = true;
return o;

var キー = function(o) {
var a=[],
for ( i in o) {
if (lang.hasOwnProperty(o, i)) { // YUI メソッド
a.push(i);
}
}
return a;
};

var uniq = function(a) {
return names(toObject(a));


を参照してください。同僚の Tian が「配列から重複を賢く削除する」を共有しています。

私が使用するメソッドは YUI のメソッドとよく似ていますが、次のように、配列内の重複項目を削除するために 1 つのループのみが使用されます。


var uniq = function (arr) {
var a = [],
o = {},
i,
v,
len = arr.length;

if (len return
}

(i = 0; i v = arr[i]
if (o[v] !== 1) {
a.push(v); >o[ v] = 1;
}
}

return a;
}


使用したメソッドのパフォーマンスYUIよりもはるかに高いです。
より良いソリューションを提供してくださる皆様を歓迎します。

2009 年 12 月 28 日更新:

上記の 2 つの関数メソッドは、当面の間、混合型を含む複雑な配列を処理できません (質問を提起してくれた Mao Mao に感謝します)。[ 0、"0"、1、"1"、0]、["null"、null]。

型が数値 (注: 0 以外で始まる数値、小数点を除く) または文字列であると合意できる配列の場合、改良された関数メソッドを使用できます (closurecache のアイデアのおかげです)。



コードをコピー コードは次のとおりです: var uniq = function (arr) {
var a = [ ],
o = {},
i,
v,
cv, // 修正値
len = arr.length;

if ( len return
}

for (i = 0; i v = arr[i]; 🎜>/* Closurecache によって提供される関数は cv = v 0;,
* を使用するため、[1, 10, "1", "10"] のような配列は区別できません。
* は演算 => の後に行われるためです。 1 、10、10、100。明らかに、重複した識別子があります。
*を前に付けても大丈夫でしょうか?
* はい: 0 で始まる 01 や 001 のような数字は配列
* には現れませんが、その適用範囲は以前よりも広くなります。
*/
cv = 0 v;

if (!o[cv]) {
a.push(v) = true; >}
}

return a;
}


この問題解決のアイデアに基づいてより完璧なものにしたい場合は、Dexter.Yy の方法をお勧めします、型判定を実行し、一意の識別子を付与します。詳細は 20 階のコメントを参照してください。

最善の方法はなく、最も適切な方法があるだけです。実際、Array.indexOf() をすでにサポートしているブラウザの場合は、ネイティブの Array.indexOf を使用することも良い選択です。 () メソッドを直接サポートしていないブラウザの場合は、ネイティブの Array.indexOf() メソッドを直接使用します。


のように Array.indexOf() メソッドを追加します。
コードをコピー


コードは次のとおりです。
if(!Array.prototype.indexOf) { Array.prototype.indexOf = function ( obj, fromIndex) { if (fromIndex == null) { fromIndex = 0; } else if (fromIndex fromIndex = Math.max(0, this.length) fromIndex);
}

for (var i = fromIndex; i if (this[i] === obj)
return i;
}
return -1;
};
}


次に、実装プロセスは非常に簡単です。

Array.indexOf() メソッドを使用してソリューションを実装するための最適化のヒント: 同じ値が見つかった場合は、それを配列から削除して、次の走査量を減らします。
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JavaScript:Web言語の汎用性の調査JavaScript:Web言語の汎用性の調査Apr 11, 2025 am 12:01 AM

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

JavaScriptの進化:現在の傾向と将来の見通しJavaScriptの進化:現在の傾向と将来の見通しApr 10, 2025 am 09:33 AM

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

javascriptの分解:それが何をするのか、なぜそれが重要なのかjavascriptの分解:それが何をするのか、なぜそれが重要なのかApr 09, 2025 am 12:07 AM

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

pythonまたはjavascriptの方がいいですか?pythonまたはjavascriptの方がいいですか?Apr 06, 2025 am 12:14 AM

Pythonはデータサイエンスや機械学習により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、簡潔な構文とリッチライブラリエコシステムで知られており、データ分析とWeb開発に適しています。 2。JavaScriptは、フロントエンド開発の中核です。 node.jsはサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。

JavaScriptをインストールするにはどうすればよいですか?JavaScriptをインストールするにはどうすればよいですか?Apr 05, 2025 am 12:16 AM

JavaScriptは、最新のブラウザにすでに組み込まれているため、インストールを必要としません。開始するには、テキストエディターとブラウザのみが必要です。 1)ブラウザ環境では、タグを介してHTMLファイルを埋め込んで実行します。 2)node.js環境では、node.jsをダウンロードしてインストールした後、コマンドラインを介してJavaScriptファイルを実行します。

クォーツでタスクが開始される前に通知を送信する方法は?クォーツでタスクが開始される前に通知を送信する方法は?Apr 04, 2025 pm 09:24 PM

Quartzタイマーを使用してタスクをスケジュールする場合、Quartzでタスク通知を事前に送信する方法、タスクの実行時間はCron式によって設定されます。今...

JavaScriptでは、コンストラクターのプロトタイプチェーンで関数のパラメーターを取得する方法は?JavaScriptでは、コンストラクターのプロトタイプチェーンで関数のパラメーターを取得する方法は?Apr 04, 2025 pm 09:21 PM

JavaScriptプログラミング、プロトタイプチェーンの関数パラメーターの理解と操作のJavaScriptのプロトタイプチェーンの関数のパラメーターを取得する方法は、一般的で重要なタスクです...

WeChat MiniプログラムWebViewでVUE.JSダイナミックスタイルの変位が失敗した理由は何ですか?WeChat MiniプログラムWebViewでVUE.JSダイナミックスタイルの変位が失敗した理由は何ですか?Apr 04, 2025 pm 09:18 PM

WeChatアプレットWeb-ViewでVue.jsを使用する動的スタイルの変位障害がvue.jsを使用している理由の分析...

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。