Js面向对象编程

1.     什么是面向对象编程?

我也不说不清楚什么是面向对象,反正就那么回事吧。

编程有时候是一件很快乐的事,写一些小游戏,用编程的方式玩游戏等等

2.     Js如何定义一个对象

一般变量的定义方法

var name = '小明';

var email = 'xiaoming@chinaedu.net';

var website = 'http://chinaedu.net';

写成对象的方式:

var xiaoming = {

name : '小明',

email : 'xiaoming@chinaedu.net',

website : 'http://chinaedu.net'

}

访问属性的方式

xiaoming.name

xiaoming['name']

追加属性

xiaoming.sex = '男';

给对象定义方法

var xiaoming = {

name : '小明',

email : 'xiaoming@chinaedu.net',

website : 'http://chinaedu.net',

sayHello : function(){

alert(this.name + ',你好!');

}

}

// 再追加一些属性和方法

xiaoming.birthday = '2005-09-23';

xiaoming.eat = function(){

alert(this.name + ',你妈叫你回家吃饭!');

};

移除属性的方法

delete xiaoming.sex

检查对象是否存在某个属性

if('sex' in xiaoming){

alert("true");

}

js对象的其实没有私有属性的,他的属性都是公有的。

一般对属性名前加_表示私有属性。

3.     对象的继承

我对继承的简单理解:子对象拥有父对象的属性,并可以对父对象的属性进行覆盖或者扩展。

第一种做法,直接把子对象的属性copy给父对象里,生成新的对象就是继承的效果了。

实现方法

function deepCopy(p, c) {

  var c = c || {};

  for (var i in p) {

    if (typeof p[i] === 'object') {

      c[i] = (p[i].constructor === Array) ? [] : {};

      deepCopy(p[i], c[i]);

    } else {

       c[i] = p[i];

    }

  }

  return c;

}

4.     js中如何定义一个类?

定义的function就是一个构造方法也就是说是定义了一个类;用这个方法可以new新对象出来。

function Person(name, age){

this.name = name;

this.age = age;

this.showInfo = function(){

alert(this.name + this.age + "岁");

}

}

Person p1 = new Person('小明', 17);

5.     类的静态属性及方法

严格来说,ECMAScript 并没有静态作用域。不过,它可以给构造函数提供属性和方法。还记得吗,构造函数只是函数。函数是对象,对象可以有属性和方法。

Person.newOrder = 0;

Person.newOrder = function(){

return Person.newOrder ++;

}

6.     类的继承

对象冒充

function Rect(width, height){

this.width = width;

this.height = height;

this.area = function(){return this.width*this.height;};

}

function MyRect(width, height, name){

//    this.newMethod = Rect;

//    this.newMethod(width,height);

//    delete this.newMethod;

Rect.call(this,width,height);// Rect.apply(this, arguments);

this.name = name;

this.show = function(){

alert(this.name+" with area:"+this.area());

}

}

原型链(prototype chaining)

function Rect(){

}

Rect.prototype = {

width:10,

height : 10,

area : function(){return this.width*this.height;}

};

function MyRect(name){

this.name = name;

this.show = function(){

alert(this.name + " with area:" + this.area());

}

}

MyRect.prototype = new Rect();

混合型

function Rect(width,height){

this.width = width;

this.height = height;

}

Rect.prototype = {

area : function(){return this.width*this.height;}

};

function MyRect(name, width, height){

Rect.call(this, width, height);

this.show = function(){

alert(this.name + " with area:" + this.area());

}

}

MyRect.prototype = new Rect();

7.     可变参数

Js的方法没有重载的概念,但是他的方法参数是可变的。你可传n多参数,只看方法名,方法名相同就认为是一个方法。同名的方法只会覆盖之前的方法。

var Rect = function(){};

Rect.prototype = {

_width : 5,

_height : 10,

width : function(width) {

if (arguments.length > 0) {

this._width = width;

return this;

}

return this._width;

},

height : function(height) {

if (arguments.length > 0) {

this._height = height;

return this;

}

return this._height;

}

}

var r1=new Rect();

r1.width(30).height(45);

alert(r1.width() + "||" + r1.height());

8.     命名空间

定义一个edu.fn的命名空间

if (typeof Edu == 'undefined') {

var Edu = {};

}

if (typeof Edu.fn == 'undefined') {

Edu.fn = {};

}

(function($) {

Edu.fn.core = {

}

})(jQuery);

工具方法

function namespace(ns) {

if (!ns)

return;

var nsArr = ns.split('.');

var root = window[nsArr[0]] || (window[nsArr[0]] = {});

for ( var i = 1; i < nsArr.length; i++) {

root = root[nsArr[i]] || (root[nsArr[i]] = {});

}

return root;

}

namespace("Edu.fn");

Edu.fn.add = function(a, b) {

return a + b;

}

alert(Edu.fn.add(1, 2));

9.         编程常用的模板

针对一些工具类,或者全局只需要存在一个对象的写法

;var YourObj = null;

(function($) {

YourObj = {

width:10,

show:function(){}

}

})(jQuery);

说明:前后加分号只是为了js代码合并压缩的时候保证不会影响别人的代码以及自己的代码。这里使用了js闭包的方式。把对象定义在外边的好处是eclipse的outline可以方便的显示对象的属性和方法。

类模板

;

var YourClass = null;

(function($) {

YourClass = function(options) {

this.settings = {

width : 5,

height : 5

};// 定义一些默认的属性

$.extend(truethis.settings, options);

};

YourClass.prototype = {

width : 10,

name : '',

show : function() {

alert(this.name + ",width:" + width);

}

}

})(jQuery);

10.  常见的一些js用法

简化if语句

a?(语句):(语句)

a=arg||’0’;

11.  js调试

现代浏览器一般都支持console.log(msg),要比alert方便,alert会阻断程序。

【参考资料】

http://www.w3school.com.cn/js/pro_js_object_defining.asp

http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_encapsulation.html

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

http://coolshell.cn/articles/6441.html

本文为作者原创,转载请注明出处,与你分享我的快乐
http://www.cnblogs.com/weirhp

 
 

Js面向对象编程的更多相关文章

  1. 带你一分钟理解闭包--js面向对象编程

    上一篇<简单粗暴地理解js原型链--js面向对象编程>没想到能攒到这么多赞,实属意外.分享是个好事情,尤其是分享自己的学习感悟.所以网上关于原型链.闭包.作用域等文章多如牛毛,很多文章写得 ...

  2. js原生设计模式——3简单工厂模式\js面向对象编程实例

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  3. JS面向对象编程(进阶理解)

    JS 面向对象编程 如何创建JS对象 JSON语法声明对象(直接量声明对象) var obj = {}; 使用 Object 创建对象 var obj = new Object(); JS对象可以后期 ...

  4. 页面循环绑定(变量污染问题),js面向对象编程(对象属性增删改查),js字符串操作,js数组操作

    页面循环绑定(变量污染问题) var lis = document.querySelectorAll(".ul li") for ( var i = 0 ; i < lis. ...

  5. js面向对象编程 ---- 系列教程

    原 js面向对象编程:数据的缓存 原 js面向对象编程:如何检测对象类型 原 js面向对象编程:if中可以使用那些作为判断条件呢? 原 js面向对象编程:this到底代表什么?第二篇 原 js面向对象 ...

  6. 简单粗暴地理解js原型链–js面向对象编程

    简单粗暴地理解js原型链–js面向对象编程 作者:茄果 链接:http://www.cnblogs.com/qieguo/archive/2016/05/03/5451626.html 原型链理解起来 ...

  7. JS面向对象编程,对象,属性,方法。

    document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v ...

  8. js面向对象编程(第2版)——js继承多种方式

    附带书籍地址: js面向对象编程(第2版)

  9. 原生js面向对象编程-选项卡(自动轮播)

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

随机推荐

  1. Linq入门演练---(2)lambda表达式

    今天大家一同学习下lambda表达式, lambda表达式使用起来更方便, lambda表达式其实是一个匿名函数,使用的运算符为=> 语法: (参数)=>表达式 如果只有一个参数,可以不使 ...

  2. iOS定义自己的回报button(它不影响返回手势)

    这种方法可以定义为返回到其button,它不影响返回手势. 新方法: self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] ...

  3. hadoop得知;datajoin;chain署名;combine()

    hadoop一种简化机制来管理job和control作业之间的非线性依赖,job对象mapreduce表明. job该目的是通过使实例化jobconf对象的构造函数的工作落实. x.addDeopen ...

  4. ToDictionary() and ToList()

    ToDictionary() and ToList() 前言: 有两个简单好用的LINQ扩展方法 ToDictionary() 和ToList(),你可能知道或不知道,但是它的的确确可以简化查询转化为 ...

  5. Tomcat剖析(三):连接器(1)

    Tomcat剖析(三):连接器(1) 1. Tomcat剖析(一):一个简单的Web服务器 2. Tomcat剖析(二):一个简单的Servlet服务器 3. Tomcat剖析(三):连接器(1) 4 ...

  6. 自己定义View之绘制圆环

    一.RingView 自己定义的view,构造器必须重写,至于重写哪个方法,參考例如以下: ①假设须要改变View绘制的图像,那么须要重写OnDraw方法.(这也是最经常使用的重写方式.) ②假设须要 ...

  7. 对[foreach]的浅究到发现[yield]

    原文:对[foreach]的浅究到发现[yield] 闲来无事,翻了翻以前的代码,做点总结,菜鸟从这里起航,呵呵. 一.List的foreach遍历 先上代码段[1]: class Program { ...

  8. C++外观设计模式模式(三)

    3.外观模式总结 引入了外观类.解除了客户类与子系统的耦合性.客户类不须要直接操作子系统,而是由外观类负责处理,对client而言是透明的,客户类仅仅须要操作外观类就能够了,符合"迪迷特法则 ...

  9. eclipse中使用git进行版本号控制

    协作开发的时候没有版本号控制是非常痛苦的事情,使用git能够非常好的完毕这项任务,由于非常多的开源码都在github上公布,因此学会使用git是非常重要的一项技能. 这篇写的是在eclipse下使用的 ...

  10. SICP 锻炼 (1.45)解决摘要

    SICP 1.45是对前面非常多关于不动点的习题的总结. 题目回想了我们之前在1.3.3节使用的不动点寻找方法.当寻找y -> x/y 的不动点的时候,这个变换本身不收敛.须要做一次平均阻尼才干 ...