使用闭包主要是为了设计私有的方法和变量。 优势是能够避免全局变量的污染, 缺点是闭包会常驻内存,会增大内存使用量,使用不当很容易形成内存泄露
第一:每一个特定的域名下最多生成20个cookiecss
1.IE6或更低版本最多20个cookie 2.IE7和以后的版本最后能够有50个cookie。 3.Firefox最多50个cookie 4.chrome和Safari没有作硬性限制
第二:cookie的最大大约为4096字节,为了兼容性,通常不能超过4095字节html
优势:极高的扩展性和可用性前端
1.经过良好的编程,控制保存在cookie中的session对象的大小。 2.经过加密和安全传输技术(SSL),减小cookie被破解的可能性。 3.只在cookie中存放不敏感数据,即便被盗也不会有重大损失。 4.控制cookie的生命期,使之不会永远有效。偷盗者极可能拿到一个过时的cookie。
缺点:web
1.`Cookie`数量和长度的限制。每一个domain最多只能有20条cookie,每一个cookie长度不能超过4KB,不然会被截掉。 2.安全性问题。若是cookie被人拦截了,那人就能够取得全部的session信息。即便加密也与事无补,由于拦截者并不须要知道cookie的意义,他只要原样转发cookie就能够达到目的了。 3.有些状态不可能保存在客户端。例如,为了防止重复提交表单,咱们须要在服务器端保存一个计数器。若是咱们把这个计数器保存在客户端,那么它起不到任何做用。
本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问而且当会话结束后数据也随之销毁。 所以sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储
用于持久化的本地存储,除非主动删除数据,不然数据是永远不会过时的
Cookie的大小是受限的,而且每次你请求一个新的页面的时候Cookie都会被发送过去,这样无形中浪费了带宽,另外cookie还须要指定做用域,不能够跨域调用 cookie须要前端开发者本身封装setCookie,getCookie
(1) link属于HTML标签,而@import是CSS提供的; (2) 页面被加载的时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载; (3) import只在IE5以上才能识别,而link是HTML标签,无兼容问题; (4) link方式的样式的权重 高于@import的权重.
box-sizing属性主要用来控制元素的盒模型的解析模式。默认值是content-boxchrome
摘自连接描述编程
级格式化上下文,是CSS中的一个渲染机制,BFC就至关于一个盒子,内部的元素与外界的元素互不干扰。它不会影响外部的布局,外部的布局也不会影响到它.
- 内部的BOX会在垂直方向上一个接一个的放置 - 于同一个BFC的俩个相邻的BOX的margin会发生重叠,与方向无关。 - 每一个元素的左外边距与包含块的左边界相接触(从左到右),即便浮动元素也是如此 - BFC的区域不会与float的元素区域重叠 - 计算BFC的高度时,浮动子元素也参与计算 - BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然
要阻止margin重叠,只要将俩个元素别放在一个BFC中便可
使得父元素包含子元素,常见的方式是为父元素设置overflow:hidden或者浮动父元素。根本缘由在于建立BFC的元素,子浮动元素也会参与其高度计算,即不会产生高度塌陷问题
与浮动元素相邻的已生成BFC的元素不能与浮动元素互相覆盖。利用该特性能够做为多栏布局的一种实现方式. 特色在于左右俩栏的宽度固定,中间栏能够根据浏览器宽度自适应
undefined是一个表示"无"的原始值,转为数值时为NaN跨域
null是一个表示"无"的对象,转为数值时为0浏览器
document.write只能重绘整个页面 innerHTML能够重绘页面的一部分
原理缓存
HTML5的离线存储是基于一个新建的.appcache文件的缓存机制(不是存储技术),经过这个文件上的解析清单离线存储资源,这些资源就会像cookie同样被存储了下来。以后当网络在处于离线状态下时,浏览器会经过被离线存储的数据进行页面展现
使用安全
.parent{ text-align: center; } .child{ display: inline-block; }
.child{ display:table; margin: 0 auto; }
.parent{ position:relative; } .child{ position:absolute; left:50%; transform: translateX(-50%); }
.parent{ display: table-cell; vertical-align:middle; }
absolute配合tranform
.parent{ position:relative; } .child{ position:absolute; top: 50%; transform: translateY(-50%); }
.parent{ display: table-cell; vertical-align:middle; text-align:center; } .child{ display: inline-block; }
.parent{ position: relative; } .child{ position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); }
.parent{ display: flex; justify-content: center; }
.parent{ display: flex; align-items: center; }
.parent{ display: flex; justify-content: center; align-items: center; }