博客地址地址
今天开启我的专栏第一篇,接下来的日子,将和大家谈论一下JavaScript一些事情,
我慢慢发现你想实习面向对象编程,你得对原型链比较熟悉,对于this指向也要比较熟悉,才能更好,将代码进行高度抽象起来
1.0 面向对象概念
1.1 面向对象和面向过程的区别
面向过程
:我们在刚刚初学JavaScript时候,我们要复用一个方法,就想这个方法写成一个函数,然后在需要用到的时候,进行调用
面向对象
:把构成问题事务分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描叙某个事物在整个解决问题的步骤中的行为。
知乎有一个关于面向对象去吧的回答
摇狗尾巴和狗摇尾巴的区别
面向过程的解决方法
在面向过程的编程方式中实现“把大象放冰箱”这个问题答案是耳熟能详的,一共分三步:
开门(冰箱);
装进(冰箱,大象);
关门(冰箱)。
面向对象的解决方法
冰箱.开门()
冰箱.装进(大象)
冰箱.关门()
2.0 实现面向对象方法
这里我们讨论几个主要的实现面向对象方法
2.1 工厂模式
何为工厂模式,
function Person(name,age,sex){
var obj = {};
obj.name = name;
obj.age=age;
obj.sex=sex;
return obj;
}
let person1 = Person('夏夏',18,'男')
console.log(person1)
其实上面还有这么写
function Person(name,age,sex){
var obj = {};
obj.name = name;
obj.age = age;
obj.sex =sex;
}
let person2 = new Person('我是有new',18,'男')
2.2 构造函数
JavaScript中new可以让函数变的与众不同
function demo() {
console.log(this);
}
demo(); // window
new demo(); // demo
关于构造函数,如果你暂时不能够理解new的具体实现,就先记住下面这几个结论吧。
与普通函数相比,构造函数并没有任何特别的地方,首字母大写只是我们约定的小规定,用于区分普通函数;
new关键字让构造函数具有了与普通函数不同的许多特点,而new的过程中,执行了如下过程:
声明一个中间对象;
- 将该中间对象的原型指向构造函数的原型;
- 将构造函数的this,指向该中间对象;
- 返回该中间对象,即返回实例对象。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。