以前用canvas画图时,都是直接在canvas标签里直接写上宽高,没有问题,但也没有探究过为什么宽高要直接写在canvas标签里,因为各个资料的例子上都是这么写的。今天王sir提出了一个问题:如果把宽高写在<style>里,看看会有什么不同。自己试了以下,果然有问题。
0 W2 N( B0 Y* Z1 l5 P0 X先看一下代码:1 u0 Y* a! R3 |% p6 X
代码如下:7 ^% M5 m1 v& I
<!doctype html> ]6 K! [: B) P M" P' n/ o9 n8 H4 n! ]
<html>
2 t0 U% n1 y% j3 [% b5 l<head>% `- E; p( k$ k! F
<meta charset=utf-8>& v, m6 l! S: V- a' L
<title>canvas</title>4 V6 Z! K, P3 X9 m! E8 |. E. g
<meta name=keywords content=>8 F% }4 @& ?& C) O
<meta name=author>- T* X6 m) K$ I' \
<style type=text/css>
; @; P4 \2 i4 f$ `6 Qbody{margin:0;}9 s2 D3 C0 P$ ^7 C; S- d) O
canvas{margin:20px;
~, I5 V$ m% D, G/*width: 400px;; @5 h4 | S |$ ]
height: 300px;*/: e1 S4 Z: t$ \4 Y$ K& T
}& i& {( @' i' G2 z+ B* s
</style>9 t+ K# n W& X T
</head>: }" \/ [- B" j& k- U( U( @- T
<body onload=draw()>4 a/ H7 C* x8 c* V+ F
<canvas id=canvas width=400 height=300 style=border:1px solid #f00;></canvas>, G8 g4 }2 S, O4 T( }* U. S
<script>
' i* V" j# A5 s& u" Q" w) @function draw() {' O" m% F! E6 L3 K6 w% z
var canvas=document.getelementbyid('canvas');
R! l. I( N2 s9 w7 d, mvar context=canvas.getcontext('2d');, T' |8 c. ~5 A/ Z
context.beginpath();6 v) j' Y2 z3 \% `' T
context.moveto(20,20);
/ e6 Y- t! o8 O t, P5 Y# m6 L' }0 lcontext.lineto(200,100);
1 E3 @$ A0 w' i# tcontext.linewidth=5;
6 d& E3 c, L# d; M3 h: F. m. rcontext.stroke();
+ Y2 l9 I1 Y5 }" ^0 }) Y, c9 e2 s: C}$ r( P9 |% C( W/ a" u }/ X
</script>) S( ^7 P3 {- W8 P' n9 J4 j
</body>
3 j( d& m i' A, y) H/ \3 L& h! E</html>% q; B+ u4 R" M; j: _
1.宽:400;高:300;直接写在<canvas>里的效果:- J/ }1 t' Y1 G# T$ @ Y8 v1 Y
名单
) E) e" u: F; d& x! I2、删除<canvas>里的宽高,宽:400;高:300;写在<style>里的效果:
( C- Q+ a7 g9 V4 ]) p7 b名单1
, t: ~9 Z0 J+ g& j) @# L K8 P- ?! u为什么两者的效果会不一样呢?
& L0 }" J8 w+ j; h# lcanvas跟其他标签一样,也可以通过css来定义样式。但这里需要注意的是:canvas的默认宽高为300px * 150px,在css中为canvas定义宽高,实际上把宽高为300px * 150px的画布进行了拉伸,如果在这样的情况下进行canvas绘图,你得到的图形可能就是变形的效果。所以,在canvas绘图时,应该在canvas标签里直接定义宽高。6 J" i) K" f) v0 r& H+ C* c( J
& i$ G/ `! P' d0 y更多网页制作信息请查看: 网页制作 |