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解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...
随机推荐
- appium连真机问题
adb devices -l 后出现:List of devices attached 解决方法:用管理员身份运行以上命令 adb kill-server adb start-server adb d ...
- Pointer 指针
利用指针访问对象,指针指向一个对象,允许使用解引用符(操作符*)来访问对象 int ival = 42; int *p = &ival;//p存放变量ival的内存地址,p是指向变量ival的 ...
- 此microsoft fix it不适用于您的操作系统 解决方案
想卸载低版本的office,下载了一个office卸载程序,但是运行时提示 此microsoft fix it不适用于您的操作系统 错误,在网上找了下解决方案,如下: 右键点击“兼容性疑难检查”,等 ...
- SAP ECC6 IDES安装及虚拟机下载
SAP ECC6.0 SR3 IDES Oracle.torrent(48.12G)下载 SAP ECC6 安装系列 SAP ECC6.0 IDES在Win7 X64上的安装 SAP ECC6.0 R ...
- HDU - 1114 Piggy-Bank 完全背包(背包恰好装满)
Piggy-Bank Before ACM can do anything, a budget must be prepared and the necessary financial support ...
- 通俗易懂,什么是.NET Core以及.NET Core能做什么
作者:依乐祝 原文地址:https://www.cnblogs.com/yilezhu/p/10880884.html 我们都知道.NET Core是一个可以用来构建现代.可伸缩和高性能的跨平台软件应 ...
- 模板 - 动态规划 - 数位dp
#include<bits/stdc++.h> using namespace std; #define ll long long ]; ll dp[][/*可能需要的状态2*/];//不 ...
- 盛大游戏技术总监徐峥:Unity引擎使用的三种方式
在5月13日Unite 2017 案例分享专场上,盛大游戏技术总监徐峥分享了使用Unity引擎的三种方式,以下为详细内容: 大家好,我先简单介绍一下我自己,我是盛大游戏的技术总监徐峥.我今天想分享的主 ...
- 2018最新苹果APP上架App Store流程(超详细)
本文转发:https://blog.csdn.net/xxw888/article/details/73618837 2018最新整理iOS app上架app详细教程 上架iOS需要一个付费688的开 ...
- ·ios 圆角
uiview 直接设置 view.layer.cornerRadius = 5 uiimageview 还需要在设置view.layer.masksToBounds = true .uiview设置这 ...