JS:从按钮调用函数
JS: Calling a function from a button
我正在学习纯JavaScript。我的问题很基本,我希望有人能好心地给我指出正确的方向。在画布绘图练习中,我使用以下函数:
drawingTools.pencil = function () {
document.getElementById("activeTool").value = "Pencil";
this.mousedown = function (evt) {
isDrawing = true;
startX = getendY(tmp_canvas, evt);
};
this.mousemove = function (evt) {
compositeDraw()
endY = getendY(tmp_canvas, evt);
if (isDrawing) {
tmp_context.beginPath();
tmp_context.moveTo(startX.x, startX.y);
tmp_context.lineTo(endY.x, endY.y);
tmp_context.lineJoin = 'round';
tmp_context.lineCap = "round";
tmp_context.stroke();
tmp_context.strokeStyle = defaultLineColor;
tmp_context.lineWidth = defaultLineThickness;
}
startX = endY;
};
this.mouseup = function (evt) {
isDrawing = false;
drawtmp_contextOncanvas();
}
};
使用下面的代码行可以很好地工作:
pencil.addEventListener('click', this.changeDrawingTool, false);
当我尝试使用按钮图标调用drawingTools.pencil
函数时,如下:
document.getElementById("iconPencil").addEventListener('click', drawingTools.pencil, false);
上述功能未被触发。
演示:http://jsfiddle.net/pgyu7/在第二个选项
document.getElementById("iconPencil").addEventListener('click', drawingTools.pencil, false);
this
指向#iconPencil
元素。此元素不实现mousedown
, mousemove
要避免丢失this
,可以使用bind
document.getElementById("iconPencil").addEventListener('click', drawingTools.pencil.bind(pencil), false);
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量