html5 笔记01

01 表单类型和属性

input的type属性

单行文本框: type=text

电子邮箱 : type=email

地址路径 : type= url

定义用于输入数字的字段: type=number

手机号码: type=tel

搜索框 : type=search

定义颜色选择器 : type=color

滑块控件 : type=range

定义日期 :type=date

定义输入时间的控件(无时区): type=time

日期时间:type=datetime-local

定义月份和年份:type=month

定义周和年控件:type=week

表单的新增属性

placeholder 占位符

autofocus 自动获取焦点

required 在提交表单之前必须填写输入字段

autocomplete 自动完成 默认值为on 开启 off 关闭提示功能

multiple 文件多选

02 音频标签(audio)

h5之前的网页没有办法显示音视频 用插件 flash

video audio 用法和img一样

video和audio的属性:

controls 规定应显示音频控件

autoplay 自动播放

loop 循环播放

兼容写法:

03 视频标签 (video)

poster 视频封面图

perload 预加载

autoplay 自动播放

muted 静音播放

兼容写法:

04 进度条标签

<progress> 标签表示任务的完成进度

属性:

max 规定任务所需的总工作量。默认值为1

value:规定任务已完成的部分。

05 canvas绘图

1. canvas 特点:

有自己默认高度: 300*150

不建议通过css设置宽高 使用行内属性设置宽高

canvas 不独占一行 属于行内块元素

canvas 一般建议兼容写法: 标签内部定义文字

2. canvas的使用步骤

定义canvas标签

<canvas style="border: 1px solid #000;" width="400" height="400">

您的浏览器版本不支持canvas绘图技术

</canvas>

js获取canvas对象

var mycanvas=document.getElementsByTagName('canvas')[0]

通过canvas对象获取画笔对象

var ctx=mycanvas.getContext('2d');

3.canvas绘制线的使用

.moveTo(x,y) 定点方法(当前画笔从哪里开始绘制)

.lineTo(x,y) 从当前定点位置开始 绘制到x,y点结束

.stroke() 描边

描边才能看见线 如果想要画多条线 要都画完再去描边 减少和浏览器的交互次数

.fill() 填充(把图形跳虫成实心的) 未闭合的图形会自动闭合

.closePath() 自动闭合图形

.lineWidth=数值 设置线的宽度

.strokeStyle='颜色' 设置描边的颜色(只针对描边图形生效)

.fillStyle='颜色' 设置填充的颜色(默认黑色)

.beginPath() 开辟新路径

上面的代码最终结果是两条线长一样

原因是 我们虽然描边了两次 但是canvas源码内部处于性能优化方面考虑

多次描边 只会按照最后一次的样式 一次性描边上去 节省性能

4.画笔的一些功能

ctx.lineCap 线两端的样式:

butt 默认值 没有样式

round 两端圆形

square 两端方块

交叉点:

上一条线的结束点 为第二条线的起点 这样才被识别为 交叉点

才可以设置交叉点样式

ctx.lineJoin="" 交叉点的样式

miter(默认值 不转换) 一个尖尖的 尖儿

round(交点呈现圆角)

bevel(平角样式,不呈现尖角)

不设置交叉点样式时 可以设置

ctx.miterLimit属性 0~5都是平角 6~9都是尖角

5.绘制矩形

.rect(x,y,width,height) 绘制一个矩形

可以通过fill画实心,也可以通过stroke画空心

.strokeRect(x,y,width,height) 直接绘制一个空心矩形

不用再次调用stroke方法 快速描边一个矩形

.fillRect(x,y,width,height) 直接绘制一个填充矩形

不用再次调用fill方法 快速填充一个矩形

6.绘制弧形

弧的绘制:

ctx.arc(圆心x,圆心y,半径r,开始弧,结束弧,布尔值(方向:顺/逆) 可选)

布尔值默认是false(顺时针) 开始的位置默认在右侧

例:

设置负值 然后结束的是45度 表示把剩余的都画了

ctx.arc(200,200,100,0,-Math.PI/180*45)

7.清除绘制内容

清除绘制内容(橡皮擦)

ctx.clearRect(x,y,width,height);

8.绘制文本

ctx.strokeText(str,x,y) 绘制空心字体

ctx.fillText(str,x,y) 绘制实心字体 默认比上面黑一些

ctx.font="20px 宋体" 字体大小(必须写family)

ps:只有字体变大才能看出stroke的效果

ctx.font="bold 50px 宋体" 可以有加粗效果

ctx.textBaseLine=""; 文本基线问题:

alphabetic 默认值 按照默认的字母基线对齐

top 顶部为基线

bottom 文本底部为基线

haning 如果有中文 那么比较top来说 更往下一点

ideographic 比bottom还往上一点

middle 文字中部对齐

ctx.textAligin="" 文本横向对齐方式

start/left end/right center

9.渐变的使用

先创建渐变对象 然后使用strokeStyle/fillStyle 引入渐变对象

10.阴影的绘制

Ctx.shadowColor="颜色" 阴影颜色

Ctx.shadowBlur=number 阴影模糊度

Ctx.shadow.OffsetX =number 模糊X轴

Ctx.shadow.OffsetY=number 模糊Y轴

Tips:filleRect和filleText都有阴影效果哟

11.canvas画图

绘制图片的方法

1.Ctx.drawImage(image,x,y)

参数1: 图片对象 参数23 图片绘制位置

按照原图片大小绘制

  1. Ctx.drawImage(image,x,y,width,height)

width和height可以改变图片大小

3.Ctx.drawImage(image,x,y,width,height,dtx,dty,dtwidth,dtheight)

图片对象 从哪一个点开始截取 截取的宽高 在哪一个点开始画 画的宽

能够从图片中截取一部分 画到canvas指定位置 并且 定义画的宽高

12.canvas转换的使用

Canvas中的转换只有旋转,位移,缩放

ctx.translate(x,y) 将canvas的0,0点平移到x,y位置

画布整体被往下平移以后 后面画的元素都会按照新的点去画

Ctx.scale(x,y) 缩放

会把内部的内容全部按比例缩放

Ctx.rotate(Math.PI/180*30) 参数是角度弧

相关推荐
黄毛火烧雪下5 分钟前
React 深入学习理解
前端·学习·react.js
自不量力的A同学1 小时前
如何下载和安装Firefox 134.0?
前端·firefox
@_猿来如此2 小时前
Web网页制作之JavaScript的应用
前端·javascript·css·html·html5
9命怪猫6 小时前
AI大模型-提示工程学习笔记5-零提示
人工智能·笔记·学习·ai·提示工程
顾尘眠6 小时前
http常用状态码(204,304, 404, 504,502)含义
前端
达子6667 小时前
笔记-使用ffmpeg产生rtsp视频流,然后用进行VLC播放
windows·笔记·ffmpeg
王先生技术栈7 小时前
思维导图,Android版本实现
java·前端
悠悠:)8 小时前
前端 动图方案
前端
m0_726965988 小时前
Harmony开发【笔记1】报错解决(字段名写错了。。)
笔记·bug·debug·harmonyos
星陈~8 小时前
检测electron打包文件 app.asar
前端·vue.js·electron