//创建构造函数,它和普通函数是一样的,不同的是习惯上首字母大写
// 调用方式不同: 普通函数直接调用,而构造函数需要使用new关键字来调用
//构造函数执行流程: 也将一个构造函数称为一个类
/*1.调用构造函数时立即创建一个新的对象
2.将新建的对象设置为函数中的this,在构造函数中可以使用this来引用新建的对象
3.逐行执行函数中的代码
4.将新创建的对象作为返回值返回
*/
function Person(){
this.name = "孙悟空";
this.age = 10;
this.sayName = function (){//将方法写在构造函数内,构造函数执行一次就会创建一个新的sayName方法,
//也就是所有实例的sayName方法都是唯一的 可以将这个方法定义在全局作用域中
alert(this.age);//
};
}
/
var person = new Person();
person.name = "dsjd";
//person.sayName();//直接出来10
//alert(person.sayName());//10,还有undefined
function Dog(name,age){
this.name = name;
this.age= 19;
this.sayName =fun;
}
//将sayName方法提取出来,就不会导致每创建一个实例就创建一个构造函数
function fun(){ //但这样全局作用域中的函数就会很多,而且还不能和这个函数重名,否则会覆盖这个函数,这也是构造函数的缺点, 人们也就采用了原型
alert(this.name);
};
var dog1 = new Dog("小狗",10);
//dog1.sayName(); //小狗
//dog1.sayName; //什么也不会显示