ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JS的封装(JS插件的封装)

2019-05-24 10:52:45  阅读:229  来源: 互联网

标签:插件 prototype console log Cat cat1 实例 封装 JS


JS中类的概念
类,实际上就是一个function,同时也是这个类的构造方法,new创建该类的实例,new出的对象有属性有方法。
方法也是一种特殊的对象。


类的方法
在构造方法中初始化实例的方法(就是在构造方法中直接编写方法,并new实例化)是不推荐的,消耗内存(每次实例化的时候都是重复的内容,多占用一些内存,既不环保,也缺乏效率)。
所有实例是共有的,创建多个实例不会产生新的function,推荐在类的prototype中定义实例的方法,
prototype中的方法会被所有实例公用。

1. 仿照jQuery封装类
匿名函数

复制代码
(function () {
    //
})();

var Id = function (i) {
  this.id = document.getElementById(i);
};
window.$ = function (i) {
  return new Id(i);
};

console.log($('main'));
复制代码 复制代码
function Cat(name, color) {
  this.name = name;
  this.color = color;
}

var cat1 = new Cat('大毛', '黄色');
var cat2 = new Cat('二毛', '黑色');

Cat.prototype.a = 'aaa';
Cat.prototype.type = '猫科动物';
Cat.prototype.eat = function () {
  alert('吃老鼠');
};

cat1.eat();
cat2.eat();

console.log(cat1.name);
console.log(cat2.color);

// cat1和cat2会自动含有一个constructor属性,指向它们的构造函数。
console.log(cat1.constructor == Cat);
console.log(cat2.constructor == Cat);

// Javascript还提供了一个instanceof运算符,验证原型对象与实例对象之间的关系。
console.log(cat1 instanceof Cat);
try {
  console.log(a instanceof Cat);
} catch (e) {
  console.log(e);
}
复制代码


所谓"构造函数",其实就是一个普通函数,但是内部使用了this变量。对构造函数使用new运算符,就能生成实例,并且this变量会绑定在实例对象上。
Javascript规定,每一个构造函数都有一个prototype属性,指向另一个对象。这个对象的所有属性和方法,都会被构造函数的实例继承。


prototype模式的验证方法
1. isPrototypeOf() 判断某个prototype对象和某个实例之间的关系
2. hasOwnProperty() 判断一个属性是本地属性还是继承自prototype对象的属性
3. in 判断是否在某个对象里

复制代码
function Cat(name, color) {
  this.name = name;
  this.color = color;
}

Cat.prototype.type = '猫科动物';

var cat1 = new Cat('大毛', '黄色');
var cat2 = new Cat('二毛', '黑色');

console.log(Cat.prototype.isPrototypeOf(cat1));
console.log(Cat.prototype.isPrototypeOf(cat2));

console.log(cat1.hasOwnProperty('name'));
console.log(cat2.hasOwnProperty('type'));

console.log('name' in cat1);
console.log('type' in cat1);
复制代码

 

 

未完:构造函数的继承:http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_inheritance.html
非构造函数的继承:http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_inheritance_continued.html

标签:插件,prototype,console,log,Cat,cat1,实例,封装,JS
来源: https://www.cnblogs.com/shaozhu520/p/10916689.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有