JavaScript创建对象的一系列方式及全局对象window

简介: JavaScript创建对象的一系列方式及全局对象window

image.png


创建对象的三种方式


无脑创建


// 一系列的学生对象
var stu1 = {
  name: "bajie",
  age: 18,
  height: 1.88,
  running: function() {
    console.log("running~")
  }
}
var stu2 = {
  name: "kobe",
  age: 30,
  height: 1.98,
  running: function() {
    console.log("running~")
  }
}
var stu3 = {
  name: "james",
  age: 25,
  height: 2.05,
  running: function() {
    console.log("running~")
  }
}


工厂函数


// 工厂函数(工厂生产student对象) -> 一种设计模式
// 通过工厂设计模式, 自己来定义了一个这样的函数
function createStudent(name, age, height) {
  var stu = {}
  stu.name = name
  stu.age = age
  stu.height = height
  stu.running = function() {
    console.log("running~")
  }
  return stu
}
var stu1 = createStudent("bajie", 18, 1.88)
var stu2 = createStudent("kobe", 30, 1.98)
var stu3 = createStudent("james", 25, 2.05)
console.log(stu1)
console.log(stu2)
console.log(stu3)


构造函数 + new 关键字


// JavaScript已经默认提供给了我们可以更加符合JavaScript思维方式(面向对象的思维方式)的一种创建对象的规则
// 在函数中的this一般指向某一个对象
/*
  如果一个函数被new操作符调用
    1.创建出来一个新的空对象
    2.让this指向这个空对象
    3.执行函数体的代码块
    4.如果没有明确的返回一个非空对象, 那么this指向的对象会自动返回
*/
function Coder(name, age, height) {
  this.name = name
  this.age = age
  this.height = height
  // 构造函数中的方法称为类方法
  this.running = function() {
    console.log("running~")
  }
}
// 在函数调用的前面加 new 关键字(操作符)
var stu1 = new Coder("bajie", 18, 1.88)
var stu2 = new Coder("kobe", 30, 1.98)
console.log(stu1, stu2)


  • 注意点:构造函数的名称使用大驼峰,普通函数使用小驼峰
  • 函数本身也是对象


全局对象 window


// 浏览器中存在一个全局对象object -> window
// 作用一: 查找变量时, 最终会找到window头上
// 作用二: 将一些浏览器全局提供给我们的变量/函数/对象, 放在window对象上面
// 作用三(了解): 使用var定义的变量会被默认添加到window上面(除了函数里的用var定义的)
console.log(window)
// 使用var定义变量
var message = "Hello World"
function foo() {
  // 自己的作用域
  // abc()
  // alert("Hello World")
  console.log(window.console === console)
  // 创建一个对象
  // var obj = new Object()
  console.log(window.Object === Object)
  // DOM
  console.log(document)
  // window.message
  console.log(window.message)
}
foo()


目录
打赏
0
0
0
0
1
分享
相关文章
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
35 1
JavaScript中对象的数据拷贝
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
66 1
js中函数、方法、对象的区别
js中函数、方法、对象的区别
40 2
Node.js 全局对象
10月更文挑战第5天
52 2
JavaScript Window Navigator
JavaScript Window Navigator
39 2

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等