JS 之 操作 Object 对象

目录

Object - JavaScript | MDN

一. 对象的使用

二. 对象的创建方式

1 - 对象字面量

2 - 构造函数

3 - 类创建 

三. 对象的操作

1 - 定义

2 - 访问对象属性 

3 - 修改对象属性

扫描二维码关注公众号,回复: 14379956 查看本文章

4 - 增加对象属性 

5 - 删除对象属性 

四. 对象的方括号 [] 使用法

五. 对象的遍历 

1 - 普通for循环

2 - for ... in ...

3 - 后续慢慢更新~

六. 对象的内存分配

1 - 面试题一

2 - 面试题二

3 - 面试题三

4 - 面试题四

5 - 面试题五

七. 创建一系列对象的方式

1 - 一个一个写

2 - 通过for循环写

3 - 通过工厂函数 

4 - 通过new操作符来创建


Object - JavaScript | MDN

一. 对象的使用

  • key: 字符串类型, 但是在定义对象的属性名时, 大部分情况下引号都是可以省略的
  • value : 可以是任意值
const person = {
  name: 'why',
  age: 18,
  height: 1.88,
  // 这种的就要加上''号
  'my friend': {
    name: 'kobe',
    age: 30
  },
  run: function () {
    console.log('running');
  },
  eat: function () {
    console.log('eat foods');
  },
};

二. 对象的创建方式

1 - 对象字面量

// 直接花括号赋值即可,用的最多
const obj1 = {
   name: "why"
}

2 - 构造函数

// 当函数被new关键词调用时,该函数就被称为构造函数
const obj = new Object()
obj.name = "star"
obj2.runing = function(){}

3 - 类创建 

class Person {
  constructor(name) {
    this.name = name;
  }
}
const stu = new Person('star');

三. 对象的操作

1 - 定义

const info = {
  name: "star",
  age: 18,
  friend: {
    name: "coder",
    age: 30
  },
  running: function() {
    console.log("running~")
  }
}

2 - 访问对象属性 

console.log(info.name)
console.log(info.friend.name)
info.running()

3 - 修改对象属性

info.age = 25
info.running = function() {
  alert("I am running~")
}
console.log(info.age)
info.running()

4 - 增加对象属性 

info.height = 1.88
info.studying = function() {
  console.log("I am studying~")
}

5 - 删除对象属性 

delete info.age
delete info.height

四. 对象的方括号 [] 使用法

const obj = {
  name: "why",
  "my friend": "kobe",
  "eating something": function() {
    console.log("eating~")
  }
}

// 这里 . 语法不能用
console.log(obj["my friend"])

console.log(obj.name)
// 这和 . 语法一个意思
console.log(obj["name"])

// 用变量的值充当对象的key
var eatKey = "eating something"
obj[eatKey]()

// 可连在一起使用
obj["eating something"]()

五. 对象的遍历 

1 - 普通for循环

// Object.keys() => 拿到对象的所有key
const infoKeys = Object.keys(info)
for (let i = 0; i < infoKeys.length; i++) {
  // 拿到key的值
  let key = infoKeys[i]
  // 拿到value的值
  let value = info[key]
  console.log(`key: ${key}, value: ${value}`)
}

2 - for ... in ...

// 可直接拿到对象的key
for (let key in info) {
  let value = info[key]
  console.log(`key: ${key}, value: ${value}`)
}

3 - 后续慢慢更新~

六. 对象的内存分配

js代码可以运行在浏览器,也可运行在node环境,无论是什么环境,最终都是运行在内存中

内存会映射在真实的电脑物理内存中,所以内存越大,跑的速度越快~~~

  • 基本类型 : 存储在内存中的栈内存
  • 引用类型 : 存储在内存中的堆内存

1 - 面试题一

const obj1 = {}
const obj2 = {}
console.log(obj1 === obj2) // false

2 - 面试题二

const info = {
  name: "why",
  friend: {
    name: "kobe"
  }
}

const friend = info.friend
friend.name = "james"
console.log(info.friend.name) // james

3 - 面试题三

function foo(a) {
  a = 200
}
const num = 100
foo(num)
console.log(num) // 100

4 - 面试题四

function foo(a) {
  a = {
    name: "star"
  }
}
const obj = {
  name: "obj"
}
foo(obj)
console.log(obj) //{ name:obj }

5 - 面试题五

function foo(a) {
  a.name = "star"
}

const obj = {
  name: "obj"
}
foo(obj)
console.log(obj) // {name : star}

七. 创建一系列对象的方式

1 - 一个一个写

有点小蠢~

const stu1 = {
  name: 'star',
  age: 16,
  height: 1.66,
  running: function () {
    console.log('running~');
  }
};
const stu2 = {
  name: 'coder',
  age: 17,
  height: 1.77,
  running: function () {
    console.log('running~');
  }
};
const stu3 = {
  name: 'liuli',
  age: 18,
  height: 1.88,
  running: function () {
    console.log('running~');
  }
};

2 - 通过for循环写

还是有点蠢~

const nameArr = ['star', 'coder', 'liuli'];
const ageArr = [16, 17, 18];
const heightArr = [1.66, 1.77, 1.88];
const funcs = {
  running: function () {
    console.log('running~');
  }
};

for (let i = 0; i < nameArr.length; i++) {
  let stu = {
    name: nameArr[i],
    age: ageArr[i],
    height: heightArr[i],
    running: funcs.running
  };
  console.log(stu); //{name: 'star', age: 16, height: 1.66, running: ƒ} ...
}

3 - 通过工厂函数 

// 工厂函数(工厂生产student对象) -> 一种设计模式
// 通过工厂设计模式, 自己来定义了一个这样的函数
function createStudent(name, age, height) {
  const stu = {};
  stu.name = name;
  stu.age = age;
  stu.height = height;
  stu.running = function () {
    console.log('running~');
  };
  return stu;
}

const stu1 = createStudent('stare', 16, 1.66);
const stu2 = createStudent('coder', 17, 1.77);
const stu3 = createStudent('liuli', 18, 1.88);
console.log(stu1);
console.log(stu2);
console.log(stu3);

弊端 :  拿到的数据的类型都是Object类型

4 - 通过new操作符来创建

简单理解下构造函数

// JavaScript已经默认提供给了我们可以更加符合JavaScript思维方式(面向对象的思维方式)的一种创建对象的规则
// 在函数中的this一般指向某一个对象
/*
  如果一个函数被new操作符调用
    1.创建出来一个新的空对象
    2.这个对象的 __proto__ 指向构造函数的 prototype
    3.让this指向这个空对象
    4.执行函数体的代码块
    5.如果没有明确的返回一个非空对象, 那么this指向的对象会自动返回
*/
function Coder(name, age, height) {
  //  相当于new操作符做了
  //  let obj = {}
  //  this = obj
  this.name = name
  this.age = age
  this.height = height
  this.running = function() {
    console.log("running~")
  }
  // return this
}

// 在函数调用的前面加 new 关键字(操作符)
const stu1 = new coder("why", 18, 1.88)
const stu2 = new coder("kobe", 30, 1.98)
console.log(stu1, stu2)

猜你喜欢

转载自blog.csdn.net/a15297701931/article/details/125828659