贝利信息

javascript如何操作canvas绘制图形【教程】

日期:2026-01-24 00:00 / 作者:夜晨
Canvas绘图依赖状态驱动的2D上下文,需手动管理图像加载、样式设置和路径重置:drawImage前须等img.onload;fillRect/strokeRect依赖当前fillStyle/strokeStyle;多路径绘制必须用beginPath()隔离。

Canvas 绘图不是“写个函数就能出图”,关键在于理解 getContext('2d') 返回的绘图上下文对象如何被状态驱动——它没有自动重绘、不保留图形历史、所有操作都依赖当前路径和样式状态。

为什么 drawImage 后看不到图像?

常见原因是图像未加载完成就调用绘图方法。Canvas 不会等待图片加载,drawImage 对未就绪的 HTMLImageElement 无效,也不会报错。

fillRect 和 strokeRect 为什么有时画不出颜色?

这两个方法本身不设置颜色,完全依赖上下文当前的 fillStylestrokeStyle 值。如果没显式设置,它们会沿用默认值(fillStyle = '#000000',但若之前被设为透明色或非法值,就会“看不见”)。

beginPath 到底什么时候必须调用?

当你要绘制**多个独立路径**(比如两个不相连的圆),且不希望它们被意外连接时,beginPath() 是必须的。Canvas 路径是累积的,stroke()fill() 会作用于整个当前路径。

Canvas 的“难”不在 API 多,而在它把渲染控制权全交给你:没有图层、没有自动更新、没有坐标系封装。一个漏掉的 beginPath()、一次提前的 stroke()、一张没等加载的图片,都足以让画面静默——这些地方没法靠 console 看出来,得靠对状态流的预判。