热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【前端小小白的学习之路】HTML5最佳实践webapp

简介本文重点关注如何充分利用HTML5和CSS让webapp运行更加流畅.Tip1:使用webstorage代替cookiecookie最大的缺陷是在每一次HTTP请求中都会携带所有符合规

简介 
本文重点关注如何充分利用HTML5和CSS让web app运行更加流畅.

Tip 1: 使用web storage代替COOKIE 
COOKIE最大的缺陷是在每一次HTTP请求中都会携带所有符合规则的COOKIE数据.这会增加请求响应时间,特别是XHR请求. 
在HTML5中使用sessionStoragelocalStorage代替COOKIE是更好的做法.

这种方法可以将数据永久或者以session时间存储在用户本地.数据不会随着HTTP请求传递.所以我们优先使用web storage,仅仅使用COOKIE作为替代方案.

// if localStorage is present, use that

if (('localStorage' in window) && window.localStorage !== null) {



// easy object property API

localStorage.wishlist
= '["unicorn", "Narwhal", "deathbear"]';



}
else {



// without sessionStorage we'll have to use a far-future COOKIE

// with document.COOKIE's awkward API

var date = new Date();

date.setTime(date.getTime()
+ (365 * 24 * 60 * 60 * 1000));

var expires = date.toGMTString();

var COOKIEstr = 'wishlist=["unicorn", "Narwhal", "deathbear"];' +

' expires=' + expires + '; path=/';

document.COOKIE
= COOKIEstr;

}

Tip 2: 使用CSS Transition代替Javascript动画

CSS Transition能带来更高的性能,更少的代码,更容易维护和理解.

Tip 3: 使用客户端数据库代替服务器请求

Web SQL Database和IndexedDB让浏览器有了数据库存储能力.很多应用场景可以迁移到客户端数据库以减少服务器的请求次数.

localStoragesessionStorage在简单数据存储时比客户端数据库更快,可以用来实现一些简单的状态,进度保存.

当一个组件需要管理上百条数据(如好友列表),同时支持用户搜索, 过滤, 排序时, 客户端数据库存储一份数据可以有效减少HTTP请求次数. 查看Web SQL Database tutorial获取详细指导.

Tip 4: 使用Javascript原生API

随着更高版本Javascript的普及, 像Array prototype新增了很多API都可以在大多数浏览器中直接使用.例如:

// give me a new array of all values multiplied by 10

[
5, 6, 7, 8, 900].map(function (value) {

return value * 10;

});

// [50, 60, 70, 80, 9000]



// create links to specs and drop them into #links.

var linksList = document.querySelector('#links');

var links = [];

[
'html5', 'css3', 'webgl'].forEach(function (value) {



links.push(value.link(
'http://google.com/search?btnI=1&q=' + value + ' spec'));

});

linksList.innerHTML
= links.join('');



// return a new array of all mathematical constants under 2

[
3.14, 2.718, 1.618].filter(function (number) {

return number <2;

});



// you can also use these extras on other collections link nodeLists

[].forEach.call(document.querySelectorAll(
'section[data-bucket]'),

function (elem, i) {

localStorage[
'bucket' + i] = elem.getAttribute('data-bucket');

});

通常情况下这些原生方法比手动编写循环要快:

for (var i = 0, len = arr.length; i i) {

}

使用原生JSON.parse()json2.js更加高效,安全.

原生的String.prototype.trim也是一个很好的例子, 这些功能不是HTML5中的,也应该得到广泛的应用.

Tip 5: 不仅仅为离线app使用cache manifest,在线网站网站也可以适当使用

后台管理系统这样的站点使用缓存可以极大提高性能.

cache manifest比设置Expires有一些优势:明确地声明需要缓存的文件,浏览器可以进行优化,可能在你使用之前就已经提前下载到本地了.

可以将页面基本结构看做模板, 显示的内容随着数据变化, 将可模板化的HTML结构通过cache.manifest进行缓存, 从服务器端获取JSON数据之后更新内容.

查看application cache tutorial获取详细指导.

Tip 6: enable硬件加速来增强视觉体验

某些浏览器可能使用GPU加速让高速动画更加平滑.Firefox Minefield, IE9, Safari已经宣称实现了硬件加速. Chromium也增加了window平台的3D transform加速.各个浏览器对硬件加速的支持肯定会越来越好.

在支持并启动了硬件加速的情况下, 动画, rotation, scaling, opacity肯定会更加平滑. 所有实际操作都发生在GPU而不需要内容的重绘. 然而需要注意的是,任何影响页面布局的操作都会降低速度.

Tip 7: 使用web worker执行需要大量CPU资源的操作

web worker有两个好处: 1) 快速 2) 不阻塞浏览器响应. 点击web worker slide查看更多信息.

web worker的一些可能的使用场景:

长文本格式化

语法高亮

图片处理

图片合成

大数组处理

Tip 8: HTML5 表单属性和input类型

HTML5增加了一系列input type,包括search, tel, url, email, datetime, date, month, week, time, number, range, color等. 在支持这些功能的浏览器中使用原生功能, js插件作为补充.

placeholder, required, pattern都能极大提高页面的可用性,和性能.

Tip 9: 使用CSS3减少图片的使用

减少图片能减少HTTP请求,同时减少页面大小,更容易维护,常用的属性如下:

linear and radial gradients

border
-radius

box
-shadow

rgba

transform

css mask

常见的使用场景有: polished buttons via gradients, replicate many other effects

Tip 10: 使用WebSocket代替XHR提供更快交互和更少的带宽

WebSockets是为了Comet而设计的. 使用它实现Comet比XHR确实带来更多的好处.

参考:http://mp.weixin.qq.com/s/U8FRxmcHAQIGKpfWjAm-7w


推荐阅读
  • 本文介绍了使用C++Builder实现获取USB优盘序列号的方法,包括相关的代码和说明。通过该方法,可以获取指定盘符的USB优盘序列号,并将其存放在缓冲中。该方法可以在Windows系统中有效地获取USB优盘序列号,并且适用于C++Builder开发环境。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Java大文件HTTP断点续传到服务器该怎么做?
    最近由于笔者所在的研发集团产品需要,需要支持高性能的大文件http上传,并且要求支持http断点续传。这里在简要归纳一下,方便记忆 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • adfs是什么_培训与开发的概念
    adfs是什么_培训与开发的概念(如您转载本文,必须标明本文作者及出处。如有任何疑问请与我联系me@nap7.com)ADFS相关开发技术的中文资料相对匮乏,之前在弄这个东西的时候 ... [详细]
  • 渗透测试基础bypass绕过阻挡我们的WAF(下)
    渗透测试基础-bypass ... [详细]
  • SQLiLabs靶场的介绍、下载与安装
    介绍SQLi-Labs是一个专业的SQL注入练习平台下面的测试场景都支持GET和POST两种注入方式:1.报错注入(联合查询)1)字符型2)数字型2.报错注入(基于 ... [详细]
author-avatar
KNN
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有