1 .必须结束标签,严谨的结构,所有标签必须闭合
2 .小写的元素和属性名
3 .标签合理嵌套,层层嵌套必须是严格对称的。
4 .属性必须括起来
5 .特殊的符号使用编码表示
1.任何小于号,大于号,&号,当他们不是实体的一部分,都必须使用编码字符
aria:用来标识页面中涉及到动态交互的地方,这些交互通常需要js和相关技术来实现,例如浮出层,对话弹出层,下拉列表等。无障碍网页应用,主要针对视觉缺陷,失聪,行动不便的残疾人以及假装残疾的测试人员。借助辅助设备可以大声朗读出盲文,aria可以让屏幕阅读器准确识别网页中的内容,变化,状态的技术规范,让这类人也无障碍阅读
1 .屏幕读取器,语音识别软件和屏幕键盘均通过特定的语义标签读取网页组件本质信息,而aria角色在语义化表示约定方面有着至关重要的作用。
2 . aria允许开发者为任何html元素添加一个简单的属性,aria的role根据上下文判断某个元素的作用和性质,也就是说,比如标签不一定是原来表示的。
3 .tabIndex:原本的html中,只有a标签和表单元素可以被键盘访问,即使是a也必须加上href属性才可以。tabindex=0,该元素可以使用tab取到,tabindex=-1,使用tab键取不到焦点,但是可以通过过js获取
4 .aria将元素分为6种的role,以及对应的states和properties,但是有一些事公用的。
5 .<div role="radio" aria-checked="true" aria-label="单选2" tabindex="0">单选tabindex="0"</div>//这个div模拟了radio的功能,平时是看不出来的,但是加上role以及aria-checked,就可以读出他的属性了
6 .https://www.cnblogs.com/webapplee/p/3771690.html
快速介绍
1.html文档由元素和文本树组成,每个元素使用开始标记和结束标记表示。也有一些开始标签和结束标签在某些情况下可以省略,并由其他标签代替
1.
2 .标签必须嵌套,使元素完全在彼此之内,不发生重叠。
3 .本规范定义了一组可以在html中使用的元素,以及有关元素嵌套方式的规则,元素可以具有控制元素如何工作的属性。属性放在开始标签内。
4 .html用户代理解析html,把他变成一个dom树,dom树就是文档在内存中的表现形式。
dom标准
1 .dom树种中有的节点比预期的多,因为包含了大量的空格和换行符,这些空格最终都是text节点。
使用脚本api的时候要避免常见的缺陷
1 .由于html文件的解析是逐渐发生的,这就意味着解析器可能随时暂停,让脚本运行。但是一旦脚本里面有事件,可能会触发不了。
2 .解决办法:1事件处理程序内容属性。就是添加事件在元素内,比如img的onload事件2.创建元素的时候并在同一段脚本中添加事件。就是千万不能把他们分来来写。那样就会出现上面的错误。也就是说,如果是现在上面创建了img元素,然后在脚本单独添加了事件监听器,那么load事件就有可能在两者之间触发,导致错过。
页面尽量避免的错误结构
1 .<p><i>111
2 .<p><i>222
3.<p><i>333
4.尽量不要写这样的dom结构。会重复渲染
h5代码规范
1 .命名规则:class:单词全部小写,驼峰写法。id:必须唯一性,命名有明确的语义。
标签
1 .html的标签必须使用小写字母
2 .标签的闭合要符合h5的规定
3 .标签的使用必须符合标签的嵌套规则
4 .书写链接的时候,必须避免重定向。例如:href='http://www.baidu.com/'在最后一个地址后面加上'/'
5 .在页面中尽量避免使用style属性,即style=''
6 .语言编码,有助于提高页面的可访问性,必须设置正确的lang属性,<html lang="en">
7 .禁止设置img的src取值为空,延迟加载也要设置默认的src属性。重要图片添加alt属性值,添加width,height属性可以避免页面抖动
8 .文本控件必须使用label标签将其与相关标题联系在一起。
9 .使用button的时候必须指明type属性值。
10 .在html中,有一些元素的属性,当只写属性名称而不指定属性值时,属性值为true,如果设置该属性值为false,则不使用该属性即可
标签的使用必须遵循标签的语义
1 .p-段落
2 .h1-h5-层级标题
3 .strong,em-强调
4 .ins-插入
5 .del-删除
6 .code-代码
7 .abbr-缩写
8 .cite-引述来源作品的标题
9 .q引用
10 .blockquote-一段或长篇引用
11 .ul,ol
12 .dl,dt,dd-定义列表
css文件分类
1 .模块:module.css
2 .基本公用:base.css
3 .布局,版面:layout.css
4 .主题:themes.css
5 .专栏:columns.css
6 .文字:font.css
7 .表单:forms.css
8 .补丁:mend.css
9 .打印:print.css
页面id命名
1 .主题:main
2 .内容:container
3 .侧栏:sider
4 .子导航:subnav
5 .顶导航:topnav