- 浏览: 189532 次
文章分类
最新评论
-
luxing44530:
你好, 关于 JDK 7中也有一个支持协程方式的实现 在那呀? ...
Java性能调优笔记 -
songgz:
你是一个会思考的人,前途无量,代码审查显然不能以风格和规则为主 ...
到底该怎么样做代码审查? -
jiaoronggui:
遇到过一模一样的问题
一条Select语句导致瓶颈 -
Leon.Wood:
写出让计算机读懂的代码很容易,写出让人读懂的只有高手才能做到. ...
到底该怎么样做代码审查? -
ajuanlove:
不经常用这玩意
对300万一张表数据,用游标进行循环,不同写法的效率比较
javascript对象的创建
JavaScript中定义对象的几种方式(JavaScript中没有类的概念,只有对象):
1) 基于已有对象扩充其属性和方法:
- var object = new Object();
- object.name = "zhangsan";
- object.sayName = function(name)
- {
- this.name = name;
- alert(this.name);
- }
- object.sayName("lisi");
2)工厂方式
- //工厂方式创建对象
- /*
- function createObject()
- {
- var object = new Object();
- object.username = "zhangsan";
- object.password = "123";
- object.get = function()
- {
- alert(this.username + ", " + this.password);
- }
- return object;
- }
- var object1 = createObject();
- var object2 = createObject();
- object1.get();
带参数的构造方法:
- function createObject(username, password)
- {
- var object = new Object();
- object.username = username;
- object.password = password;
- object.get = function()
- {
- alert(this.username + ", " + this.password);
- }
- return object;
- }
- var object1 = createObject("zhangsan", "123");
- object1.get();
让一个函数对象被多个对象所共享,而不是每一个对象拥有一个函数对象。
- function get()
- {
- alert(this.username + ", " + this.password);
- }
- function createObject(username, password)
- {
- var object = new Object();
- object.username = username;
- object.password = password;
- object.get = get;
- return object;
- }
- var object = createObject("zhangsan", "123");
- var object2 = createObject("lisi", "456");
- object.get();
- object2.get();
3)构造函数方式
- function Person()
- {
- //在执行第一行代码前,js引擎会为我们生成一个对象
- this.username = "zhangsan";
- this.password = "123";
- this.getInfo = function()
- {
- alert(this.username + ", " + this.password);
- }
- //此处有一个隐藏的return语句,用于将之前生成的对象返回
- }
- var person = new Person();
- person.getInfo();
可以在构造对象时传递参数
- function Person(username, password)
- {
- this.username = username;
- this.password = password;
- this.getInfo = function()
- {
- alert(this.username + ", " + this.password);
- }
- }
- var person = new Person("zhangsan", "123");
- person.getInfo();
4)原型(“prototype”)方式
- //使用原型(prototype)方式创建对象
- /*
- function Person()
- {
- }
- Person.prototype.username = "zhangsan";
- Person.prototype.password = "123";
- Person.prototype.getInfo = function()
- {
- alert(this.username + ", " + this.password);
- }
- var person = new Person();
- var person2 = new Person();
- person.username = "lisi";
- person.getInfo();
- person2.getInfo();
- */
- function Person()
- {
- }
- Person.prototype.username = new Array();
- Person.prototype.password = "123";
- Person.prototype.getInfo = function()
- {
- alert(this.username + ", " + this.password);
- }
- var person = new Person();
- var person2 = new Person();
- person.username.push("zhangsan");
- person.username.push("lisi");
- person.password = "456";
- person.getInfo();
- person2.getInfo();
如果使用原型方式对象,那么生成的所有对象会共享原型中的属性,这样一个对象改变了该属性也会反应到其他对象当中。
单纯使用原型方式定义对象无法在构造函数中为属性赋初值,只能在对象生成后再去改变属性值。
使用原型+构造函数方式来定义对象,对象之间的属性互不干扰,各 个对象间共享同一个方法
- //使用原型+构造函数方式来定义对象
- function Person()
- {
- this.username = new Array();
- this.password = "123";
- }
- Person.prototype.getInfo = function()
- {
- alert(this.username + ", " + this.password);
- }
- var p = new Person();
- var p2 = new Person();
- p.username.push("zhangsan");
- p2.username.push("lisi");
- p.getInfo();
- p2.getInfo();
5)动态原型方式:在构造函数中通过标志量让所有对象共享一个方法,而每个对象拥有自己的属性。
- function Person()
- {
- this.username = "zhangsan";
- this.password = "123";
- if(typeof Person.flag == "undefined")
- {
- alert("invoked");
- Person.prototype.getInfo = function()
- {
- alert(this.username + ", " + this.password);
- }
- Person.flag = true;
- }
- }
- var p = new Person();
- var p2 = new Person();
- p.getInfo();
- p2.getInfo();
JavaScript中的继承。
1) 对象冒充
- //继承第一种方式:对象冒充
- function Parent(username)
- {
- this.username = username;
- this.sayHello = function()
- {
- alert(this.username);
- }
- }
- function Child(username, password)
- {
- //下面三行代码是最关键的代码
- this.method = Parent;
- this.method(username);
- delete this.method;
- this.password = password;
- this.sayWorld = function()
- {
- alert(this.password);
- }
- }
- var parent = new Parent("zhangsan");
- var child = new Child("lisi", "1234");
- parent.sayHello();
- child.sayHello();
- child.sayWorld();
2) call方法方式。
call方法是Function对象中的方法,因此我们定义的每个函数都拥有该方法。可以通过函数名来调用call方法,call方法的第一个参数会被传递给函数中的this,从第2个参数开始,逐一赋值给函数中的参数。
- <p>//使用call方式实现对象的继承</p><p>function Parent(username)
- {
- this.username = username;</p><p> this.sayHello = function()
- {
- alert(this.username);
- }
- }</p><p>function Child(username, password)
- {
- Parent.call(this, username);</p><p> this.password = password;</p><p> this.sayWorld = function()
- {
- alert(this.password);
- }
- }</p><p>var parent = new Parent("zhangsan");</p><p>var child = new Child("lisi", "123");</p><p>parent.sayHello();</p><p>child.sayHello();
- child.sayWorld();</p><p>
- </p><span style="font-size:18px;"><span style="color:#000000;"> </span></span>
3) apply方法方式
- //使用apply方法实现对象继承
- function Parent(username)
- {
- this.username = username;
- this.sayHello = function()
- {
- alert(this.username);
- }
- }
- function Child(username, password)
- {
- Parent.apply(this, new Array(username));
- this.password = password;
- this.sayWorld = function()
- {
- alert(this.password);
- }
- }
- var parent = new Parent("zhangsan");
- var child = new Child("lisi", "123");
- parent.sayHello();
- child.sayHello();
- child.sayWorld();
4)原型链方式(无法给构造函数传参数)
- //使用原型链(prototype chain)方式实现对象继承
- function Parent()
- {
- }
- Parent.prototype.hello = "hello";
- Parent.prototype.sayHello = function()
- {
- alert(this.hello);
- }
- function Child()
- {
- }
- Child.prototype = new Parent();
- Child.prototype.world = "world";
- Child.prototype.sayWorld = function()
- {
- alert(this.world);
- }
- var child = new Child();
- child.sayHello();
- child.sayWorld();
5)混合方式(推荐)
更多信息请查看 java进阶网 http://www.javady.com
- //使用混合方式实现对象继承(推荐)
- function Parent(hello)
- {
- this.hello = hello;
- }
- Parent.prototype.sayHello = function()
- {
- alert(this.hello);
- }
- function Child(hello, world)
- {
- Parent.call(this, hello);
- this.world = world;
- }
- Child.prototype = new Parent();
- Child.prototype.sayWorld = function()
- {
- alert(this.world);
- }
- var child = new Child("hello", "world");
- child.sayHello();
- child.sayWorld();
发表评论
-
Java程序员从笨鸟到菜鸟之(三十三)大话设计模式之单例模式
2012-04-23 22:26 1059单例模式属于对象创建型模式,其意图是保证一个类仅有 ... -
Java程序员从笨鸟到菜鸟之(三十二)大话设计模式之设计模式分类和三种工厂模式
2012-04-23 22:25 1140设计模式分类 首先先简单说一下设计模式的分类设计模式可 ... -
Java程序员从笨鸟到菜鸟之(三十一)大话设计模式之设计模式遵循的七大原则
2012-04-23 22:24 760最近几年来,人们踊跃的提倡和使用设计模式,其根 ... -
Java程序员从笨鸟到菜鸟之(三十)javascript弹出框、事件、对象化编程
2012-04-23 22:24 1262一:弹出框 JavaScript ... -
Java程序员从笨鸟到菜鸟之(二十四)Xml基础详解和DTD验证
2012-04-22 15:20 859Xml基础详解 Xml:可扩展标记语言 (Extens ... -
Java程序员从笨鸟到菜鸟之(二十三)常见乱码解决以及javaBean基础知识
2012-04-22 15:20 1205乱码问题应该是做javaWeb开发人员都遇到过的问题吧 ... -
Java程序员从笨鸟到菜鸟之(二十二)华山论session和cookie机制
2012-04-22 15:19 965会话(Session)跟踪是Web程序中常用的技术,用 ... -
Java程序员从笨鸟到菜鸟之(二十一)java过滤器和监听器详解
2012-04-22 15:18 10201、Filter工作原理( ... -
Java程序员从笨鸟到菜鸟之(二十)jsp自定义标签
2012-04-22 15:17 835一、基本概念 1、标签(Tag) 标签是一种XML元 ... -
Java程序员从笨鸟到菜鸟之(十九)EL表达式和JSTL
2012-04-21 12:55 1073一:EL表达式: 1.定义:为了计算和输出存储在标志位 ... -
Java程序员从笨鸟到菜鸟之(十八)JSP基本语法与动作指令
2012-04-21 12:54 866Jsp,通常的被大家认为是做网页的前台界面,我刚学习的时 ... -
Java程序员从笨鸟到菜鸟之(十六)CSS基础积累总结(上)
2012-04-21 12:52 806一:CSS的工作原理 1. ... -
java程序员从笨鸟到菜鸟之(七)一—java数据库操作
2012-04-19 22:48 1394更多信息请查看 java进 ... -
Java程序员从笨鸟到菜鸟之(六)I/O流操作
2012-04-19 22:47 1653在软件开发中,数 ... -
Java程序员从笨鸟到菜鸟之(十)枚举,泛型详解
2012-04-19 22:48 1122一:首先从枚举开始 ... -
Java程序员从笨鸟到菜鸟之(九)——数据库有关知识补充(事务、视图、索引、存储过程)
2012-04-19 22:48 1075一:事务 首先看一下什么是事务: 通俗的理解,事务 ... -
Java程序员从笨鸟到菜鸟之(八)反射和代理机制
2012-04-19 22:48 831反射和代理机制是 ... -
java程序员从笨鸟到菜鸟之(七)一—java数据库操作
2012-04-18 21:14 0数据库访问几乎每一个稍微成型的程序都要用到的知识,怎么 ... -
Java程序员从笨鸟到菜鸟之(六)I/O流操作
2012-04-18 21:13 0在软件开发中,数据流和数据库操作占据了一个很重要的位置 ... -
Java程序员从笨鸟到菜鸟之(五)java开发常用类(包装,数字处理集合等)(下)
2012-04-18 00:12 786写在前面:由于前天 ...
相关推荐
java程序员-从笨鸟到菜鸟.pdf
### Java程序员成长之路——从菜鸟到笨鸟 #### 一、引言 《Java程序员由菜鸟到笨鸟》是一本由曹胜欢编写的书籍,旨在帮助初学者掌握Java编程的基础知识,并逐步进阶至更高级的应用场景。本书不仅适合初学者作为...
曹胜欢在《JAVA程序员 从笨鸟到菜鸟.pdf》中分享了他个人学习Java的经历,从迷茫到逐渐成长的过程。他强调了自学的重要性,并鼓励初学者不要怕走弯路,同时希望自己的经验可以帮助到同样在学习Java的初学者。 2. ...
2. **面向对象编程**:介绍类、对象、封装、继承、多态等核心概念,以及如何设计和实现面向对象的程序。 3. **异常处理**:讲解如何捕获和处理运行时异常,提高程序的健壮性。 4. **集合框架**:包括ArrayList、...
### Java程序员从笨鸟到菜鸟 #### 一、开发环境搭建与基本语法 ##### 开发环境搭建 在开始Java的学习之前,首先需要搭建一个合适的开发环境。这通常涉及到以下步骤: 1. **JDK(Java Development Kit)安装**:...
资源名称:《Java程序员-从笨鸟到菜鸟》PDF 下载资源目录:作者简介:..........................................................................................................................................
以上内容只是《Java程序员由菜鸟到笨鸟》这本书中可能涵盖的部分知识点。对于初学者来说,系统地学习这些基础知识是非常重要的,因为它们构成了Java编程的基础,也是进一步学习高级主题的基石。希望这些内容能够帮助...
根据提供的文件信息,“Java程序员由菜鸟到笨鸟”是一本旨在帮助初学者成长为合格Java开发者的书籍。本书作者为曹胜欢,发布日期为2018年3月17日。以下是从该书的标题、描述以及部分可能包含的内容中提炼出的关键...
《Java游戏:笨鸟》(也称为FlappyBird)是一款基于...通过分析和实现《Java游戏:笨鸟》,初学者可以深入理解Java语言的面向对象编程思想,熟悉GUI编程,以及游戏开发的基本流程,为后续更复杂的项目打下坚实的基础。
day01_Object类、常用API day02_Collection、泛型 day03_List、Set、数据结构、Collections day04_Map,斗地主案例 day05_异常,线程 day06_线程、同步 day07_等待与唤醒案例、线程池、Lambda...Java基础小节练习题答案