前端开发面试题:cookies, sessionStorage与localStorage解析及src与href的区别

需积分: 23 2 下载量 151 浏览量 更新于2024-08-05 收藏 25KB DOCX 举报
"前端开发基础题目及答案,涵盖了cookies,sessionStorage,localStorage的对比,以及src与href的区别" 在前端开发中,理解如何在浏览器端存储数据以及引用外部资源是至关重要的。首先,我们来看一下cookies,sessionStorage和localStorage的区别。 1. **cookies**:作为最早的客户端存储方式之一,cookies最初设计是为了保持HTTP会话状态,通过在浏览器每次请求时发送到服务器,以识别用户。它们有大小限制(通常4KB),并且会被发送到每个请求的服务器,这可能导致性能问题。此外,cookies可以通过JavaScript进行读写,但默认情况下具有安全性限制,可以跨域访问。 2. **sessionStorage**:这是HTML5引入的一种新的存储方式,其数据仅在当前浏览器窗口或标签页中有效。当窗口或标签页关闭时,数据会被清除。它适用于临时存储用户在单个会话中的信息,如表单输入数据或导航历史。 3. **localStorage**:同样是HTML5提供的功能,它允许长期存储数据,即使浏览器关闭再打开,数据仍然存在。这对于存储用户设置、游戏进度等持久化数据非常有用。但同样需要注意的是,所有数据都以字符串形式存储,且存在一定的存储空间限制(通常5MB左右)。 接下来,我们讨论src和href的区别: 2. **src** 和 **href** 都是用来链接外部资源的属性,比如图像、CSS文件、JavaScript脚本或网页。但它们的作用方式有所不同。`src` 是 "source" 的缩写,它会替换当前元素,并将所链接的资源内容嵌入到文档中。例如,当你使用 `<img src="image.jpg">`,浏览器会下载图像并显示在页面上。同样,对于 `<script src="script.js">`,浏览器会暂停页面渲染,等待脚本加载和执行后再继续。 相比之下,`href` 是 "Hypertext Reference" 的缩写,它主要用于链接到其他资源,如链接到其他网页。例如,`<a href="http://example.com">链接</a>` 创建了一个指向外部页面的超链接。而对于 `<link href="styles.css">`,它只是建立一个链接,告诉浏览器加载CSS文件,但不会替换当前元素。 理解这些基本概念对于前端开发者来说至关重要,无论是编写交互式的Web应用还是优化性能,都需要根据需求正确选择数据存储方式和外部资源引用方式。