jquery源码解析----对象的创建
2016-09-12 13:55
295 查看
//jquery源码解析
对象的构建
面向对象的语言都有一个特点,他们都会有类这一个概念,通过类可以抽象出创建具体
相同方法与属性的对象,但是ECMAScript中是没有类的概念的,因此它的对象与基于类
的语言如java的定义是有所不同的。
在javascript世界中函数作为"一等公民",它不仅拥有一切传统函数的使用方式,而且
可以做到像简单值一样赋值、传参、返回,这样的函数也称之为第一级函数。不仅如此,
而且还可以通过操作符new来充当类的构造器。
函数在充当类构造器的时候,原型prototype是一个重要的概念。protopye是构造函数的
一个属性,该属性指向一个对象。而这个对象作为该构造函数所创建的所有实例的基引用,
可以把对象的基引用想象成一个自动创建的隐藏属性。当访问对象的一个属性的时候,
首先查找对象本身,找到则返回。若不,则查找基引用指向的对象的属性。
类一:
function ajQuery() {
this.name = 'jQuery';
this.sayName = function(){
return this.name
}
var a = new ajQuery()
var b = new ajQuery()
var c = new ajQuery()
类二:
function ajQuery() {
this.name = 'jQuery'
}
ajQuery.prototype = {
sayName: function() {
return this.name
}
}
var a = new ajQuery()
var b = new ajQuery()
var c = new ajQuery()
类一与类二产生的结构几乎是一样的,而本质区别就是:类二new产生的a、b、c三个实例对象共享了原型的sayName方法,这样的好处节省了内存空间,类一则是要为每一个实例复制sayName方法,每个方法属性都占用一定的内存的空间,所以如果把所有属性方法都声明在构造函数中,就会无形的增大很多开销,这些实例化的对象的属性一模一样,都是对this的引用来处理。除此之外类一的所有方法都是拷贝到当前实例对象上。类二则是要通过scope连接到原型链上查找,这样就无形之中要多一层作用域链的查找了。
对象的构建
面向对象的语言都有一个特点,他们都会有类这一个概念,通过类可以抽象出创建具体
相同方法与属性的对象,但是ECMAScript中是没有类的概念的,因此它的对象与基于类
的语言如java的定义是有所不同的。
在javascript世界中函数作为"一等公民",它不仅拥有一切传统函数的使用方式,而且
可以做到像简单值一样赋值、传参、返回,这样的函数也称之为第一级函数。不仅如此,
而且还可以通过操作符new来充当类的构造器。
函数在充当类构造器的时候,原型prototype是一个重要的概念。protopye是构造函数的
一个属性,该属性指向一个对象。而这个对象作为该构造函数所创建的所有实例的基引用,
可以把对象的基引用想象成一个自动创建的隐藏属性。当访问对象的一个属性的时候,
首先查找对象本身,找到则返回。若不,则查找基引用指向的对象的属性。
类一:
function ajQuery() {
this.name = 'jQuery';
this.sayName = function(){
return this.name
}
var a = new ajQuery()
var b = new ajQuery()
var c = new ajQuery()
类二:
function ajQuery() {
this.name = 'jQuery'
}
ajQuery.prototype = {
sayName: function() {
return this.name
}
}
var a = new ajQuery()
var b = new ajQuery()
var c = new ajQuery()
类一与类二产生的结构几乎是一样的,而本质区别就是:类二new产生的a、b、c三个实例对象共享了原型的sayName方法,这样的好处节省了内存空间,类一则是要为每一个实例复制sayName方法,每个方法属性都占用一定的内存的空间,所以如果把所有属性方法都声明在构造函数中,就会无形的增大很多开销,这些实例化的对象的属性一模一样,都是对this的引用来处理。除此之外类一的所有方法都是拷贝到当前实例对象上。类二则是要通过scope连接到原型链上查找,这样就无形之中要多一层作用域链的查找了。
相关文章推荐
- jQuery源码解析--对象创建
- JQuery源码解析-- 对象的创建
- jquery源码解析:jQuery延迟对象Deferred(工具方法)详解1
- JQuery源码之“对象的结构解析”
- 源码-JavaScript&jQuery交互式前端开发-第3章-函数、方法与对象-使用字面量语法创建对象
- jquery源码解析:jQuery延迟对象Deferred(工具方法)详解2
- jQuery源码学习之对象创建与初始化
- jquery源码解析:val方法和valHooks对象详解
- jQuery源码学习之对象创建与初始化
- jQuery源码之创建jQuery对象
- 献给和我合作的过得前端童靴们:jquery源码分析--核心函数(创建jquery空对象)
- jQuery深入之源码解析(三)——构造jQuery对象
- 源码-JavaScript&jQuery交互式前端开发-第3章-函数、方法与对象-使用构造函数语法创建对象
- 献给和我合作的过得前端童靴们:jquery源码分析--核心函数(使用函数作为参数创建jQuery对象)
- jQuery源码学习:使用隐藏的new来创建对象
- jquery 1.7.2源码解析(二)构造jquery对象
- jquery源码解析:jQuery静态属性对象support详解
- jQuery源码分析以及从jQuery对象创建的角度理解extend方法的原理
- Javascript笔记:jQuery源码分析以及从jQuery对象创建的角度理解extend方法的原理
- JQuery源码解析---jQuery回调对象