zoukankan      html  css  js  c++  java
  • js 面向对象的三大特性:封装,继承、多态

    一:什么是封装?

    封装的定义:就是对象内部的变化对外界是透明的,不可见的。

    封装的场景:

     在写项目的过程中,有时候不同页面,会有相同的功能,我们还需要每个页面都写一遍吗?额,,,,其实也可以写的,只不过不嫌累 就i行,皮一下下~~

    例如:人员库项目中,部门管理中部门主管的模糊搜索,和新增部门的模糊搜索两个地方相同的功能,我们可不可以将模糊搜索的方法进行封装呢,然后,在不同页面点击触发的时候调用呢?这样我们是不是 就不必要 写大量重复的代码了,也会让我们的代码更加清晰。

    // 部门主管的模糊搜索
    remoteMethod(val) {
                this.query.keyWord = val;
                this.$store.dispatch('department/querySupervisorid', this.query)
    },  

    封装的好处:使用封装,可以达到代码的复用,使代码更加简洁,不会重复写很多的代码。

    二:什么是继承

    继承的定义:我们想要一个对象能够访问另一个对象的属性,同时,这个对象还能够添加自己新的属性或者覆盖可访问的另一个对象的属性,我们实现这个目标的方式叫做“继承”。

    实现继承的方式:

    function Foo(x, y) {
        this.x = x
        this.y = y
    }
    Foo.prototype.sayX = function() {
        console.log(this.x)
    } 
    Foo.prototype.sayY = function() {
        console.log(this.y)
    }
    
    function Bar(z) {
        this.z = z 
        this.x = 10
    }
    Bar.prototype = Object.create(Foo.prototype) // 注意这里,该方法时在FOO的原型上创建Bar的原型属性的空对象
    Bar.prototype.sayZ = function() {
        console.log(this.z)
    }
    Bar.prototype.constructor = Bar
    
    var o = new Bar(1)
    o.sayX() // 10
    o.sayZ() // 1

    这种继承方式被称为“构造函数继承”。

    三:什么是多态

     多态:同一操作作用于不同的对象,可以有不同的解释,产生不同的执行结果。本质上就是将”做什么“和”谁去做以及怎么做“分开,就是消除不同对象的耦合关系。

    重载:方法名相同,参数不同,表示不同的方法

    init() {
          this.test(100, 200)
          this.test(10)
        },
     test(num1, num2) {
          if(arguments.length===2) {
            console.log('111', num1, num2)
          } else {
            console.log('222', num1)
          }
    },

    重写:方法名相同,后者覆盖前者

    test1() {
          console.log('重写1')
     },
     test1() {
          console.log('重写2')
      },

    打印结果是: 重写2

  • 相关阅读:
    MySQL数据库安装和基本使用
    Android studio JNI技术实现与本地C++链接
    笔记 java中i++ 和 ++i的区别
    LaTeX中添加usepackage{subfigure}一直报错的解决办法,亲测
    Android Studio 出现“Cannot resolve symbol” 解决办法
    记录一个sql
    linux 文件内容查找、去重、统计
    MVC框架的模板缓存
    Linux 命令学习
    笔记 :PHP中的数据结构库SPL
  • 原文地址:https://www.cnblogs.com/mn6364/p/10411729.html
Copyright © 2011-2022 走看看