微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在JS中将函数设置为类?

如何解决如何在JS中将函数设置为类?

我有一个功能

function log() {
    console.log('something');
}

我希望这个对象具有:

class Car {
  constructor(name) {
    this.name = name;
  }
  log() {
    // something
  }
}

如何在不重复函数内部代码的情况下附加它?

解决方法

像这样

要么作为成员函数要么在原型上

class Car {
  constructor(name) {
    this.name = name;
  }
  log = str => console.log(str); // or log = log if log is defined elsewhere
}

const carA = new Car();
carA.log("vroom");

// or

const logger = str => console.log(str);

Car.prototype.logger = logger;

const carB = new Car();
carA.logger("vroom"); // also available to the previous and other Car objects
carB.logger("vroom");

,

您可以将该函数作为方法附加到 Car 原型上,因此现在它可以作为所有实例的方法使用。

function log() {
    console.log('something');
}

class Car {
  constructor(name) {
    this.name = name;
  }
}

Car.prototype.log = log;

const a = new Car("Audi");
const b = new Car("BMW");

a.log();
b.log();

,

基本上可以通过三种方式来实现;

第一种方法是使用类构造函数并在构造函数调用中传递函数

function log() {
    console.log('something');
}


class Car {
  constructor(name,log) {
    this.name = name;
    this.log = log
  }
  
}
const audi = new Car("name",log);
audi.log();
第二种方法是简单地使用相等运算符
function log() {
    console.log('something');
}


class Car {
  constructor(name,log)  {
    this.name = name;
  }
  log = log
  
}


const audi =  new Car("some");
audi.log();

第三种方式是使用原型

function log() {
    console.log('something');
}


class Car {
  constructor(name,log) {
    this.name = name;
  }
  
}

Car.prototype.log = log;

const audi =  new Car("some");
audi.log();

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?