Heim > Web-Frontend > js-Tutorial > Hauptteil

Was ist ein JS-Objekt? Einführung in js-Objekte (mit Code)

不言
Freigeben: 2018-08-14 09:55:40
Original
3263 Leute haben es durchsucht

In diesem Artikel erfahren Sie, was ein JS-Objekt ist. Die Einführung von js-Objekten (mit Code) hat einen gewissen Referenzwert. Freunde in Not können darauf verweisen.

Was ist ein Objekt?

In JavaScript ist ein Objekt wie eine Entität mit separaten Eigenschaften und Typen. Eine Tasse ist ein Objekt und die Tasse hat Attribute wie Farbe und Gewicht. Ebenso verfügt ein JavaScript-Objekt über Eigenschaften, die seine Eigenschaften definieren.
Eine Methode ist eine Funktion, die einem Objekt zugeordnet ist, oder mit anderen Worten, eine Methode ist eine Objekteigenschaft, deren Wert eine Funktion ist.
Objekte können in die folgenden Kategorien unterteilt werden

  • Eingebaute Objekte/native Objekte

sind vordefinierte Objekte in der JavaScript-Sprache

  • Hostobjekt

ist ein Objekt, das von der JavaScript-Laufumgebung bereitgestellt wird

  • Benutzerdefiniertes Objekt

ist ein vom Entwickler unabhängig erstelltes Objekt

Objektobjekt

Der Objekttyp ist ein Referenztyp. Aber der Objekttyp ist das übergeordnete Element aller Typen in JavaScript (alle Objekttypen können Eigenschaften und Methoden von Objekt sein).

Objekte erstellen

/*
* 1. 对象的初始化器创建方式
*     var 对象名={
*      属性名 : 属性值
*      方法名 : function{
*         方法体
*      }
*    }
*/
var obj = {
    name : '九筒',
    age : 2,
    sayYou : function () {
        console.log('火锅')
    }
};

/* 2. 对象的构造函数方式
*      * 利用所有的引用类型创建对应的对象->具有具体的类型
*        var num = new Number;//number类型
*        var str = new String;//string类型
*        var boo = new Boolean;//boolean类型
*      * 利用Object作为构造函数创建对象
*        var 对象名 = new Object();
*        var 对象名 = Object();
*/
var num = new Number();
var str = new Storage();
var boo = new Boolean();

var obj2 = new Object();
var obj3 = Object();

/*   利用Object.create创建对象
*      var 对象名 = Object.create(null) -> 创建一个空对象
      var 对象名 = Object.create(obj)
      * obj - 表示另一个对象
      * 特点 - 当前创建的新对象拥有与obj对象相同的属性和方法*/
var obj4 = Object.create(null);
var obj5 = Object.create(obj);
Nach dem Login kopieren

Eigenschaften von Objekten

Definieren die Eigenschaften eines Objekts

Die Eigenschaften eines Objekts sind wie Variablen, die an das Objekt angehängt sind

/*对象介意定义多个属性
*  属性之间使用逗号分开*/
var obj = {
    name : '吴凡',
    age : 23,
    book : function () {
        console.log('暗毁')
    }
};
Nach dem Login kopieren

Eigenschaften des Objekts aufrufen

/*  调用对象的属性
*     对象名.属性名
*     不适用于复杂命名的属性名称*/
console.log(obj.name);

/*   对象名[属性名]-通用方式
     适用于复杂命名的属性名称
*     */
console.log(obj['name']);//属性名是字符串形式
Nach dem Login kopieren

Hinzufügen, löschen und ändern Eigenschaften des Objekts

var obj = {
    name : '火锅',
    variety : '比熊',
    age : function () {
        console.log('3')
    }
}
   /* 新增对象的属性
   *    1对象名.新的属性名 = 属性值
   *    2对象名[新的属性名] = 属性值*/
obj.col='白色';
console.log(obj.col);//白色

   /*删除对象的属性
   * delete 对象名.属性名
   * delete 对象名[属性名]*/
delete obj.col
console.log(obj.col);//undefined

  /*修改对象的属性
  * 对象名.已存在的属性名 = 属性值
  * 对象名[已存在的属性名] = 属性值*/
obj.name = '九筒';
console.log(obj.name);//九筒
Nach dem Login kopieren

Eigenschaften von Objekten erkennen

var obj = {
    name : '火锅',
    variety : '比熊',
    age : function () {
        console.log('3')
    }
};
console.log(obj.name)

/*   1. 判断对象的属性值是否为undefined*/
if (obj.name !==undefined){
    console.log('obj对象name属性存在')
}else{
    console.log('obj对象name属性不存在')
}

/*   2. 判断对象的属性值,先转换为boolean类型*/
if (obj.name){
    console.log('obj对象name属性存在')
}

/*   3. 利用in关键字进行判断*/
if ('name' in obj){
    console.log('obj对象name属性存在')
}else{
    console.log('obj对象name属性不存在')
}

/*   4. Object类型提供了hasOwnProperty()方法*/
if (obj.hasOwnProperty('name')){
    console.log('obj对象name属性存在')
}else{
    console.log('obj对象name属性不存在')
}
Nach dem Login kopieren

Komfortattribute

var obj = {
    name : '小薄荷',
    age : '0.3',
    variety : function () {
        console.log('萨摩耶')
    }
};
// 1.for...in语句
for (var objAttr in obj) {
    // 通过对象属性或方法对应的值的类型进行区别
    if (obj[objAttr] instanceof Function) {
        // 当前是对象的方法
        obj[objAttr]();
    } else {
        // 当前是对象的属性
        console.log(obj[objAttr]);
    }
}

// 2.Object类型提供了keys()方法 - 只能遍历可枚举的属性
var arr = Object.keys(obj);
for (var v in arr) {
    var objAttr = arr[v];
    // 通过对象属性或方法对应的值的类型进行区别
    if (obj[objAttr] instanceof Function) {
        // 当前是对象的方法
        obj[objAttr]();
    } else {
        // 当前是对象的属性
        console.log(obj[objAttr]);
    }
}

// 3.Object类型提供了getOwnPropertyNames()方法 - 包括不可枚举的属性
var arr = Object.getOwnPropertyNames(obj);
for (var v in arr) {
    var objAttr = arr[v];
    // 通过对象属性或方法对应的值的类型进行区别
    if (obj[objAttr] instanceof Function) {
        // 当前是对象的方法
        obj[objAttr]();
    } else {
        // 当前是对象的属性
        console.log(obj[objAttr]);
    }
}
Nach dem Login kopieren

Methoden von Objekten

Methoden zum Aufrufen, Hinzufügen, Ändern und Objekte löschen

Die Methoden und Attribute zum Aufrufen, Hinzufügen, Ändern und Löschen von Objekten sind grundsätzlich gleich

var obj = {
    name : '火锅',
    variety : '比熊',
    age : function () {
        console.log('3')
    }
}

/*调用对象的方法*/
// 1.对象名.方法名()
obj.sayMe();
// 2.对象名[方法名]()
obj['sayMe']();

/*新增对象的方法*/
// 1.对象名.新的方法名 = function(){}
obj.name = function(){
    console.log('九筒');
}
console.log(obj);
// 2.对象名[新的方法名] = function(){}

/*修改对象的方法*/
// 1.对象名.方法名 = function(){}
obj.name = function(){
    console.log('九筒');
}
// 2.对象名[方法名] = function(){}

/*删除对象的方法*/
//1.delete 对象名.方法名
delete obj.sayMe;
// 访问对象中不存在的方法 -> 报错(TypeError: obj.sayMe is not a function)
// obj.sayMe();
// 2.delete 对象名[方法名]
Nach dem Login kopieren

Verwandte Empfehlungen:

Eine Zusammenfassung der Zeichenmethoden und String-Manipulationsmethoden in js (mit Code)

Analyse häufiger Probleme in http-proxy, der http-Proxy-Bibliothek in nodejs

Das obige ist der detaillierte Inhalt vonWas ist ein JS-Objekt? Einführung in js-Objekte (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!