目次
1. 演算子を削除します
2. js の内部プロパティ
2.1 データ属性
2.3 获取内部属性
3. 总结
ホームページ ウェブフロントエンド jsチュートリアル js_javascript スキルの内部属性と削除演算子の概要

js_javascript スキルの内部属性と削除演算子の概要

May 16, 2016 pm 03:46 PM
delete オペレーター

Configurableを説明する前に、まず面接の質問を見てみましょう:

a = 1;
console.log( window.a ); // 1
console.log( delete window.a ); // true
console.log( window.a ); // undefined

var b = 2;
console.log( window.b ); // 2
console.log( delete window.b ); // false
console.log( window.b ); // 2
ログイン後にコピー

上記の質問から、2 つの違いがわかります。変数が var を使用して宣言されていない場合、その変数は delete キーワードを使用して削除できます。変数が var を使用して宣言された場合、値は再度取得されると未定義になります。 delete を使用して削除することはできず、取得しても値は 2 のままです。

1. 演算子を削除します

delete を使用して変数または属性を削除すると、削除が成功した場合は true が返され、そうでない場合は false が返されます。上記の例のように、delete で変数 a を削除できない場合は false が返され、delete で変数 b を正常に削除できた場合は true が返されます。

上記の 2 つの状況に加えて、delete で削除できる一般的に使用される変数と、削除できない変数が他にもあります。 delete がそのような結果を生成する理由については心配しないでください。ここでは、その戻り値だけを見てみましょう:

削除配列内の要素を削除します:

// 使用for~in是循环不到的,直接忽略到该元素
// 使用for()可以得到该元素,但是值是undefined
var arr = [1, 2, 3, 4];
console.log( arr );     	// [1, 2, 3, 4]
console.log( delete arr[2] );	// true,删除成功
console.log( arr );      	// [1, 2, undefined, 4]
ログイン後にコピー

関数型変数の削除:

// chrome 不能删除;火狐可以删除
function func(){
}
console.log( func );
console.log( delete func );
console.log( func );
ログイン後にコピー

取得した仮パラメータの数である function.length を削除します:

function func1(a, b){
}
console.log( func1.length );   	// 2
console.log( delete func1.length );	// true,删除成功
console.log( func1.length );   	// 0
ログイン後にコピー

よく使用される変数を削除します:

console.log( delete NaN );  	// false,删除失败
console.log( delete undefined );// false
console.log( delete Infinity );	// false
console.log( delete null );  	// true,删除成功
ログイン後にコピー

プロトタイプの属性を削除するのではなく、プロトタイプを削除します:

function Person(){
}
Person.prototype.name = "蚊子";
console.log( delete Person.prototype );	// false,无法删除
console.log( delete Object.prototype );	// false
ログイン後にコピー

配列や文字列の長さを削除する場合:

var arr = [1, 2, 3, 4];
console.log( arr.length );    	// 4
console.log( delete arr.length ); 	// false,删除失败
console.log( arr.length );    	// 4

var str = 'abcdefg';
console.log( str.length );    	// 7
console.log( delete str.length ); 	// false,删除失败
console.log( str.length );    	// 7
ログイン後にコピー

obj の属性を削除する場合:

var obj = {name:'wenzi', age:25};
console.log( obj.name );   	// wenzi
console.log( delete obj.name );	// true,删除成功
console.log( obj.name );   	// undefined
console.log( obj );      	// { age:25 }
ログイン後にコピー

インスタンス オブジェクトの属性を削除する場合、次の出力からわかるように、delete を使用して属性を削除すると、インスタンス オブジェクト自体の属性のみが削除され、プロトタイプの属性は削除できないことがわかります。再度削除しても削除されません。プロトタイプの属性または属性のメソッドを削除する場合は、delete Person.prototype.name:

のみを削除できます。
function Person(){
  this.name = 'wenzi';
}
Person.prototype.name = '蚊子';
var student = new Person();
console.log( student.name );    // wenzi
console.log( delete student.name ); // true,删除成功
console.log( student.name );    // 蚊子
console.log( delete student.name ); // true
console.log( student.name );    // 蚊子
console.log( delete Person.prototype.name );// true,删除成功
console.log( student.name );    // undefined
ログイン後にコピー

2. js の内部プロパティ

上記の例では、一部の変数または属性は正常に削除できますが、他の変数または属性は削除できないということになります。

ECMA-262 第 5 版は、JS オブジェクト プロパティ (JS エンジンで使用され、外部から直接アクセスできない) の特性を定義します。 ECMAScript には、データ プロパティとアクセサー プロパティの 2 種類のプロパティがあります。

2.1 データ属性

データ属性は、値の読み取りまたは書き込みが可能なデータ値を含む場所を指します。この属性には、その動作を説明する 4 つのプロパティがあります。

    [[configurable]]: delete 演算子を使用して削除および再定義できるかどうか、またはアクセサー属性として変更できるかどうかを示します。デフォルトは true です。
  • [[Enumberable]]: for-in ループを通じて属性を返すことができるかどうかを示します。デフォルトは true;
  • [[Writable]]: 属性の値を変更できるかどうかを示します。デフォルトは true;
  • [[Value]]: この属性のデータ値が含まれます。この値は読み取り/書き込み可能です。デフォルトは未定義です。たとえば、name 属性は上記のインスタンス オブジェクト Person で定義されており、その値は 'wenzi' になります。この値は
  • で変更されます。
オブジェクト プロパティのデフォルト特性 (デフォルトは true) を変更するには、Object.defineProperty() メソッドを呼び出すことができます。このメソッドは、プロパティが配置されているオブジェクト、プロパティ名、記述子オブジェクトの 3 つのパラメータを受け取ります (構成可能、番号付け可能、書き込み可能、​​値、1 つ以上の値を設定できる必要があります)。

は次のとおりです:

var person = {};
Object.defineProperty(person, 'name', {
  configurable: false,	// 不可删除,且不能修改为访问器属性
  writable: false,		// 不可修改
  value: 'wenzi'			// name的值为wenzi
});
console.log( person.name);			// wenzi
console.log( delete person.name );	// false,无法删除
person.name = 'lily';
console.log( person.name );			// wenzi
ログイン後にコピー
person.name の値は削除もリセットも有効ではないことがわかります。これは、defineProperty 関数を呼び出すとオブジェクトのプロパティの特性が変更されるためです。configurable が false に設定されると、defineProperty が変更できることに注意してください。 true に変更するためには使用されなくなりました (実行すると、次のエラーが報告されます: Uncaught TypeError: Cannot redefine property: name);

2.2 アクセサーのプロパティ

これには主にゲッター関数とセッター関数のペアが含まれています。アクセサー属性を読み取るときはゲッターが呼び出され、有効な値が返されます。アクセサー属性が書き込まれるときは、セッターが呼び出され、新しい値が書き込まれます。属性には次の 4 つの特徴があります:

    [[Configurable]]: 削除演算子を使用して属性を削除および再定義できるかどうか。
  • [[Numberable]]: この属性が for-in ループで見つかるかどうか
  • [[Get]]: プロパティの読み取り時に自動的に呼び出されます、デフォルト: unknown;
  • [[Set]]: 属性を書き込むときに自動的に呼び出されます、デフォルト: 未定義;
  • アクセサー プロパティは直接定義できません。次のように、defineProperty() を使用して定義する必要があります。

var person = {
  _age: 18
};
Object.defineProperty(person, 'isAdult', {
	Configurable : false,
  get: function () {
    if (this._age >= 18) {
      return true;
    } else {
      return false;
    }
  }
});
console.log( person.isAdult ); // true
ログイン後にコピー
ただし、Object.defineProperty() メソッドでプロパティを設定する場合、アクセサー プロパティ (set および get) とデータ プロパティ (書き込み可能または値) を同時に宣言することはできません。これは、プロパティに書き込み可能属性または値属性セットがある場合、このプロパティは get または set を宣言できず、その逆も同様であることを意味します。

次のように定義すると、アクセサー プロパティとデータ プロパティが同時に存在します:

上面的代码看起来貌似是没有什么问题,但是真正执行时会报错,报错如下:

Uncaught TypeError: Invalid property. A property cannot both have accessors and be writable or have a value

对于数据属性,可以取得:configurable,enumberable,writable和value;

对于访问器属性,可以取得:configurable,enumberable,get和set。

由此我们可知:一个变量或属性是否可以被删除,是由其内部属性Configurable进行控制的,若Configurable为true,则该变量或属性可以被删除,否则不能被删除。

可是我们应该怎么获取这个Configurable值呢,总不能用delete试试能不能删除吧。有办法滴!!

2.3 获取内部属性

ES5为我们提供了Object.getOwnPropertyDescriptor(object, property)来获取内部属性。

如:

var person = {name:'wenzi'};
var desp = Object.getOwnPropertyDescriptor(person, 'name'); // person中的name属性
console.log( desp );	// {value: "wenzi", writable: true, enumerable: true, configurable: true}
ログイン後にコピー

通过Object.getOwnPropertyDescriptor(object, property)我们能够获取到4个内部属性,configurable控制着变量或属性是否可被删除。这个例子中,person.name的configurable是true,则说明是可以被删除的:

console.log( person.name );			// wenzi
console.log( delete person.name );	// true,删除成功
console.log( person.name );			// undefined
ログイン後にコピー

我们再回到最开始的那个面试题:

a = 1;
var desp = Object.getOwnPropertyDescriptor(window, 'a');
console.log( desp.configurable ); 	// true,可以删除

var b = 2;
var desp = Object.getOwnPropertyDescriptor(window, 'b');
console.log( desp.configurable ); 	// false,不能删除
ログイン後にコピー

跟我们使用delete操作删除变量时产生的结果是一样的。

3. 总结

别看一个简简单单的delete操作,里面其实包含了很多的原理!

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

キーボードの削除キーとは何ですか? キーボードの削除キーとは何ですか? Mar 16, 2023 pm 04:48 PM

キーボードの削除キーは、del (削除) キーとバックスペース キーの 2 つです。バックスペースはバックスペース キーとも呼ばれます。このキーはカーソルの前のテキスト コンテンツを削除でき、削除キーは文字、ファイル、選択したオブジェクトを削除できます。 Del キーを押すたびに、カーソルの右側の文字が削除され、カーソルの右側の文字が 1 フレーム左に移動します。1 つ以上のファイル/フォルダが選択されている場合は、Del キーを押します。キーを押すとすぐに削除できます。一部のアプリケーションでは、プログラム内のオブジェクトを選択し、Del キーを押すと、選択したオブジェクトをすぐに削除できます。

削除キーの機能は何ですか 削除キーの機能は何ですか Mar 10, 2023 pm 06:07 PM

削除キーの機能は次のとおりです: 1. 文字の削除; 削除キーを押すたびに、カーソルの右側の文字が削除され、カーソルの右側の文字が 1 フレーム左に移動します。 2. ファイルを削除します。1 つ以上のファイル/フォルダーが選択されている場合は、Delete キーを押してそれらをすぐに削除します (回復のためにごみ箱に移動します)。 3. 選択したオブジェクトを削除します。一部のアプリケーションではオブジェクトを選択し、Delete キーを押すと、選択したオブジェクトがすぐに削除されます。

Control + Alt + Delete の方法: Mac チュートリアル Control + Alt + Delete の方法: Mac チュートリアル Apr 16, 2023 pm 12:37 PM

Control+Alt+Delete:「Mac」モード Ctrlaltdel は、Windows ユーザーがタスク マネージャーを開くために使用する一般的なキーの組み合わせです。通常、マネージャー メニューから不要なアプリケーションを終了して、コンピューター上のスペースを解放します。 Control+Alt+Delete Mac 版を使用すると、強制終了メニューを開くことができます。 Mac ユーザーが問題の原因となっているプログラムを終了したい場合、または開いているプログラムを表示したい場合は、メニューを操作してさらに調査することができます。 Mac で ControlAltDelete を実行するにはどうすればよいですか?正常に動作していないアプリケーションがある場合は、このキーの組み合わせを使用する必要があります。

削除されたファイルは復元できますか? 削除されたファイルは復元できますか? Feb 24, 2023 pm 03:49 PM

delete で削除されたファイルは復元できます。ユーザーが delete を使用してファイルを削除すると、これらのファイルはごみ箱に移動され、完全には削除されないためです。回復方法: 1. 「ごみ箱」を開き、復元したいファイルを選択し、「この項目を復元」をクリックします; 2. 「ごみ箱」を開き、復元したいファイルを選択し、元に戻すショートカットを使用します。 「ctrl+z」。できます。

jQueryでテーブル行を追加、編集、削除するにはどうすればよいですか? jQueryでテーブル行を追加、編集、削除するにはどうすればよいですか? Sep 05, 2023 pm 09:49 PM

今日の Web 開発時代では、特にデータ量の多い Web アプリケーションを扱う場合、効果的かつ効率的なテーブル管理が非常に重要になっています。テーブルの行を動的に追加、編集、削除できる機能により、ユーザー エクスペリエンスが大幅に向上し、アプリケーションがよりインタラクティブになります。これを達成する効果的な方法は、jQuery の機能を活用することです。 jQuery は、開発者が操作を実行するのに役立つ多くの機能を提供します。テーブルの行 テーブルの行は、相互に関連するデータのコレクションであり、HTML の要素で表されます。これは、テーブル内のセル (要素で表される) をグループ化するために使用されます。各要素はテーブル内の行を定義するために使用され、複数属性テーブルの場合、通常は 1 つ以上の要素が含まれます。構文$(セレクター).append(co

Linux コマンドにおける「!」演算子の 8 つの謎の使用法 Linux コマンドにおける「!」演算子の 8 つの謎の使用法 Jun 27, 2023 pm 12:51 PM

「!」記号を使用するほとんどの Linux コマンドの使用法は、シェルによって異なる場合があります。私が提供する例は通常 bash シェルで使用されますが、他の一部の Linux シェルでは実装が異なる場合や、「!」記号の特定の使用をまったくサポートしていない場合があります。 Linux コマンドにおける「!」記号の驚くべき謎に満ちた使い方を見てみましょう。 1. コマンド番号を使用して履歴からコマンドを実行する あまり知られていないかもしれませんが、コマンド履歴 (すでに実行されたコマンド) からコマンドを実行できます。まず、「history」コマンドを実行してコマンドの番号を見つけます。 linuxmi@linuxmi:~/www.linuxmi.

SpringBoot で PUT リクエストと Delete リクエストを使用する方法 SpringBoot で PUT リクエストと Delete リクエストを使用する方法 May 13, 2023 pm 12:16 PM

PUT リクエストと Delete リクエストは Form フォームで使用され、get メソッドと post メソッドのみをサポートします。put メソッドを実装するには、次の 3 つの手順で実装できます: 1) SpringMVC で HiddenHttpMethodFilter を設定する 2) 上に投稿フォームを作成する3ページ目) 指定したリクエストメソッドを値として名前「_method」という入力項目を作成し、HiddenHttpMethodFilterクラスの「_method」の値を取得して新しいリクエストメソッドを取得します。番目のタグは thymeleaf テンプレートです。これは、従業員が

データベース削除の使い方 データベース削除の使い方 Nov 13, 2023 am 11:50 AM

データベース削除の使用法: 1. 単一レコードの削除; 2. 複数のレコードの削除; 3. すべてのレコードの削除; 4. 特定の条件下でのレコードの削除。

See all articles