• 什么是对象

  对象是一个整体,对外提供一些操作

  • 什么是面向对象

  使用对象时,只关注对象提供的功能,不关注其内部细节;比如jQuery

  • 面向对象编程(OOP)的特点(自己理解的特点:把书本上多态放在类继承里
  1. 封装
  2. 继承:从已有的对象上,继承出新的对象
  • 多重继承
  • 多态
  • 对象的组成
  1. 方法---函数:过程、动态的
  2. 属性---变量:状态、静态的
arr=[,,,,]

//arr是一个对象

arr.length;//属性

arr.push(6);//方法
//变量跟属性本是同一个东西
//var a=12;//变量:自由
//arr.a = 5;//属性:属于一个对象
//函数
function show(){ }
//方法:属于一个对象的
arr.fn=function(){ }
  • 简单解释一下this指向
//针对array
var arr=[,,];
arr.show=function(){
//this:是当前的方法,属于谁
alert(this)//arr
}
//针对object
var obj = new Object();
obj.aaa=;
obj.show=function(){
alert(this.aaa)//12
}
obj.show();
  • 工厂模式构造对象
//其实这个函数就是创建一个对象(用工厂方式构造对象)
//用工厂方式构造对象
//好听点就是:构造函数
function create(name,sex){
var obj = new Object();
//属性
obj.name=name;
obj.sex=sex;
//方法
obj.showName=function(){
alert(this.name)//
}
obj.showSex=function(){
alert(this.sex)//男
}
return obj;
}
var p1=create("","男');
p1.showName();
p1.showSex();
  • 缺点
  1. 没有new
  2. 浪费资源---每个对象都有自己的function
  • 解决缺点
//this:当前方法,属于谁;
//但是函数前面有new的话,this就会失效;
function create(name,sex){
//属性
//var this = newObject();//假想系统帮我们处理了创建对象
this.name=name;
this.sex=sex;
//方法
this.showName=function(){
alert(this.name)//
}
this.showSex=function(){
alert(this.sex)//男
}
//return this;//假想系统帮我们处理了return
}
var p1=new create("","男');
p1.showName();
p1.showSex();
//记住一句话里面有new,外面就不需要new;外面有new,里面就不需要new;
  • 以上解决了new那怎么解决浪费资源呢?看下面
//首先区别一下类,对象(实例)
var arr = new Array();
Array.prototype.sum=function(){
//在Arry这个类上都可以使用sum()
}
//arr对象:真正有功能的东西,是被类构造出来的
//Array类:不具备实际的功能,只能用来构造对象
//所以我理解的就是构造函数就是类,类就是构造函数---只针对js
function Create(name,sex){
//属性
this.name=name;
this.sex=sex;
}
//Create就是类,也是构造函数
Create.prototype.showName=function(){
alert(this.name)//
}
Create.prototype.showSex=function(){
alert(this.sex)//男
}
//记住一句话相同的加在原型里,不同加在构造函数里
var p1=new create("","男');
p1.showName();
p1.showSex();
//混合模式
  • 以上就是优化后的代码---每个人理解不一样只要你自己明白就行

JavaScript面向对象①的更多相关文章

  1. JavaScript学习笔记(三)——this、原型、javascript面向对象

    一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化, ...

  2. JavaScript学习总结(三)——this、原型、javascript面向对象

    一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化, ...

  3. Javascript面向对象特性实现封装、继承、接口详细案例——进级高手篇

    Javascript面向对象特性实现(封装.继承.接口) Javascript作为弱类型语言,和Java.php等服务端脚本语言相比,拥有极强的灵活性.对于小型的web需求,在编写javascript ...

  4. javascript面向对象系列第四篇——选项卡的实现

    前面的话 面向对象的应用并非只是读几本书那么容易,需要有大量的工程实践做基础才能真正理解并学会使用它.本文将用面向对象的技术来制作一个简单的选项卡 图示说明 由图示结果看到,这是一个非常简单的选项卡. ...

  5. javascript面向对象系列第三篇——实现继承的3种形式

    × 目录 [1]原型继承 [2]伪类继承 [3]组合继承 前面的话 学习如何创建对象是理解面向对象编程的第一步,第二步是理解继承.本文是javascript面向对象系列第三篇——实现继承的3种形式 [ ...

  6. javascript面向对象系列第一篇——构造函数和原型对象

    × 目录 [1]构造函数 [2]原型对象 [3]总结 前面的话 一般地,javascript使用构造函数和原型对象来进行面向对象编程,它们的表现与其他面向对象编程语言中的类相似又不同.本文将详细介绍如 ...

  7. Javascript面向对象(封装、继承)

    Javascript 面向对象编程(一):封装 作者:阮一峰 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程( ...

  8. 《javascript面向对象精要》读书笔记

    <javascript面向对象精要> 买这本书的原因主要是因为作者,Nicholas C. Zakas 牛X闪闪的js专家,读过js高程的应该都知道他,而这本书是他的最新力作,感觉也是js ...

  9. 【转】javascript面向对象编程

    摘要:本文本来是想自己写的,奈何花了好长时间写好之后忘记保存,还按了刷新键,一键回到解放前,索性不写了,所以本文是转载的. 面向对象编程是用抽象方式创建基于现实世界模型的一种编程模式,主要包括模块化. ...

  10. javascript面向对象(一):封装

    本文来自阮一峰 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握. 下面就是我的学 ...

随机推荐

  1. 201871010108-高文利《面向对象程序设计(java)》第十三周学习总结

    项目 内容 这个作业属于哪个课程 <任课教师博客主页链接> https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 <作业链接地址> ht ...

  2. SpingBoot四——前后端分离

    ◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:https://www.cnblogs.com/by-dream/p/11336057.html 根据之前的教程,我们已经可以独立 ...

  3. opencv旋转图像,90度标准旋转

    摘自opencv 源代码 void rotate(InputArray _src, OutputArray _dst, int rotateMode) { CV_Assert(_src.dims() ...

  4. 并发、并行、同步、异步、全局解释锁GIL、同步锁Lock、死锁、递归锁、同步对象/条件、信号量、队列、生产者消费者、多进程模块、进程的调用、Process类、

    并发:是指系统具有处理多个任务/动作的能力. 并行:是指系统具有同时处理多个任务/动作的能力. 并行是并发的子集. 同步:当进程执行到一个IO(等待外部数据)的时候. 异步:当进程执行到一个IO不等到 ...

  5. Dubbo支持的协议(四)

    1. Dubbo Dubbo 官方推荐的协议 本质:使用 NIO 和线程池进行处理 缺点:大文件传输时可能出现文件传输失败问题. 2. RMI JDK 提供的协议,远程方法调用协议 缺点:偶尔连接失败 ...

  6. Sublime Text 3安装GoSublime

      GoLand IDE工具虽然在编程时很好用,但是在使用中也有个问题,有时我们可能只是写一个简单的脚本来测试,对于我而言在打开IDE太重量级了,所以捣鼓了GoSublime工具来满足平时最基本的需求 ...

  7. [POJ1189][BZOJ1867][CODEVS1709]钉子和小球

    题目描述 Description 有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且 ...

  8. NLP之概率图模型

    1.概率图模型 概率图模型是一类用图来表达变量相关关系的概率模型,它以图为表示工具,最常见的是用一个结点表示一个或一组随机变量,结点之间的边表示变量间的概率相关关系.概率图模型可大致分为两类:第一类是 ...

  9. docker的一些常用操作

    镜像:一个打包好的应用,还有应用运行的系统.资源.配置等容器:镜像的实例,一个镜像可以有一个或多个实例(容器)对docker容器的变更时写到容器的文件系统的,而不是写到docker镜像中的,可以用一个 ...

  10. [LeetCode] 843. Guess the Word 猜单词

    This problem is an interactive problem new to the LeetCode platform. We are given a word list of uni ...