Javasctipt 从数组调用对象的函数
Javasctipt call object's function from array
index.html
<body>
<canvas id ="mainCanvas" width = "400" height = "400"></canvas>
<script src ="script.js"></script>
<script src ="test.js"></script>
</body>
测试.js
var canvas = document.getElementById("mainCanvas")
var context = canvas.getContext("2d")
var array = [
context.fillRect
]
array[0](10,10,10,10)
它说:
未捕获类型错误:非法调用
通常这个context.fillRect(10,10,10,10)
工作...
那么为什么我不能从数组中调用该引用呢?
这里的问题实际上是上下文。当你输入array[0]时,你就在该函数对象的上下文中(函数是javascript中的一个对象)。但是您希望处于上下文变量的上下文中。所以有两种解决方案
var canvas = document.getElementById("mainCanvas")
var context = canvas.getContext("2d")
var array = [
function(params) {
context.fillRect(params)
}
]
array[0](10,10,10,10)
或使用call
的第二种方法
var canvas = document.getElementById("mainCanvas")
var context = canvas.getContext("2d")
var array = [
context.fillRect
]
array[0].call(context,10,10,10,10)
相关文章:
- 在javascript中调用函数/对象引用时,可容纳任何数据类型
- 访问函数对象的上下文属性|如何
- 为什么可以'我们在函数体中为函数对象添加属性,就像在javascript中为对象文字添加属性一样
- 如何将函数对象从javascript传递到Polymer元素
- 为什么函数对象的实例没有继承函数原型属性
- 为什么我会从 JavaScript 函数返回一个命名函数(对象)
- 为什么实例构造函数指向最上面的函数构造函数对象
- 使用object.freeze()扩展函数对象-can't添加字段
- 为什么'这'与函数对象一起使用时会有不同的处理方式
- setTimeout()/setInterval()赢得't执行**我正在传递函数对象,而不是执行函数
- 为什么茉莉花间谍不't通过引用解析函数对象
- 在 mongo map 中调用外部 javascript 函数(对象)或减少上下文的可能方法
- 在 JavaScript 中为函数对象添加别名
- 在 Express JS 中从路由调用函数对象
- 函数对象的名称属性是什么
- 构造函数对象
- 节点.js - 从另一个函数/对象发出事件
- 声明函数是否会创建具有函数名称和分配给它的函数对象的变量
- 函数对象__proto__和原型属性
- 类仿真 - 模块模式与函数对象