美文网首页
BOM与window

BOM与window

作者: YYanm | 来源:发表于2018-10-30 17:04 被阅读0次
BOM
  • BOM是browser object model的缩写,简称浏览器对象模型。
  • 浏览器对象模型提供了独立于内容的、可以与浏览器窗口进行互动的对象结构。
  • Window是BOM中的核心对象。
1. window.onload 和 document.onDOMContentLoaded 有什么区别?
  • 当使用window.onload时,页面上所有的DOM、样式表、脚本、图片、flash都已经加载完成。
  • 当使用document.onDOMContentLoaded时,仅当DOM加载完成不包括样式表、图片、flash。
2. 如何获取图片真实的宽高?
document.querySelector("img").onload = dunction() {
    console.log(this.width);
    console.log(this.height);
3. 如何获取元素的真实宽高?
//假如我要获取名为body元素的宽高
console.log(body.offsetHeight)
console.log(body.offsetWidth)
4. URL 如何编码解码?
JavaScript中提供了四个URL编码方法:
  • encodeURI()
    用于转码整个 URL。它的参数是一个字符串,代表整个 URL。它会将元字符和语义字符之外的字符,都进行转义。不会对ASCII字母、数字、~!@#$&*()=:/,;?+'
    字符编码 。
encodeURI('http://www.example.com/q=春节')
// "http://www.example.com/q=%E6%98%A5%E8%8A%82"
  • encodeURIComponent()
    用于转码 URL 的组成部分,会转码除了语义字符之外的所有字符,即元字符也会被转码。所以,它不能用于转码整个 URL。它接受一个参数,就是 URL 的片段。不会对ASCII字母、数字、~!*()' 字符编码。
注意:encodeURIComponent()会连 URL 元字符一起转义,所以如果转码整个 URL 就会出错。
encodeURIComponent('春节')
// "%E6%98%A5%E8%8A%82"
encodeURIComponent('http://www.example.com/q=春节')
//"http%3A%2F%2Fwww.example.com%2Fq%3D%E6%98%A5%E8%8A%82"
  • decodeURI()
    用于整个 URL 的解码。它是encodeURI()方法的逆运算。它接受一个参数,就是转码后的 URL。
decodeURI('http://www.example.com/q=%E6%98%A5%E8%8A%82')
// "http://www.example.com/q=春节"
  • decodeURIComponent()
    用于URL 片段的解码。它是encodeURIComponent()方法的逆运算。它接受一个参数,就是转码后的 URL 片段。
decodeURIComponent('%E6%98%A5%E8%8A%82')
// "春节"
5.为什么要编码?
  • URL就是网址,只要上网,就一定会用到。
  • 只有字母和数字[0-9a-zA-Z]、一些特殊符号“$-_.+!*'(),”[不包括双引号]、以及某些保留字,才可以不经过编码直接用于URL。
  • 如果URL中有汉字,就会导致乱码。
  • URL参数字符串中如果包含”&”或者”%”势必会造成服务器解析错误。
  • 不同情况浏览器,网页,编码的处理方式不同。也会导致编码混乱不堪。
怎么解决上述问题?

使用Javascript先对URL编码,然后再向服务器提交,不要给浏览器插手的机会。因为Javascript的输出总是一致的,所以就保证了服务器得到的数据是格式统一的。

6. cookie & session &localStorage 分别是什么?
cookie
  • 会跟随请求被发送到服务器上
  • 是存储在浏览器上的一小段数据,用来记录某些当页面关闭或者刷新后仍然需要记录的信息
  • 一般浏览器存储cookie 最大容量为4k,所以大量数据不要存到cookie。
  • 有个数限制,不同浏览器下,一个域名下cookie的个数有限,并且限制数量可能不一样
session
  • 当一个用户打开一个页面登录后,刷新浏览器仍然展示登录状态。服务器如何分辨这次发起请求的用户是刚才登录过的用户呢 这里就使用了session保存状态。用户在输入用户名密码提交给服务端,服务端验证通过后会创建一个session用于记录用户的相关信息,这个 session 可保存在服务器内存中,也可保存在数据库中。
  • 创建session后,会把关联的session_id 通过setCookie 添加到http响应头部中。
  • 浏览器在加载页面时发现响应头部有 set-cookie字段,就把这个cookie 种到浏览器指定域名下。
  • 当下次刷新页面时,发送的请求会带上这条cookie, 服务端在接收到后根据这个session_id来识别用户。
  • cookie 是存储在浏览器里的一小段「数据」,而session是一种让服务器能识别某个用户的「机制」,session 在实现的过程中需要使用cookie。 二者不是同一维度的东西。
localStorage
  • localStorage HTML5本地存储web storage特性的API之一,用于将大量数据(最大5M)保存在浏览器中,保存后数据永远存在不会失效过期,除非用 js手动清除。
  • 不参与网络传输。
  • 一般用于性能优化,可以保存图片、js、css、html 模板、大量数据。
  • 总体数量无限制

相关文章

  • BOM与window

    BOM BOM是browser object model的缩写,简称浏览器对象模型。 浏览器对象模型提供了独立于内...

  • 第二周总结

    window对象 BOM BOM:window对象下面包含5个属性,navigator、location、docu...

  • BOM和DOM的区别

    BOM中的对象 window对像 是整个BOM的核心,所有对象和集合都以某种方式回到window对象,window...

  • BOM简介

    BOM概述 1.什么是BOM 2.BOM的构成 window对象的常见事件 1.窗口加载时间 window.onl...

  • JavaScript BOM

    一、Window对象 浏览器对象模型 (BOM) 使 JavaScript 有能力与浏览器“对话”。 Window...

  • 2019-01-27

    js中的BOM BOM的核心:window对象 bom:浏览器对象模型 window:是浏览器的一个实例,在浏览器...

  • JavaScript基础知识点--BOM基础及window对象

    什么是 BOM BOM(browser object model)浏览器对象模型 BOM 对象 window na...

  • 19-第十九章 BOM

    19-第十九章 BOM浏览器对象模型 (BOM) 使 JavaScript 有能力与浏览器“对话”。 Window...

  • JS高程:读书摘要(五)BOM属性

    BOM window 全局作用域 BOM的核心对象是window,它表示浏览器的一个实例。在浏览器中,window...

  • BOM与DOM的区别

    BOM中的对象 Window对象: 是整个BOM的核心,所有对象和集合都以某种方式回接到window对象。...

网友评论

      本文标题:BOM与window

      本文链接:https://www.haomeiwen.com/subject/pvmgtqtx.html