简单的控制器结构

var  Controller = {};
//创建一个users控制器
(Controller.users = function ($) {
var nameClick = function() {
//....
};
$(function() {
$("#click").click(nameClick);
});
})(jQuery);

var Controller = {
user: function($) {
var userClick = function() {
//....
};
$(function() {
$("#tabs").click(userClick);
})
}
};
Controller.user(jQuery);

创建类

var Class = function() {
//js保留了class名称
var klass = function() {
//this为创建的实例,其在编译阶段就被赋予相应属性了;
this.init.apply(this, arguments);
}
klass.prototype.init = function() {this.name = "klass"};
return klass;
}
//这里等价于var Person = Class();
var Person = new Class; Person.prototype.init = function() {this.name = "person"};
//生成的实例的类型为Klass
var person = new Person;

根据传入参数稍作处理

var Class = function () {
var klass = function() {
arguments = arguments[0];
this.init.call(this, arguments);
}
klass.prototype.init = function(obj) {
var name = obj.name || "klass";
this.name = name;
}
return klass;
};
var Person = new Class;
Person.prototype.init = function(obj) {
var name = obj.name || "person";
this.name = name;
};
var person = new Person({name:"jinks"});

给“类”库添加方法

var Class = function() {
var klass = function() {
this.init.apply(this, arguments)
};
klass.fn = klass.prototype;
klass.fn.parent = klass;
klass.fn.init = function(){};
//这是给类方法添加方法
klass.extend = function(obj) {
var extended = obj.extended;
for(var prop in obj) {
klass[prop] = obj[prop];
}
extended && extended(klass);
}
//与extend不同,方法使直接写进继承的原型中
klass.include = function(obj) {
var included = obj.included;
for(var prop in obj) {
klass.fn[prop] = obj[prop];
}
included && included(klass);
}
return klass;
}
//Person通过fn属性来访问klass.prototype
var Person = new Class; Person.prototype.init = function() {
this.name = "person";
//...
}
//注意这是方法不是对象,不是引用地址,所以每个类添加的方法不会共用
Person.extend({
find: function() {},
exists: function() {},
});
//添加给类方法的原型中,所以同一类方法的实例都会有
Person.include({
save: function() {},
destroy: function() {}
});
//person通过parent来访问klass
var person = new Person;

基于原型的类继承

var Animal = function() {};
Animal.prototype.breath = function() {
console.log("breath");
}
var Dog = function() {};
//Dog继承了Animal
Dog.prototype = new Animal;
Dog.prototype.wag = function() {
console.log("wag tail");
} var dog = new Dog;
dog.wag();
dog.breath();

给“类”库添加继承

var Class = function(parent) {
var klass = function() {
this.init.apply(this, arguments);
}
//基于基于原型的类继承,改变klass原型
if(parent) {
var subclass = function() {};
subclass.prototype = parent.prototype;
klass.prototype = new subclass;
}
klass.fn = klass.prototype;
klass.fn.parent = klass;
klass.fn.init = function(){};
/*include和extend代码*/ return klass
}
var Animal = new Class;
Animal.include({
breath: function() {}
});
var Cat = new Class(Animal);
var tommy = new Cat;
tommy.breath();

控制"类"库的作用域

var Class = function(parent) {
var klass = function() {
this.init.apply(this, arguments);
}
if(parent) {
var subclass = function() {};
subclass.prototype = parent.prototype;
klass.prototype = new subclass;
}
klass.prototype.init = function() {};
klass.fn = klass.prototype;
klass.fn.parent = klass; klass.extend = function(obj) {
var extended = obj.extended;
for(var i in obj) {
klass[i] = obj[i];
}
if(extended) extended(klass)
};
klass.include = function(obj) {
var included = obj.included;
for(var i in obj) {
klass.fn[i] = obj[i];
}
if(included) included(klass)
}
klass.proxy = function(func) {
var self = this;
return (function() {
return func.apply(self, arguments);
});
}
klass.fn.proxy = klass.proxy;
return klass;
}
var Button = new Class; Button.extend({
init: function(elem) {
this.elem = jQuery(elem);
this.elem.click(this.proxy(this.click));
//上面其实等价于: this.elem.click(this.click.bind(this));
},
click: function() {alert(0)}
}); Button.init("button");

mvc-1mvc和类(1)的更多相关文章

  1. 一点ASP.NET MVC Html.Helper类的方法

    一点ASP.NET MVC Html.Helper类 这里就只写一个Html.ActionLink()和Html.DropdownList(). Html.ActionLink()里有三个参数,第一个 ...

  2. PHP MVC框架核心类

    PHP MVC框架核心类 现在我们举几个核心框架的例子演示:在framework/core下建立一个Framework.class.php的文件.写入以下代码: // framework/core/F ...

  3. asp.net mvc自定义JsonResult类来防止MaxJsonLength超过限制

    前不久在做一个项目的时候,我用到了mvc的webapi返回了一个大数据,结果报了500错误,如下图所示: Server Error in ‘/’ Application. Error during s ...

  4. (译文)MVC通用仓储类

    Generic Repository Pattern MVC Generic Repository Pattern MVC 原文链接:http://www.codeproject.com/Articl ...

  5. MVC缓存OutputCacheAttribute 类提高网站效率(转)

    原文转自:http://www.cnblogs.com/iamlilinfeng/p/4419362.html 命名空间:  System.Web.Mvc 程序集:  System.Web.Mvc(在 ...

  6. spring mvc 的Controller类默认Scope是单例(singleton)的

    使用Spring MVC有一段时间了,之前一直使用Struts2,在struts2中action都是原型(prototype)的, 说是因为线程安全问题,对于Spring MVC中bean默认都是(s ...

  7. 自己动手写控件(模仿mvc htmlhelper的类)

    自定义helper类,要求命名空间在 System.Web.Mvc之下,要求,静态类,静态方法,特殊生成对应html的返回字段, 传递Htmlhleper,返回特定类型 返回值是MvcHtmlStri ...

  8. MVC Controller 基类中的Request

    今天在测试自己MVC程序的时候发现之前写代码的一个BUG,需求是每个页面要获取当前URL链接中包含的城市ID,我把获取url的方法写到了Controller的基类BaseController(Base ...

  9. ASP.NET MVC 创建控制器类过程

    MvcHandler.ProcessRequestInit()方法: 1.1获取控制器的名称string requiredString = this.RequestContext.RouteData. ...

  10. Spring MVC中一般类使用service

    在Spring MVC中,Controller中使用service只需使用注解@Resource就行,但是一般类(即不使用@Controller注解的类)要用到service时,可用如下方法: 1.S ...

随机推荐

  1. 和我一起来了解SEO

    基础知识 搜索引擎 搜索引擎爬虫会检索各个网站,分析他们的关键字,从一个连接到另一个连接,如果爬虫觉得这个关键字是有用的 就会存入搜索引擎数据库,反之如果没用的.恶意的.或者已经在数据库的,就会舍弃. ...

  2. 漫长Appium之路(一)——从黑苹果到虚拟机

    作为一名普普通通的实习生,我也开始习惯折腾一般的生活了.部门应该最近是要搞个iOS自动化测试工具,我从最开始说起吧. 应该是上上上周五.主管找到我,说要装一个黑苹果,要我尽快把黑苹果能支持的硬件配置给 ...

  3. matlab之round any size rat isscalar ismatrix mean find max

    1.round : 四舍五入 例子:a = [-1.9, -0.2, 3.4, 5.6, 7.0, 2.4+3.6i] round(a): [-2  0  3  6  7  2  4] 2.butte ...

  4. mySQL笔记2

    php主要实现B/S .net IIS java TomCat LAMP: Linux 系统 A阿帕奇服务器 Mysql数据库 Php语言(KE) mysql:c常用代码 create table c ...

  5. Atlas安装及配置

    ==============linux下快捷键==================ctrl+insert 复制shift +insert 粘贴 输入文件名的前三个字母,按tab键自动补全文件名 在vi ...

  6. BestCoder Round #60 题解链接

    题解  题目 1001 GT and sequence 注意先特判000的情况:如果读入的数据有000,那么去掉所有的000且最后答案和000取一个max. 剩下的正数显然全部乘起来比较优. 对于负数 ...

  7. asp.net 网站 或者web Api 发布

    asp.net 发布iis时可能遇到的内部服务错误常见的有两种: 1.如下图,500.19 Internal Server Error(内部服务错误) 这种错误可能是由于本机的注册表中的asp.net ...

  8. grep与egrep

    当只有一个匹配条件时:egrep pattern file等价于grep -E pattern file 例如: 当多个匹配条件时,只能用egrep -e pattern1 -e pattern2 - ...

  9. Linux 的shell 字符串截取很有用。有八种方法。

    一 Linux 的字符串截取很有用.有八种方法. 假设有变量 var=http://www.linuxidc.com/123.htm 1  # 号截取,删除左边字符,保留右边字符. echo ${va ...

  10. 获取oracle 表字段,表名,以及主键之类等等的信息。

    获取表名:  Oracle的user_talbes用于记录了用户表信息. select * from user_tables  获取某个表的字段: USER_TAB_COLS中记录了用户表的列信息.下 ...