课外学习(一)

课外学习 郑士旭
文章标签: 拓展

1.缓存


基本概念:

  • Cookie:指某些网站为了辨别用户身份而存储在用户本地终端上的数据。
    • 分类
      • 内存 Cookie

由浏览器维护,保存在内存中,浏览器关闭就小时,存在时间短暂。

  • 硬盘 Cookie

保存在硬盘中,除非用户手工清理或到了过期时间,一般不会删除。

  • 用途
    • 服务器可以设置或读取 Cookies 中包含的信息,借此维护用户跟服务器会话中的状态

因为 HTTP 协议是无状态的,就是说服务器不知道用户上一次做了什么,为实现交互,就用 Cookie 来记录。

比如,网上购物,用户选购了一个商品,服务器在向用户发送网页时还发送一段记录商品信息的 Cookie,当用户访问另一个页面,浏览器会把 Cookie 发送给服务器端,于是服务器就知道用户选购了什么。

  • 登录网站勾选“下次自动登录”,那么下次访问就不用再输入密码等信息。

这是因为在第一次登录时,如果勾选了自动登录,那么服务器发送包含登录凭据(用户加密码的某种加密形式)的 Cookie 到用户的硬盘上,第二次登录的时候,浏览器就会发送该 Cookie,服务器验证凭据,就不用再次输入密码等。

  • 缺陷
    • Cookie 会被附加到每个 HTTP 请求中,无形增加了流量
    • HTTP请求中的 Cookie 是明文传递,安全性成问题。(HTTPS 不会)
    • Cookie 大小限制在 4KB,对于复杂的存储需求是不够用的
  • LocalStorage
    • Web Storage 有两种机制
      • sessionStorage 为每一个给定的源维持一个独立的存储区域,该存储区域在页面会话期间可用(浏览器是打开状态,包括页面重载和恢复)
      • localStorage 同上,但浏览器关闭之后,重新打开数据还是存在。

 

区别

特性CookieLocalStorage sessionStorage
数据的声明周期一般由服务器生成,可设置失效时间。如果在浏览器生成,默认是关闭浏览器之后失效除非被清楚,否则永久保存仅在当前会话有效,关闭页面或浏览器后被清除
存放数据大小4KB一般 5MB一般 5MB
与服务端通信每次都会携带在HTTP头中,如果使用 cookie 保存过多数据会带来性能问题仅在客户端中保存,不参与和服务器的通信。也可有脚本选择性提交到服务器端?同 LocalStorage
用途一般由服务器端生成,用于标识用户身份用于浏览器端缓存数据同 LocalStorage
共享   

 

相同点:

三者都可以被用来在浏览器端存储数据,而且都是字符串类型的键值对。

2.for in  和for  of的区别

  1. 推荐在循环对象属性的时候,使用for...in,在遍历数组的时候的时候使用for...of

  2. for...in循环出的是key,for...of循环出的是value

  3. 注意,for...of是ES6新引入的特性。修复了ES5引入的for...in的不足

  4. for...of不能循环普通的对象,需要通过和Object.keys()搭配使用

假设我们要遍历一个数组的valuelet aArray = ['a',123,{a:'1',b:'2'}]

使用for...in循环:

for(let index in aArray){
    console.log(`${aArray[index]}`);
}

使用for...of循环:

for(var value of aArray){
    console.log(value);
}

咋一看好像好像只是写法不一样而已,那为什么说for...of修复了for...in的缺陷和不足。
假设我们往数组添加一个属性name:
aArray.name = 'demo',再分别查看上面写的两个循环:

for(let index in aArray){
    console.log(`${aArray[index]}`); //Notice!!aArray.name也被循环出来了
}
for(var value of aArray){
    console.log(value);
}

所以说,作用于数组的for-in循环除了遍历数组元素以外,还会遍历自定义属性。

for...of循环不会循环对象的key,只会循环出数组的value,因此for...of不能循环遍历普通对象,对普通对象的属性遍历推荐使用for...in

如果实在想用for...of来遍历普通对象的属性的话,可以通过和Object.keys()搭配使用,先获取对象的所有key的数组
然后遍历:

var student={
    name:'wujunchuan',
    age:22,
    locate:{
    country:'china',
    city:'xiamen',
    school:'XMUT'
    }
}
for(var key of Object.keys(student)){
    //使用Object.keys()方法获取对象key的数组
    console.log(key+": "+student[key]);
}


还能输出{{restrictNumber}}个字符  
  • {{reply.author}}

    {{CommonUtil.formateDate(reply.ac_CommentDate).shortTime}}
  • 回复了{{Comments.author}} :