如何给构造函数/原型函数增加值?
How can I add value to a constructor/prototype function?
假设我有一个这样的构造函数
function Persons(lastName) {
this.lastName = lastName;
this.firstName = [];
}
然后是这样的原型
Persons.prototype.getFirstName = function() {
getName();
return firstName;
}
和getName函数
var getName = function() {
}
如果我在getName中想要发送值"Andrew"到数组this。firstName = [];我怎么能做到呢?这可能吗?
您可以将数组传递给函数并在那里填充它:
Persons.prototype.getFirstName = function() {
getName(this.firstName);
return this.firstName;
}
var getName = function(arr) {
arr.push("Andrew");
}
或者您可以从函数返回值并在方法中设置它:
Persons.prototype.getFirstName = function() {
this.firstName.push(getName());
return this.firstName;
}
var getName = function() {
return "Andrew";
}
是可能的,像这样:
var getName = function(person) {
person.firtName.push("Andrew");
};
然后在你的prototype
中:
Persons.prototype.getFirstName = function() {
getName(this);
return firstName;
};
但是看起来不太好。这似乎是一种不好的做法。无论如何,希望这对你有帮助。
您可以使用Function
的call
方法,如下所示:
Persons.prototype.getFirstName = function() {
getName.call(this);
}
这样就可以将this
引用绑定到getName
函数,这样就可以像下面这样安全地访问它:
var getName = function() {
this.firstName.push("Andrew");
}
您可以在这里找到更多关于call
的详细信息。
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Node.js v6.2.0类扩展不是函数错误
- 比较从函数和生成的日期对象
- javascript函数,它将数组作为输入,将每个数组元素增加1,并返回增加值的新数组
- 如何给构造函数/原型函数增加值?