[whatwg] Canvas should be script-only, not an HTML element
Lenny Domnitser
ldrhcp at gmail.com
Sat May 28 08:27:13 PDT 2005
Creating a non-semantic <canvas> element as the only element that can
be drawn on is backwards. Instead, a scripting interface to drawing
should take any element as a context node. So instead of this [1]:
<html>
<head>
<script type="application/x-javascript">
function init() {
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
ctx.fillStyle = "rgb(200,0,0)";
ctx.fillRect (10, 10, 50, 50);
ctx.fillStyle = "rgba(0, 0, 200, 0.5)";
ctx.fillRect (30, 30, 50, 50);
}
</script>
</head>
<body onload="init()">
<canvas id="canvas" width="300" height="300"></canvas>
</body>
</html>
I propose this:
<html>
<head>
<script type="application/x-javascript">
function init() {
var canvas = new Canvas(document.getElementById("canvas"));
var ctx = canvas.getContext("2d");
ctx.fillStyle = "rgb(200,0,0)";
ctx.fillRect (10, 10, 50, 50);
ctx.fillStyle = "rgba(0, 0, 200, 0.5)";
ctx.fillRect (30, 30, 50, 50);
}
</script>
</head>
<body onload="init()">
<div id="canvas" width="300" height="300"></div>
</body>
</html>
The significant changes are that the scripting canvas is not a
document node and that the element drawn on is a DIV.
I only proposed a minimal change, but if this method of drawing is
used over a canvas element, the script could be simplified to replace
getContext() with:
var ctx = new 2DCanvas(document.getElementById('canvas'));
[1]: http://developer-test.mozilla.org/docs/Drawing_Graphics_with_Canvas#A_Simple_Example
More information about the whatwg-whatwg.org
mailing list