Web最佳实践阅读总结(2)
代码符合标准
- 标准的页面会保证正确的渲染
- 页面容易被搜索引擎搜索,提高搜索排名(SEO)
- 提高网站的易用性
- 网页更好维护和扩展(Validator,HTML Validator 属于Firefox插件)
停止使用不标准的标签和属性,简化HTML代码
- 标签没有实际意义,仅设置样式(不推荐使用)
- 不推荐使用blink,marquee
- 让HTML拥有更好的语义
- 移除不常用的HTML标签
样式和结构分离
- HTML页面链接一个CSS(最优),提高加载速度
- HTML内嵌CSS(单一页面最佳,减少加载CSS样式文件的请求数目,加快加载速度
- 内联CSS样式,可以使用JS动态来统一修改,很少使用,JQ中使用其实现动画效果
- 在CSS样式文件中引用CSS文件,避免使用
添加JS禁用提示信息
- 使用noscrpt,HTML4只在body中起作用,HTML5中可以出现在head中,支持HTML,不支持XHTML
- 最好使用noscript,采用渐进增强的模式,平稳降级
添加必要的meta的标签
- meta的属性:name,http-equiv,content,charset
- name和content属性组合,构成名称/值对
- name中keywords,description最常用
- http-equiv和content属性结合,构成http命令
- 其中content-type,default-style,refresh已经确定,content-language,set-cookie 未正式确定
- charset设置编码
常用的meta方法
- 设置IE浏览器的兼容性
- 设置页面在移动设备中的显示
- 设置IE浏览器的固定网站功能
HTML语义化
- 语义化使搜索引擎和第三方抓取工具更容易读懂代码
- 去掉CSS也可以保持良好的外观
- div,span尽量少使用
- 把无关的元素重HTML中删除
- 添加一些隐藏文字
要求:
- 熟悉所有规范中的HTML标签,理解各标签的语义
- 熟悉各标签上规范的属性,给HTML标签设置必要的属性
- 样式和结构的分离
构建页面标题的最佳实践:
- 使用hx标签
- 页面只是使用一个h1
- hx使用过程中不要跳级
- 不要使用hx设置样式
设计表单:
- 使用label标签,并设置label标签的for属性
- 给输入控件设置合适的水印提示
- 输入控件设置tab顺序
- 使用HTML5中引入的表单控件
HTML5新特性使用
async和defer属性
- 不使用在内联里面
- defer:以并行的方式下载脚本,而不是阻塞的方式下载,在脚本加载完成后,浏览器会在DOM触发之前按照引用顺序运行JS
- async:以异步的方式下载脚本,在下载结束后立即执行代码,而不会等待页面解析结束
- 在设置async时候,推荐同时设置defer属性,提高脚本加载执行的性能
- 标签上的自定义属性data-*
- script可以编写HTML模板和XML数据
选择器注意
- 尽量不使用ID选择器
- 减少子选择器的层级(less和Sass的滥用)
使用组合CSS类选择器
兼容IE浏览器
- 兼容旧浏览器的代码,被称为hack代码
- 熟悉IE浏览器中常见的兼容样式
分离样式兼容代码
.color{ _color:green;} ( IE6 (含 IE6 ) 以下) .color{ *color:gray; } ( IE7 ( 含 IE7 )以下) .color { color:green \0; } ( IE8 + ) .color { color:green \ ; } ( IE8 . IE9 ) :root .color { color:green \0; } ( IE9 + ) .color { color:green \9\0; } ( IE9+ ) .color { color:green \9; } ( IE10 ( 含 IE10 ) 以下 ) *::-ms-backdrop, .color{ color:red; } ( IE11 ) * html .color { color: red; } (IE6 ONLY ) *+html .color { color: red; } ( IE7 ONLY ) @media screen\9 {
.color { color: black; }
} ( IE6 . IE7 )
@media \0screen {
.color { color: black; }
} ( IE8 ONLY )
@media \0screen, screen\9 {
.color { color: black; }
} ( IE6 . IE7 . IE8 )
@media screen\0 {
.color { color: black; }
} ( IE8 . IE9 . IE10 )
@media screen and (min-width: 0\0) {
.color { color: black; }
} ( IE9 . IE10 ) @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
.color { color: black; }
} ( IE10 ONLY ) @media all and (-ms-high-contrast:none){
.color { color:greeny \0; }
} ( IE10 + ) @media all and (-ms-high-contrast:none){
*::-ms-backdrop, .color { color:green \0; }
} ( IE11 + )
em,px,%
- px:绝对尺寸,em:应用元素上字体大小的两倍,%:相对于父元素的百分比
- 尽量设置相对尺寸
- 只有在可预知元素尺寸的情况下才使用绝对尺寸
- 使用em设置字体的大小
Web最佳实践阅读总结(2)的更多相关文章
- Web最佳实践阅读总结(1)
介绍 最近开始刷一些书和题,此系列是介绍在读Web最佳实践的一些收获和体会. web前端发展现状 存在问题: 代码组织混乱 代码格式的问题突出 页面布局随意 网站整体性能差,没有意识到应用诸如缓存,动 ...
- PHP-PHP核心技术与最佳实践阅读
1.对象的实质: 对象就是数据, 对象本身不包含方法, 但是对象有一个"指针"指向一个类, 这个类里可以有方法 2.反射是指在PHP运行状态中, 扩展分析PHP程序, 导出或者提取 ...
- Web 前端最佳实践
Web 最佳实践 前端 选择器 尽量使用ID选择器 基于Id的选择器:先使用ID选择器定位,然后再使用find方法精确查找 // Fast: $( "#container div ...
- 【转】优化Web程序的最佳实践
自动排版有点乱,看着蛋疼,建议下载中文PDF版阅读或阅读英文原文. Yahoo!的Exceptional Performance团队为改善Web性能带来最佳实践.他们为此进行了 一系列的实验.开发了各 ...
- Web前端优化最佳实践及工具集锦
Web前端优化最佳实践及工具集锦 发表于2013-09-23 19:47| 21315次阅读| 来源Googe & Yahoo| 118 条评论| 作者王果 编译 Web优化Google雅虎P ...
- 【Web前端开发最佳实践系列】前端代码推荐和建议
一.常用的前端文件的组织结构: 1.js (放置JavaScript代码) lib(放置框架JavaScript文件) custom.js 2.css(放置CSS样式代码) lib(放置框架CSS文件 ...
- 《modern-php》 - 阅读笔记 - 最佳实践
过滤.验证和转义数据 过滤数据 不要相信任何外部数据! 常见的有以下几种数据需要过滤:HTML,SQL查询,用户提交的信息(邮件地址.电话号码.身份证) HTML htmlentities() HTM ...
- JavaScript Web 应用最佳实践分析
[编者按]本文作者为 Mathias Schäfer,旨在回顾在客户端大量使用JavaScript 的最佳 Web应用实践.文章系国内 ITOM 管理平台 OneAPM 编译呈现. 对笔者来说,Jav ...
- 【社区公益】送《Web前端开发最佳实践》给需要的人
算起来至今,我进入软件开发行业已经有11年之久.从最初的研究人工智能,到后来的Web开发,控件开发,直到现在纯粹的Web前端开发.虽然没有大的作品问世,但也是勤勤恳恳,踏实做事,低调做人.从来不吹牛逼 ...
随机推荐
- HDU-4553 约会安排(线段树维护连续区间)
http://acm.hdu.edu.cn/showproblem.php?pid=4553 Problem Description 寒假来了,又到了小明和女神们约会的季节. 小明虽为屌丝级码农,但 ...
- django,inspectdb,操作已经存在的表
1.Django附带了一个名为inspectdb程序,它可以通过现有数据库来创建模型,并将相关模型代码另存到指定文件中.在新建的newmodels.py文件中挑选指定表格对应的模型代码,并将其复制到相 ...
- vue2.XX 提示[Vue warn]: Error in render: "TypeError: Cannot read property 'img' of undefined"
item 是向后台请求的一条数据,里面包含img,但是却提示img未定义 父组件向子组件传递数据时, 子组件 具体代码: <img :src="item.img" /> ...
- 2018安卓巴士开发者大会打造Android技术盛宴
2018安卓巴士开发者大会打造Android技术盛宴2018安卓巴士开发者大会将于8月25日在上海举行,作为中国最具前沿性.专业性的安卓技术会议,将邀请来自爱奇艺.阿里.饿了么等知名企业的一线工程师分 ...
- Java为什么能够跨平台?
首先介绍一下Java的各个层级,先放一张图: 硬件,操作系统和操作系统接口:这三级不说大家都知道,操作系统有很多种,比如Windows,Linux.Windows又分为win7,win10,win x ...
- 科技报告|AD报告|DTIC|PB报告|STAR|ERA|NTIS|DTIC|DOE|EPA|NASA |JPL|
信息检索-科技报告是灰色文献获取渠道有限. 技术论文中因保密需要,会删除关键性技术. AD报告也产生较早,1951年开始出版.现由美国国防技术情报中心(DTIC:Defence Technical I ...
- [LC] 56. Merge Intervals
Given a collection of intervals, merge all overlapping intervals. Example 1: Input: [[1,3],[2,6],[8, ...
- Qt QImag图像保存、格式转换
图像保存bool QImage::save(const QString &fileName, const char *format = Q_NULLPTR, int quality = -1) ...
- “冰桶挑战”之外:微软科技助力ALS患者
编者按:"直到ALS出现治疗方法,科技就是我的解药."ALS患者,前美国橄榄球联盟(NFL)球员Steve Gleason如是说.最近,一支微软首届黑客马拉松(Hackathon) ...
- python djangjo 文件上传
视图: request.GET 获取数据 request.POST 提交数据 request.FILES 获取文件用 checkbox 等多选的内容 request.POST.getlist ...