在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 类的更多相关文章

  1. Java类的继承与多态特性-入门笔记

    相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...

  2. C++ 可配置的类工厂

    项目中常用到工厂模式,工厂模式可以把创建对象的具体细节封装到Create函数中,减少重复代码,增强可读和可维护性.传统的工厂实现如下: class Widget { public: virtual i ...

  3. Android请求网络共通类——Hi_博客 Android App 开发笔记

    今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...

  4. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库

    在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...

  5. ASP.NET Core 折腾笔记二:自己写个完整的Cache缓存类来支持.NET Core

    背景: 1:.NET Core 已经没System.Web,也木有了HttpRuntime.Cache,因此,该空间下Cache也木有了. 2:.NET Core 有新的Memory Cache提供, ...

  6. .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类

    .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...

  7. Java基础Map接口+Collections工具类

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  8. PHP-解析验证码类--学习笔记

    1.开始 在 网上看到使用PHP写的ValidateCode生成验证码码类,感觉不错,特拿来分析学习一下. 2.类图 3.验证码类部分代码 3.1  定义变量 //随机因子 private $char ...

  9. C# 多种方式发送邮件(附帮助类)

    因项目业务需要,需要做一个发送邮件功能,查了下资料,整了整,汇总如下,亲测可用- QQ邮箱发送邮件 #region 发送邮箱 try { MailMessage mail = new MailMess ...

  10. .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator

    去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...

随机推荐

  1. javascript私有属性失效及解决方案

    1.js创建私有属性的方法 在 javascript 中所有对象的成员是公有的 构造函数也是如此: function Gadget ( ) { this.name = ' jack '; this.p ...

  2. 三 Flask+ MySQL 数据库操作

    一: __init__.py作用: __init__.py 文件的作用是将文件夹变为一个Python模块,Python 中的每个模块的包中,都有__init__.py 文件.通常__init__.py ...

  3. C++源码学习

    C/C++是最主要的编程语言.这里列出了50名优秀网站和网页清单,这些网站提供c/c++源代码.这份清单提供了源代码的链接以及它们的小说明.我已尽力包括最佳的C/C++源代码的网站.这不是一个完整的清 ...

  4. git base cli

  5. select2,利用ajax高效查询大数据列表(可搜索、可分页)

    二.导入css和js到网站上 1.使用CDN,节省自己网站的流量 ? 1 2 <link href="https://cdnjs.cloudflare.com/ajax/libs/se ...

  6. ASP.NET web application中的redirect

    在开发ASP.NET MVC web application过程中,开发上线了新系统后,需要把老系统的url redirect新系统下 其中在项目系统目录下有一个文件 301RedirectsPage ...

  7. 使用MeshLab的技巧总结(自己原创总结)

    1.放大点的显示,Alt+wheel,即按住Alt键后使用鼠标滑轮改变点的显示大小.

  8. URL辅助方法

    URL辅助方法则负责用来产生url地址,那什么时候需要呢,以输出超链接来说,使用Html.ActionLink()辅助方法一定会产生超链接的a标签,如果只是想单纯的输出asp.net mvc的某个网址 ...

  9. [Leetcode]847. Shortest Path Visiting All Nodes(BFS|DP)

    题解 题意 给出一个无向图,求遍历所有点的最小花费 分析 1.BFS,设置dis[status][k]表示遍历的点数状态为status,当前遍历到k的最小花费,一次BFS即可 2.使用DP 代码 // ...

  10. Unity DOTS 走马观花

    https://segmentfault.com/a/1190000019143037 本文还在不断完善,可能不会及时同步在 SegmentFault,源文章在我的博客中:萤火之森 - Unity D ...