Class 类
在javascript 中应用类的概念
// javascript web applications 富应用开发 // 类库:生成类的地方;给所有的构造函数提供基础方法,如 extend, include...
var Class = function () { var klass = function () { // 实例化对象时立即运行init函数
this.init.apply(this, arguments);
}; klass.prototype.init = function () {}; // 定义 prototype 的别名
klass.fn = klass.prototype; // 给类添加属性
klass.extend = function (obj) {
var prop;
for (prop in obj) {
klass[prop] = obj[prop];
}
}; // 给实例添加属性
klass.include = function (obj) {
var prop;
for (prop in obj) {
klass.fn[prop] = obj[prop];
}
}; return klass; // 仍然返回一个类
}; // new 一个类
var Person = new Class(); /*
* 初始化方法(生成实例的时候一定会运行的方法)
*
* 等同于:
*
* var Person = function (name) {
* this.name = name;
* };
*/
Person.prototype.init = function (name) {
this.name = name;
}; // 原型方法
Person.include({
say: function () {
console.log(this.name + " say hello to everyone!");
}
}); var person = new Person("Davi"); person.say(); // Davi say hello to everyone!
用 backboon.js 实现类
/*
* <script src="js/underscore-1.6.0.js"><\/script>
* <script src="js/backbone-1.1.2.js"><\/script>
*
* backboon.js 是一个 MVC 框架
* 重度依赖 underscore.js
*/ // 用 backbone 框架实现类
var Person = Backbone.Model.extend({
initialize: function (attr) {
var prop;
for (prop in attr) {
this[prop] = attr[prop];
}
},
say: function () {
console.log(this.name + " is " + this.age + " years old.");
}
}); // 类的原型继承:即父类的扩充
var Student = Person.extend({
study: function () {
console.log("good good study!");
}
}); // 实例化的时候执行了 initialize 初始化函数
var s = new Student({
name: "Davi",
age: "20"
}); // Person 的 say 方法;Student 的 study 方法。
s.say(); // Davi is 20 yeas old.
s.study(); // good good study!
Backbone 与 jQuery
// backboon 数据模型
var model = new Backbone.Model({
name: "this is a model",
ver: "1.0"
}); // underscore
_.each(model.attributes, function (value, key) {
console.log(key + " : " + value);
}); _.each(model.values(), function (value) {
console.log(value);
}); // jquery or zepto
$.each(model.attributes, function (key, value) {
console.log(key + " : " + value);
});
Class 类的更多相关文章
- Java类的继承与多态特性-入门笔记
相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...
- C++ 可配置的类工厂
项目中常用到工厂模式,工厂模式可以把创建对象的具体细节封装到Create函数中,减少重复代码,增强可读和可维护性.传统的工厂实现如下: class Widget { public: virtual i ...
- Android请求网络共通类——Hi_博客 Android App 开发笔记
今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库
在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...
- ASP.NET Core 折腾笔记二:自己写个完整的Cache缓存类来支持.NET Core
背景: 1:.NET Core 已经没System.Web,也木有了HttpRuntime.Cache,因此,该空间下Cache也木有了. 2:.NET Core 有新的Memory Cache提供, ...
- .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类
.NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...
- Java基础Map接口+Collections工具类
1.Map中我们主要讲两个接口 HashMap 与 LinkedHashMap (1)其中LinkedHashMap是有序的 怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...
- PHP-解析验证码类--学习笔记
1.开始 在 网上看到使用PHP写的ValidateCode生成验证码码类,感觉不错,特拿来分析学习一下. 2.类图 3.验证码类部分代码 3.1 定义变量 //随机因子 private $char ...
- C# 多种方式发送邮件(附帮助类)
因项目业务需要,需要做一个发送邮件功能,查了下资料,整了整,汇总如下,亲测可用- QQ邮箱发送邮件 #region 发送邮箱 try { MailMessage mail = new MailMess ...
- .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator
去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...
随机推荐
- DefaultTableCellRenderer 自定义
方式一: DefaultTableCellRenderer render = new DefaultTableCellRenderer(); render.setHorizontalAlignment ...
- [xdoj1227]Godv的数列(crt+lucas)
解题关键:1001=7*11*13,模数非常小,直接暴力lucas.递归次数几乎为很小的常数.最后用中国剩余定理组合一下即可. 模数很小时,一定记住lucas定理的作用 http://acm.xidi ...
- 3.7-3.9 HBase表属性
一.表压缩 1.HBase Sanppy HBase Sanppy 1)配置Haodop压缩 [beifeng@hadoop-senior hadoop-2.5.0]$ bin/hadoop chec ...
- jQuery命名空间和自定义插件的的多种方法
jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jquery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级 ...
- 1. docker安装
前提 系统:我这边都使用虚拟机安装的CentOS7,具体安装可以参考:Windows安装Linux虚拟机(CentOS7) yum:推荐更新下yum:yum update;我们这边CentOS7自带d ...
- 交互原型设计软件axure rp学习之路(一)
开始学习之前,请一定要明白:Axure是个极其极其极其简单的软件.因为你所做的就是拖部件,打字,拖部件,打字,最多加个对齐.如果你能把axure当作word或者ppt来用,那你就学会了axure. A ...
- this解惑
前言 要正确理解this,首先得理解执行上下文,这里推荐汤姆大叔的执行上下文,因为this是在运行代码时确认具体指向谁,箭头函数除外. 全局作用域中的this node: 每个javaScript文件 ...
- 无监督学习:Linear Dimension Reduction(线性降维)
一 Unsupervised Learning 把Unsupervised Learning分为两大类: 化繁为简:有很多种input,进行抽象化处理,只有input没有output 无中生有:随机给 ...
- STL——queue
1.初始化 需要头文件<queue> queue<int>que; 2.成员函数 C++队列Queue类成员函数如下: back()返回最后一个元素 empty()如果队列空则 ...
- Node.js 内置模块crypto加密模块(5) RSA
RSA加密算法 写在前面: 了解RSA算法的原理请查看下面的文章 一文搞懂 RSA 算法 来源:简书 作者:somenzz 在使用 Node 进行 RSA 加密之前我们首先需要获取RSA公共和私有密 ...