网站首页 > 技术文章 正文
闭包的理解
使用闭包主要是为了设计私有的方法和变量。 优点是可以避免全局变量的污染, 缺点是闭包会常驻内存,会增大内存使用量,使用不当很容易造成内存泄露
Cookie
第一:每个特定的域名下最多生成20个cookie
- IE6或更低版本最多20个cookie
- IE7和之后的版本最后可以有50个cookie。
- Firefox最多50个cookie
- chrome和Safari没有做硬性限制
第二:cookie的最大大约为4096字节,为了兼容性,一般不能超过4095字节
优点:极高的扩展性和可用性
- 通过良好的编程,控制保存在cookie中的session对象的大小。
- 通过加密和安全传输技术(SSL),减少cookie被破解的可能性。
- 只在cookie中存放不敏感数据,即使被盗也不会有重大损失。
- 控制cookie的生命期,使之不会永远有效。偷盗者很可能拿到一个过期的cookie。
缺点:
- Cookie数量和长度的限制。每个domain最多只能有20条cookie,每个cookie长度不能超过4KB,否则会被截掉。
- 安全性问题。如果cookie被人拦截了,那人就可以取得所有的session信息。即使加密也与事无补,因为拦截者并不需要知道cookie的意义,他只要原样转发cookie就可以达到目的了。
- 有些状态不可能保存在客户端。例如,为了防止重复提交表单,我们需要在服务器端保存一个计数器。如果我们把这个计数器保存在客户端,那么它起不到任何作用。
浏览器本地存储
sessionStorage
本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。 因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储
localStorage
用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的
web storage和cookie的区别
Cookie的大小是受限的,并且每次你请求一个新的页面的时候Cookie都会被发送过去,这样无形中浪费了带宽,另外cookie还需要指定作用域,不可以跨域调用 cookie需要前端开发者自己封装setCookie,getCookie
link 和@import 的区别是
- link属于HTML标签,而@import是CSS提供的;
- 页面被加载的时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载;
- import只在IE5以上才能识别,而link是HTML标签,无兼容问题;
- link方式的样式的权重 高于@import的权重.
box-sizing属性
box-sizing属性主要用来控制元素的盒模型的解析模式。默认值是content-box
- content-box:让元素维持W3C的标准盒模型。元素的宽度/高度由border + padding + content的宽度/高度决定,设置width/height属性指的是content部分的宽/高
- border-box:让元素维持IE传统盒模型(IE6以下版本和IE6~7的怪异模式)。设置width/height属性指的是border + padding + content
BFC规范的理解
级格式化上下文,是CSS中的一个渲染机制,BFC就相当于一个盒子,内部的元素与外界的元素互不干扰。它不会影响外部的布局,外部的布局也不会影响到它.
创建BFC
- float的值不是none
- position 的值不是static或者relative
- display的值是inline-block,table-cell,flex,table-caption或者inline-flex
- overflow的值不是visible
BFC的特性
- 内部的BOX会在垂直方向上一个接一个的放置
- 于同一个BFC的俩个相邻的BOX的margin会发生重叠,与方向无关。
- 每个元素的左外边距与包含块的左边界相接触(从左到右),即使浮动元素也是如此
- BFC的区域不会与float的元素区域重叠
- 计算BFC的高度时,浮动子元素也参与计算
- BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然
BFC在布局中的应用
要阻止margin重叠,只要将俩个元素别放在一个BFC中即可
使得父元素包含子元素,常见的方式是为父元素设置overflow:hidden或者浮动父元素。根本原因在于创建BFC的元素,子浮动元素也会参与其高度计算,即不会产生高度塌陷问题
与浮动元素相邻的已生成BFC的元素不能与浮动元素互相覆盖。利用该特性可以作为多栏布局的一种实现方式. 特点在于左右俩栏的宽度固定,中间栏可以根据浏览器宽度自适应
null和undefined的区别
undefined
undefined是一个表示"无"的原始值,转为数值时为NaN
- 变量被声明了,但没有赋值时,就等于undefined
- 调用函数时,应该提供的参数没有提供,该参数等于undefined
- 对象没有赋值的属性,该属性的值为undefined
- 函数没有返回值时,默认返回undefined
null
null是一个表示"无"的对象,转为数值时为0
- 作为函数的参数,表示该函数的参数不是对象
- 作为对象原型链的终点
documen.write和 innerHTML的区别
document.write只能重绘整个页面 innerHTML可以重绘页面的一部分
HTML5的离线存储
原理
HTML5的离线存储是基于一个新建的.appcache文件的缓存机制(不是存储技术),通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来。之后当网络在处于离线状态下时,浏览器会通过被离线存储的数据进行页面展示
使用
- 在文档的 html 标签设置 manifest 属性,如 manifest="/offline.appcache"
- 在项目中新建 manifest 文件,manifest 文件的命名建议:xxx.appcache
- 在 web 服务器配置正确的 MIME-type,即 text/cache-manifest
css各种居中
水平居中
.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%); }
垂直居中
- table-cell配合vertical-align
.parent{ display: table-cell; vertical-align:middle; }
absolute配合tranform
.parent{ position:relative; } .child{ position:absolute; top: 50%; transform: translateY(-50%); }
水平+垂直居中
- inline-block配合text-align加上table-cell配合vertical-align
.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%); }
全能的flex
.parent{ display: flex; justify-content: center; } .parent{ display: flex; align-items: center; } .parent{ display: flex; justify-content: center; align-items: center; }
猜你喜欢
- 2024-09-29 前端知识-概念篇 “前端”
- 2024-09-29 前端开发应当掌握的10大板块内容,每一个知识点应当相当熟悉
- 2024-09-29 web开发之-前端知识介绍 web前端基本知识
- 2024-09-29 web前端基础知识 web前端基础知识 相关课程
- 2024-09-29 前端小知识点汇总,常忘记的知识点汇总(面试,笔试)学习笔记
- 2024-09-29 高级前端开发应该掌握的知识图谱 高级前端开发应该掌握的知识图谱是什么
- 2024-09-29 14个前端小知识,我猜你每天都会遇到
- 2024-09-29 初学者学习web前端要掌握的知识点!(附前端开发自学教程)
- 2024-09-29 一个合格的Web前端工程师要掌握的哪些知识点?
- 2024-09-29 前端必会网络知识 前端必学知识点
你 发表评论:
欢迎- 05-11FANUC修改前端目录教程
- 05-11前端分享-Set你不知道的事
- 05-11jq+ajax+bootstrap改了一个动态分页的表格
- 05-11千万级大表分页查询效率剧降,你会怎么办?
- 05-11Elasticsearch深度分页
- 05-11如何写一个简单的分页
- 05-11手速太快引发分页翻车?前端竞态陷阱揭秘
- 05-11「linux」Socket缓存是如何影响TCP性能的?
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)