数日前、友人が Object.getOwnPropertyNames()
が何に使われるのか尋ねました。
私は普段このメソッドをあまり使いません。答え方がわかりません
メソッド名の分析から、オブジェクト自身のプロパティ名で構成される配列が返されるはずです
##これはObject と同じではありませんか。物事はそれほど単純ではないと感じたので、オブジェクトを走査するこれらのメソッドの違いを詳しく調べました。for in
for in ループはオブジェクトを走査する最も基本的な方法であり、オブジェクト プロトタイプ チェーンのプロパティも取得します
// 创建一个对象并指定其原型,bar 为原型上的属性 const obj = Object.create({ bar: 'bar' }) // foo 为对象自身的属性 obj.foo = 'foo' for (let key in obj) { console.log(obj[key]) // foo, bar }
オブジェクト プロトタイプのプロパティも循環していることがわかります
この場合、オブジェクト
hasOwnProperty()メソッドを使用して、プロトタイプ チェーン上のプロパティをフィルターで除外できます。
for (let key in obj) { if (obj.hasOwnProperty(key)) { console.log(obj[key]) // foo } }
この時点で、プロトタイプの bar プロパティがフィルターされます。 outObject.keys
は、ES5 の新しいオブジェクト メソッドです。このメソッドは、オブジェクト自身のプロパティ名で構成される配列を返します。プロトタイプ チェーン上のプロパティを自動的にフィルターで除外します。その後、配列の
forEach() メソッドを使用して <pre class="brush:php;toolbar:false">Object.keys(obj).forEach((key) => {
console.log(obj[key]) // foo
})</pre>
を走査できます。さらに、Object.values()# もあります。 ## メソッドと
Object.entries()
Object と同じです。 .keys() メソッドは似ているため、再度説明しません。
for in ループと
Object.keys() メソッドは、オブジェクトの列挙不可能なプロパティを返しません
Object.getOwnPropertyNames() メソッドを使用する必要があります。
Object.getOwnPropertyNames()
forEach
メソッドを介して走査することもできます。// 创建一个对象并指定其原型,bar 为原型上的属性 // baz 为对象自身的属性并且不可枚举 const obj = Object.create({ bar: 'bar' }, { baz: { value: 'baz', enumerable: false } }) obj.foo = 'foo' // 不包括不可枚举的 baz 属性 Object.keys(obj).forEach((key) => { console.log(obj[key]) // foo }) // 包括不可枚举的 baz 属性 Object.getOwnPropertyNames(obj).forEach((key) => { console.log(obj[key]) // baz, foo })
ES2015 では追加されています。オブジェクトのキーとして使用できる Symbol データ型。この型の場合、ES2015 では
Object.getOwnPropertySymbols() メソッド
Object .getOwnPropertySymbols## も追加されています。 #Object.getOwnPropertySymbols()
このメソッドは、文字列プロパティを除く、オブジェクト自体の Symbol プロパティで構成される配列を返します。
Object.getOwnPropertySymbols(obj).forEach((key) => { console.log(obj[key]) })
オブジェクトがまだシンボルを持っていないため、何もありません。属性
// 给对象添加一个不可枚举的 Symbol 属性 Object.defineProperties(obj, { [Symbol('baz')]: { value: 'Symbol baz', enumerable: false } }) // 给对象添加一个可枚举的 Symbol 属性 obj[Symbol('foo')] = 'Symbol foo' Object.getOwnPropertySymbols(obj).forEach((key) => { console.log(obj[key]) // Symbol baz, Symbol foo })
Reflect.ownKeys
このメソッドは、ES2015 の新しい静的メソッドです。このメソッドは、次のすべてのプロパティ名で構成される配列を返します。オブジェクト自体。列挙不可能なプロパティとシンボル プロパティを含む
Reflect.ownKeys(obj).forEach((key) => { console.log(obj[key]) // baz, foo, Symbol baz, Symbol foo })
コントラスト
#メソッド
基本プロパティ
Symbol | ##for in | Yes | ||
---|---|---|---|---|
Object.keys() | Yes | #No | No | |
##Object.getOwnPropertyNames() | Yes | No | Yes | No |
Object.getOwnPropertySymbols() | No | No | Yes | Yes |
Reflect.ownKeys() | Yes | No | Yes | Yes |
結論 | for in ループのみがオブジェクト プロトタイプ チェーンのプロパティを取得します。他のメソッドはオブジェクト自体のプロパティにのみ適用できます | ES追加された新機能は、以前のコードに副作用をもたらしません。たとえば、ES2015 より前に存在した for in ループ、Object.keys() および Object.getOwnPropertyNames() は、Symbol プロパティを返しません。 | 推奨チュートリアル: 「 | JS チュートリアル
以上がJS でオブジェクトをトラバースするにはいくつかの方法がありますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PythonとJavaScriptの主な違いは、タイプシステムとアプリケーションシナリオです。 1。Pythonは、科学的コンピューティングとデータ分析に適した動的タイプを使用します。 2。JavaScriptは弱いタイプを採用し、フロントエンドとフルスタックの開発で広く使用されています。この2つは、非同期プログラミングとパフォーマンスの最適化に独自の利点があり、選択する際にプロジェクトの要件に従って決定する必要があります。

PythonまたはJavaScriptを選択するかどうかは、プロジェクトの種類によって異なります。1)データサイエンスおよび自動化タスクのPythonを選択します。 2)フロントエンドとフルスタック開発のためにJavaScriptを選択します。 Pythonは、データ処理と自動化における強力なライブラリに好まれていますが、JavaScriptはWebインタラクションとフルスタック開発の利点に不可欠です。

PythonとJavaScriptにはそれぞれ独自の利点があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1. Pythonは、データサイエンスやバックエンド開発に適した簡潔な構文を備えた学習が簡単ですが、実行速度が遅くなっています。 2。JavaScriptはフロントエンド開発のいたるところにあり、強力な非同期プログラミング機能を備えています。 node.jsはフルスタックの開発に適していますが、構文は複雑でエラーが発生しやすい場合があります。

javascriptisnotbuiltoncorc;それは、解釈されていることを解釈しました。

JavaScriptは、フロントエンドおよびバックエンド開発に使用できます。フロントエンドは、DOM操作を介してユーザーエクスペリエンスを強化し、バックエンドはnode.jsを介してサーバータスクを処理することを処理します。 1.フロントエンドの例:Webページテキストのコンテンツを変更します。 2。バックエンドの例:node.jsサーバーを作成します。

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。

JavaScriptフレームワークのパワーは、開発を簡素化し、ユーザーエクスペリエンスとアプリケーションのパフォーマンスを向上させることにあります。フレームワークを選択するときは、次のことを検討してください。1。プロジェクトのサイズと複雑さ、2。チームエクスペリエンス、3。エコシステムとコミュニティサポート。

はじめに私はあなたがそれを奇妙に思うかもしれないことを知っています、JavaScript、C、およびブラウザは正確に何をしなければなりませんか?彼らは無関係であるように見えますが、実際、彼らは現代のウェブ開発において非常に重要な役割を果たしています。今日は、これら3つの間の密接なつながりについて説明します。この記事を通して、JavaScriptがブラウザでどのように実行されるか、ブラウザエンジンでのCの役割、およびそれらが協力してWebページのレンダリングと相互作用を駆動する方法を学びます。私たちは皆、JavaScriptとブラウザの関係を知っています。 JavaScriptは、フロントエンド開発のコア言語です。ブラウザで直接実行され、Webページが鮮明で興味深いものになります。なぜJavascrを疑問に思ったことがありますか


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
