在画布上绘制时,“未捕获的类型错误:无法读取未定义的属性'getContext'”
"Uncaught TypeError: Cannot read property 'getContext' of undefined" when drawing on canvas
每当我调用应该在画布上画一个圆的函数时,我都会收到上述错误。错误发生在"我的文档"var ctx = c.getContext("2d");
布局如下的行上:
应该画圆的函数在头部:
function circleTrans() {
var c = $(this).find('canvas')[0];
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.arc(95,50,40,0,2*Math.PI);
ctx.stroke();
}
调用函数的事件也在上述之后的头部中:
$(".projectContainer").click(function(){
circleTrans();
});
因此,当单击多个"projectContainer"div之一时,相应div中的画布应绘制一个圆圈。下面是项目容器的位置,稍后在正文中:
<div class="projectContainer" name="Film Festival">
<canvas class="canvases"></canvas>
</div>
有人知道错误的原因吗?
你调用函数的方式,this
不是元素。
像这样引用它以获得正确的this
值
$(".projectContainer").on('click', circleTrans);
正如 Adeneo 所说,this
不是元素,还有另一种方式可以传递元素,例如,
$(".projectContainer").click(function(){
circleTrans(this);
//pass element-^
});
获取div
元素作为参数cthis
function circleTrans(cthis) {
//--------^
var c = $(cthis).find('canvas')[0];
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.arc(95,50,40,0,2*Math.PI);
ctx.stroke();
}
相关文章:
- TypeError:无法读取属性'推'未定义的JavaScript
- 同样,同样的错误'ahorcado.js:26未捕获类型错误:无法读取属性'beginPath'
- 未捕获的类型错误:无法读取属性'删除'的未定义
- AngularJS指令出错-无法读取属性'编译'的未定义
- 未捕获的类型错误:无法读取属性'name'即使它存在,也无法定义
- 看到“;未捕获的类型错误:无法读取属性'weight'未定义的“;尽管按照字面上的指示
- 无法读取属性'材料'未定义的Three.js
- 得到"TypeError:无法读取属性'filename'未定义的“;调用“npm start
- Soundcloud api"未捕获的类型错误:无法读取属性'uri'“未定义”;
- 未捕获的类型错误:无法读取属性'addEventListener'的null chrome扩展名
- Soundcloud Javascript SDK 3.0-回调无法读取属性'connectCallback
- 未捕获的类型错误:无法读取属性'状态'在react中为null
- JavaScript承诺-无法读取属性'那么'的未定义
- Javascript Float32数组抛出无法读取属性'0'即使数组定义良好,也为null
- 未捕获的类型错误:无法读取属性'中止'的未定义
- 角度推入数组给出:TypeError:无法读取属性'推'的未定义
- http/rxjs catch回调中的Angular 2重定向导致TypeError:无法读取属性'订阅'
- Javascript未捕获类型错误:无法读取属性'0'的未定义
- jQuery控制台错误:无法读取属性'top'的未定义
- TypeError:无法读取属性'findAll'的未定义