当前位置: 首页 > news >正文

JavaScript中的面向对象编程

OPP在JavaScript的表现方式:原型

传统的OPP:类

在这里插入图片描述

● 对象(实例)由类实例化,类的功能类似于蓝图,通过蓝图来实现建筑(实例)
● 行为(方法)从类复制到所有实例

JS中的OPP:原型

在这里插入图片描述

● 对象与原型对象相连;
● 原型继承:原型包含的方法(行为)可被链接到该原型的所有对象访问;
● 行为委托给链接的原型对象;

举例:
在这里插入图片描述

Array.prototype 是我们在 Javascript 中创建的所有数组对象的原型,因此,所有数组都可以使用 map 方法!

在 JavaScript 中实现原型继承的 3 种方法

**我们究竟如何去创建原型呢?并且我们将如何把对象链接到原型上呢?我们如何在没有类的情况下去创建一个新对象呢?

  1. 构造函数
    a. 从函数中创建对象的技术;
    b. 这就是数组、地图或集合等内置对象的实际实现方式
  2. ES6 Classes
    a. 构造函数语法的现代替代方案;
    b. “语法糖”:在幕后,ES6 类的工作原理正是链接构造函数;
    c. ES6 类的行为与 "经典 OOP "中的类不同
  3. Object.create()
    a. 将对象链接到原型对象的最简单、最直接的方法**

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 数据高效交互丨DolphinDB Redis 插件使用指南
  • 数据结构(Java):树二叉树
  • 前端数据加密方式
  • 《Windows API每日一练》9.13资源-鼠标位图和字符串
  • 基于Java+SpringMvc+Vue技术的药品进销存仓库管理系统设计与实现系统(源码+LW+部署讲解)
  • 什么叫图像的中值滤波,并附利用OpenCV和MATLB实现均值滤波的代码
  • Go 初始化一个字典
  • Android人脸解锁源码解析
  • el-table 动态添加删除 -- 鼠标移入移出显隐删除图标
  • 2024前端面试题之Vue3
  • 【面试题】防火墙的部署模式有哪些?
  • 3D问界-深入理解骨骼绑定与蒙皮绑定在三维动画中的角色
  • 从数据仓库到数据湖(下):热门的数据湖开源框架
  • NAS 必备导航页 Homarr 可视化配置 布局简单且美观
  • 将swagger注解导入apifox的IDEA配置
  • 分享的文章《人生如棋》
  • 【407天】跃迁之路——程序员高效学习方法论探索系列(实验阶段164-2018.03.19)...
  • centos安装java运行环境jdk+tomcat
  • Git初体验
  • javascript 总结(常用工具类的封装)
  • Laravel 实践之路: 数据库迁移与数据填充
  • Linux下的乱码问题
  • mysql innodb 索引使用指南
  • ng6--错误信息小结(持续更新)
  • ubuntu 下nginx安装 并支持https协议
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 记录:CentOS7.2配置LNMP环境记录
  • 来,膜拜下android roadmap,强大的执行力
  • 理清楚Vue的结构
  • 批量截取pdf文件
  • 使用 QuickBI 搭建酷炫可视化分析
  • 使用parted解决大于2T的磁盘分区
  • 算法之不定期更新(一)(2018-04-12)
  • 问题之ssh中Host key verification failed的解决
  • 学习笔记TF060:图像语音结合,看图说话
  • 【干货分享】dos命令大全
  • Semaphore
  • 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解 ...
  • (04)odoo视图操作
  • (07)Hive——窗口函数详解
  • (173)FPGA约束:单周期时序分析或默认时序分析
  • (1综述)从零开始的嵌入式图像图像处理(PI+QT+OpenCV)实战演练
  • (2024.6.23)最新版MAVEN的安装和配置教程(超详细)
  • (4)Elastix图像配准:3D图像
  • (Redis使用系列) Springboot 在redis中使用BloomFilter布隆过滤器机制 六
  • (阿里云在线播放)基于SpringBoot+Vue前后端分离的在线教育平台项目
  • (初研) Sentence-embedding fine-tune notebook
  • (独孤九剑)--文件系统
  • (二)换源+apt-get基础配置+搜狗拼音
  • (仿QQ聊天消息列表加载)wp7 listbox 列表项逐一加载的一种实现方式,以及加入渐显动画...
  • (附源码)spring boot公选课在线选课系统 毕业设计 142011
  • (未解决)macOS matplotlib 中文是方框
  • (一)Java算法:二分查找
  • (轉貼) 2008 Altera 亞洲創新大賽 台灣學生成果傲視全球 [照片花絮] (SOC) (News)
  • .L0CK3D来袭:如何保护您的数据免受致命攻击