当使用HTML5画布,我们不断与画布交互上下文对象,其中包含丰富的样式属性和绘画方法降温。对一个典型的代码块绘制到画布上的东西,我们画一个路径,设置一些上下文属性风格不管我们画画,然后使用方法如fill()和stroke()实际绘制到画布上。块蛋糕,对吗?
但是如果我们创建大型的、复杂的帆布应用程序中,我们有很多方法和函数,画的东西放到画布上可以以任何顺序执行哪一个?我们当然不希望风格从我们的代码库的不同部分流入其他地方的代码库。这里有一个例子:
<!DOCTYPE HTML>
<html>
<canvas id="myCanvas" width="580" height="200"></canvas>
<script>
function drawTransparentSquare(context) {
context.fillStyle = 'red';
context.globalAlpha = 0.5;
context.fillRect(100, 20, 100, 100);
}
function drawSquare(context) {
context.fillStyle = 'red';
context.fillRect(300, 50, 120, 120);
}
var canvas = document.getElementById('myCanvas');
var context = canvas.getContext('2d');
drawTransparentSquare(context);
drawSquare(context);
</script>
</html>