BOM的基本介绍

 

8-1浏览器引入JavaScript

要想利用J avaScript和网页实现互动,那么首先第一步就是应该了解如何向网页中引入 JavaScript代码。实际上,向网页引入JavaScript代码的方式也是多种多样,下面我们一起来看 —下。

8-1-1直接在HTML文件中引入

首先第1种方式就是直接在HTML文档里面引入JavaScript代码。在维护一些老项目的时候,经常 可以看到J avaScript代码是写在<title>标签下面的,并且通过一对<sc ript>标签来引入代 码。示例如下:

<head>

<meta charset="UTF-8">

<title>Document</title>

<script>

//JS代码

</script>

</head>

但是,如果是直接在HTML文件中引入JavaScript代码,我们一般不写在vtitle>标签下面,更 加优化的一种方式是将<sc ript>标签写在<body>标签的最小面,这样可以更快的加载出页面 效果。如下:

<body>

<! — HTML —>

<script>

//JS代码

</script>

</body>

8-1-2调用外部JS文件

第2种方式是使用外部链接的方式来调用外部的JS文件。这种方式适用于当我们的JavaScript代 码是单独的一个js文件时,就可以采用这种方式来引入JavaScript代码。示例如下:

<body>

<! — HTML —>

<sc ript sr c="外部 JS 文件"</sc ript>

</body>

8-1-3使用a标记的href属性

我们还可以在<a>标签的href属性里面书写JavaScript代码,这样会改变<a>标签默认的超链 接特性,而变为执行这段JavaScript代码,示例如下:

<body>

<! — HTML —>

<a hr ef="javasc ri pt:ale rt('Hello Worl d')"> 点击 </a> </body>

8-1-4事件里面直接书写JS代码

在后面学习的事件中,我们也可以直接将JavaScript代码写在事件里面,例如我们书写一个点击 事件,当点击button按钮时,会执行相应的J avaScript代码,示例如下:

<body>

<! — HTML —>

<button onclick="javasc ri pt:ale rt('Hello Worl d!')"> 点击 </button〉 </body>

8-2 BOM基本介绍

8-2-1什么是BOM

所谓BOM,英语全称为Browser Object Model,翻译成中文为浏览器对象模型。我们的浏览 器,可以被看做是由各种各样的对象所组成的,就像我们这个可爱的世界一样。

—般来讲,在BOM中大致存在如下几个对象:

  • window:表示窗口对象
  • navigator:包含浏览器相关信息
  • location:包含当前页面的位置信息
  • history :包含用户访问页面的历史信息
  • screen:包含客户端显示能力信息
  • document:表示整个页面

整个BOM的核心对象就是是window对象,它代表的是浏览器的一个实例。window对象同时也是 最顶层的对象。

8-2-2 BOM与DOM的关系

在下一章,我们还会介绍一个东西,被称之为DOM。很多初学者刚开始都搞不清楚BOM和DOM 之间的关系,事实上很简单,DOM可以算是BOM的一个分支。因为BOM里面存在一个叫做 Documen的对象,但是这个对象的属性和方法太多了,所以W3C将其单独取了出来,做成了一 套规范,这个就是DOM,英语全称document object model,翻译成中文就是文档对象模型。

需要说明一下的是BOM目前还没有相应的规范。浏览器提供商会按照各自的想法去随意扩展 它,于是浏览器之间共有的对象就成了事实上的标准。这些对象在浏览器中得以存在,很大程度 上是由于它们提供了与浏览器的互操作性。目前,W3C已经将BOM的主要方面纳入了HTML5的 规范中。

8-3 window 对象

8-3-1 window对象基本介绍

我们先来看一下window对象。浏览器每打开一个窗口,就包含了一个window对象。window对 象是整个BOM的核心对象,它代表着一个浏览器窗口的实例。

window对象扮演着在ES中的globa I对象的角色,因此所有在全局作用域中声明的变量以及函数 都会成为该对象的属性和方法。也就是说全局变量是window对象的属性,全局函数是window对 象的方法。我们来看下面的示例:

<body>

<script>

  var a = 1;

  function test(){ alert("this is a test");

  }

    alert(a);//1 alert(window.a);//1

    test();//this is a test

    window.test();//this is a test

</script>

</body>

可以看到,这里我们通过访问window.a和window.test()也可以打印出a变量的值和调

用test()函数。

全局属性和window属性的区别

var和window对象的属性真的就是一模一样么?

也不是,还是有稍微不同的地方,那就是不能使用delete操作符删除用var声明的变量,但是如 果是window的属性就可以使用delete操作符来进行删除。

<body>

<script>

var i = 10; window.j = 20;

console.log(window.i);//10

console.log(window.j);//20

delete window.i;//并没有被删除掉

delete window.j;//已经被删除掉了

console.log(window.i);//可以打印出来 console.log(window.j);//被删除了,所以是 undefined

</script>

</body>

let以及const所声明的变量

还需要注意的是,使用ES6新提供的let和const所声明的变量不会成为window对象的属性,证明 如下:

<body>

<script>

var i = 10;

let j = 20;

const k = 30;

alert(window.i);//10

alert(window.j);//undefined

alert(window.k);//undefined

</script>

</body>

8-3-2常见属性

既然是对象,那么肯定就有相应的属性和方法。这一小节,我们先来看一下window对象中常见 的属性有哪些。

  1. 窗口大小

关于窗口大小的属性有两组,inne rWidth , inne rHeight 以及 oute rWidth , oute rHeight 区别在于:inner那一组表示的是页面视图区的大小,而outer那一组表示的是浏览器窗口本身的 尺寸。

<body>

<script>

console.log(innerHeight);

console.log(innerWidth); console.log(outerHeight);

console.log(outerWidth);

</script>

</body>

效果:

726

368

800

1280

但是,不同的浏览器,所表示的值略微有差异。

我们除了通过inne rWidth , inne rHeight来获取页面视图区的大小以外,还可以通 过 document.documentElement.clientWidth 以

及document.documentElement.clientHeight来获取页面视图区的大小,示例如下:

<body>

<script> console.log('innerHeight:',innerHeight);

console.log('innerWidth',innerWidth);

console.log('outerHeight',outerHeight);

console.log('outerWidth',outerWidth);

console.log('document.documentElement.clientWidth:',document.documen tElement.clientWidth);

console.log('document.documentElement.clientHeight:',document.docume ntElement.clientHeight);

</script>

</body>

效果:

innerHeight: 635

innerWidth 1280

outerHeight 709

outerWidth 1280

document ・ documentElement ・ clientwidth: 1280 document・ documentElement・ clientHeight: 635

那这两个属性有什么区别呢?具体如下表:

属性

innerWidth

innerHeight

document.documentElement.clientWidth

document.documentElement.clientHeight

  1. 窗口位置
    窗口位置的属性也是有两组,分别是scr eenLeft和scr eenTop,还有scr eenX和scr eenY

这两组属性都是表示窗口相对于屏幕左边和上边的位置,如下:

<body>

<script> console.log(window.screenLeft); console.log(window.screenTop);

console.log("------------- ");

console.log(window.screenX); console.log(window.screenY);

</script>

</body>

效果:

22

45

22

45

区别在于screenX和screen Y属性最早是火狐浏览器里面特有的属性。但是上面的代码是在谷歌浏 览器里面运行的,可以看到,现在这两组属性在很多浏览器里面都是通用的了。接下来我将上面 两组属性的区别总结成下面的表格,如下:

属性                                     描述

screenX        返回浏览器相对于屏幕窗口的x坐标(IE不支持)

screenY        返回浏览器相对于屏幕窗口的y坐标,即距离浏览器最顶端(IE不支持)

screenL

sceeeft        返回浏览器相对于屏幕窗口的x坐标

 

screenTop       返回浏览器相对于屏幕窗口的y坐标(在IE中这个坐标包括了工具栏+菜单栏+地址栏的高度)

  1. 元素位置

既然讲到了位置,那么这里我们提前来看一下如何获取一个元素在页面中的位置。我们可以通 过offsetLeft以及offsetTop来得到一个元素在页面中的位置,位置的信息是不带单位的, 示例如下:

<head>

<meta charset="UTF-8">

<title>Document</title>

<style>

div{

width: 100px;

height: 150px;

background-color: pink;

position: absolute;

top: 300px;

left: 200px;

}

</style>

</head>

<body>

<div id="div"></div>

<script>

console.log(div.offsetLeft); // 200 console.log(div.offsetTop); // 300 </script>

</body>

  1. 元素大小

除了获取到一^元素在页面中的位置,我们还可以通过offsetwidth和offsetHeight来得到

—个元素的宽高,示例如下:

<head>

<meta charset="UTF-8"> <title>Document</title>

<style>

div{

width: 100px; height: 150px;

background-color: pink;

position: absolute;

top: 300px;

left: 200px;

}

</style>

</head>

<body>

<div id="div"></div>

<script>

console.log(div.offsetwidth); // 100 console.log(div.offsetHeight); // 150

</script>

</body>

  1. 滚动位置

通过pageXOffset和pageYOffset属性我们可以获取文档在窗口左上角水平和垂直方向滚动的 像素。

<head>

<meta charset="UTF-8"> <title>Document</title>

<style> body { height: 5000px;

}

</style>

</head>

<body>

<script> window.onscroll = function () { console.log(window.pageYOffset);

}

</script>

</body>

需要注意的是,pageXOffset和pageYOffset属性相等于scr ollX和scr ollY属性。这些属 性都是只读属性。

注:关于各浏览器

对 document.body.onscroll , window.onscroll , document.documentElement.onscr oil的兼容性,可以参见下面这篇文档 https://blog.csdn.net/qq_26445509/article/details/51153153

8-3-3常用方法

接下来我们来一起看一下window对象中常见的方法有哪些。

  1. 系统提示框

ale rt():用于显示带有一条指定消息和一个确定按钮的警告框。

注意:alert会终止JavaScript代码的执行 例如:

<body>

<script> window.alert("Hello");

</script>

</body>


此网页显示:运行结果:

Hello

确定

<body>

<script>

let i = window.confirm("Are you sure?"); console.log(i,typeof i);//true "boolean" </script>

</body>

<body>

<script>

let i = window.prompt("Please input something");

console.log(i,typeof i);//用户输入内容 string </script>

</body>

  1. 2.     窗口大小调整(有问题)

关于窗口大小,也有一组方法,resizeTo()和resizeBy() r esizeTo():将浏览器窗口调整到指定的值

r esizeBy():相对于原来的浏览器窗口来进行调节

<body>

<script>

window. resizeTo(100,100);//调整到 100x100

window. resizeBy(100,50);//在原来的基础上增加 100和50 变为200x150 </script>

</body>

  1. 3.     窗口位置移动

关于窗口位置,我们如何来移动呢,在window对象里面提供了 moveTo()和moveBy()

<body>

<script>

window.moveTo(100,100);//移动到 100x100 的位置 window.moveBy(100,50);//在原来的基础上向右移动100,向下移动50

</script>

</body>

但是需要注意:这两组方法在浏览器里面基本上都是被禁用的,所以基本效果出不来。

  1. 4.     打开和关闭窗口

open()方法:使用window.open()方法,该方法有4个参数,如下:

<body> <script>

//参数1:要加载的URL

//参数2:指定tar get属性或窗口的名称

//参数3:-个特性字符串,新窗口的大小

//参数4:新窗口是否取代历史记录中的当前页面 window.open("2.html","123","height=400,width=400,top=10,resizable=ye s");

</script> </body>

效果:重新加载页面以后弹出新的窗口 (2.html文件是提前准备好了的)

 

 

需要注意现在的浏览器一般都是会阻止弹窗的。一般需要我们点击允许弹出后,才弹出2.htm I页 面

在调用了 window对象的open()方法以后,他会返回一个对象,可以调用这些对象的方法,其 中就有一个close()方法,示例如下:

<body>

<button onclick="test()"> 关闭新窗口 </button>

<script>

//参数1:要加载的URL

//参数2:指定tar get属性或窗口的名称

//参数3:-个特性字符串,新窗口的大小

//参数4:新窗口是否取代历史记录中的当前页面

let i = window.open("2.html","123","height=400,width=400,resizable=y es");

let test = function(){

i.close();

}

</script>

</body>

还有一个opener属性,保存着打开它的原始窗口对象

<body>

<script>

//参数1:要加载的URL

//参数2:指定tar get属性或窗口的名称

//参数3:-个特性字符串,新窗口的大小

//参数4:新窗口是否取代历史记录中的当前页面

let i = window.open("2.html","123","height=400,width=400,resizable=y es");

console.log(i.opener === window);//true </script>

</body>

  1. 定时函数

间歇调用

setInterval()与clearInterval():这两个方法可以说是一组方法,前面是设定指定的时间 周期调用某个函数,而后面的方法则是清除前面的设定。

setInterval()语法如下:

setinterval(函数名,间隔时间)

其中间隔时间以毫秒来计算,1000毫秒为1秒。该方法会返回一个id值,这个id值可以用于停止 重复调用。

clea rInte rval()语法如下:

clearinterval(id)

作用是清除设置的间歇调用

示例:

<body>

<script>

  let i = 1;

  let test = function(){ console.log(i);

    i++;

  if(i == 10){ clearInterval(id);

    }

  }

  let id = setInterval("test()",1000);

</script>

</body>

运行结果:依次打印出1-10 练习1:

制作一个时钟

<body>

<span id="myTime"></span>

<script>

  let myTime = document.getElementById("myTime");

  let showTime = function(){ myTime.innerText = new Date().toLocaleString();

  }

  setInterval("showTime()",1000);

</script>

</body>

运行结果:

2017/11/28 上午 11:04:02

超时调用

setTimeout()和clea rTimeout():这两个也可以算是一组方法,前面是设定指定的时间周期 后调用某个函数,而后面的方法是清除前面的设定。

setTimeout()语法如下:

setinterval(函数名,间隔时间)

其中间隔时间也是指代的毫秒数,但是这个毫秒数的含义是执行代码前需要等待的毫秒数。该方

法也会返回一^ id,可用于clearTimeout

clearTimeout()语法如下:

clearinterval(id)

作用是清除设置的超时调用

示例:

<body>

<button id="btn">5 秒后显示 </button〉

<script>

  let btn = document.getElementById("btn");

  btn.onclick = function(){

  setTimeout("alert('已经过了5秒了 ')",5000);

}

</script>

</body>

效果:点击按钮后过5秒钟弹出提示框

 

下面的例子显示了 clearTimeout的用法,其实就是清除前面的设定

 

<body>

<button id="btn">5 秒后显示 </button〉

<script>

let btn = document.getElementById("btn");

btn.onclick = function(){

setTimeout("alert('已经过了5秒了 ')",5000); clearTimeout(i);

}

</script>

</body>

 

8-4 navigator 对象

8-4-1 navigator 对象介绍

navigator对象包含浏览器和运行浏览器的操作系统的大量信息。例如操作系统版本,浏览器类型 和版本等信息。很多时候我们需要在判断网页所处的浏览器和平台,navigator对象为我们提供了 便利。

8-4-2 navigator 对象属性

navigator对象所包含的属性大致如下表:

属性

描述

appCodeName

返回浏览器的代码名

appMinorVersion

返回浏览器的次级版本

appName

返回浏览器名称

appVersion

返回浏览器的平台和版本信息

browserLanguage

返回当前浏览器的语言

cookieEnabled

返回指明浏览器中是否启动cookie的布尔值

cpuClass

返回浏览器系统的CPU等级

onLine

返回指明系统是否处于脱机模式的布尔值

platform

返回运行浏览器的操作系统平台

systemLanguage

返回OS使用的默认的语言

userAgent

返回由客户机发送服务器的user-agent头部的值

userLanguage

返回OS的自然语言设置

 

示例:

<body>

<script>

console.log("浏览器名称:",navigato r.appName);
console.log("浏览器版本:",navigat or .appVe rsion); console.log("浏览器主语言:",navigato「.language); console.log("产品名称:",navigat or.pr oduct);

</script>

</body>

效果:

浏览器名称:Netscape

浏览器版本:5.0 (Macintosh; Intel Mac OS X 10_13_1) AppIeWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94

Safari/537.36

浏览器主语言:zh-CN

产品名称:Gecko

 

8-5 location 对象

locatio n对象提供了当前窗口中加载的文档的有关信息。这个对象有点特别,它既是window对象 的属性,也是document对象的属性,也就是说window.location和document.location调用 的是同一个对象,我们也可以通过下面的方式来进行证明,如下:

<body>

<script>

console.log(window.location === document.location);//true

</script>

</body>

8-5-1常见属性

常见的location对象的属性如下表:

属性

描述

hash

返回一个URL的锚部分

host

返回一个URL的主机名和端口

hostname

返回URL的主机名

href

返回完整的URL

pathname

返回的URL路径名

port

返回一个URL服务器使用的端口号

protocol

返回一个URL协议

search

返回一个URL的查询部分

 

这里主要介绍一下href属性,可以查看或者设置l ocatio n的href属性 查看当前页面的URL:

<body> <script>

console.log(location.href); //file:///Users/Jie/Desktop/1.html

</script>

</body>

设置当前页面的URL:

<body>

<button onclick="test()">点击我们跳转</button>

<script>

  let test = function(){

  location.href = "http://www.baidu.com";

}

</script>

</body>

效果:点击按钮后跳转到百度

接下来我们来看一下其他的属性:

・hash:如果URL中包含有“#”,该方法将返回该符号之后的内容例

如: http://www.sunchis.eom/index.html#welcome 的 hash 是 #welcome

  • host:服务器的名字,例如www.sunchis.com
  • hostname :通常等于host,有时会省略前面的www

・href:当前页面载入的完整URL。

• pathname: URL中主机名之后的部分。例

如:http://www.sunchis.com/html/js/jsbasic/2010/0319/88.html 的 pathname

是 /html/js/jsbasic/2010/0319/88.html 。

・port: URL中声明的请求端口。默认情况下,大多数URL没有端口信息(默认为80端口), 所以该属性通常是空白的。像http://www.sunchis.com:8080/index.html这样的URL的 port属性为8080

• protocol: URL中使用的协议,即双斜杠(//)之前的部分。例

如  http://www.sunchis.com 中的protocoI属性等于 http:, ftp://www.sunchis.com 的 protocol属性等于ftp:

・search:执行GET请求的URL中的问号(?)后的部分,又称查询字符串。例

http://www.sunchis.com/search.html?tern=sunchis 中search属性为

term=sunchis

8-5-2常见方法

location对象中常见的方法如下表:

方法

assign。   载入一个新的文档

reload。    重新载入当前文档

replace。   用新的文档替换当前文档

接下来我们一个一个来看。

reload():该方法用于重新加载当前文档。

示例:

<body>

<button onclick="test()"> 刷下< /button> <script>

let test = function(){ location.reload();

}

</script>

</body>

效果:点击按钮后会刷新一下页面

接下来的两个方法看上去是差不多的,分别是assign和replace方法。

assign():该方法加载新的文档。

示例:

<body>

<button onclick="test()"> 加载 </button> <script>

let test = function(){

location.assign("http://www.baidu.com");

}

</script>

</body>

replaced :该方法可用一个新文档取代当前文档。

示例:

<body>

<button onclick="test()"> 替换 </button> vscript>

let test = function(){

location.replace("http://www.baidu.com");

}

</script>

</body>

那么这两个方法的区别是什么呢?

assign()方法:加载URL指定的新的HTML文档。就相当于一个链接,跳转到指定的URL, 当前页面会转为新页面内容,可以点击后退返回上一个页面。

replaced方法:通过加载URL指定的文档来替换当前文档,这个方法是替换当前窗口页面, 前后两个页面共用一个窗口,所以是没有后退返回上一页的。

跳转的方式

最后我们来总结一下页面跳转的方式,抛开<a>标签,通过JavaScript代码来实现页面的跳转大 致有下面几种方式:

  • location.href
  • window」o cation
  • location
  • location.assign。
  • location.replace。

 

8-6 history 对象

history对象用来管理当前窗口最近访问过的URL记录,这些URL记录被保存在history列表中, history对象使得脚本程序可以模拟浏览器工具栏的前进和后退按钮。

8-6-1常见属性

history对象常见属性如下表:

属性                 描述

length      返回浏览器历史列表中URL的数量

示例:

<body>

<button onclick="test()"> 查看历史列表数量 </button>

<script>

let test = function(){

console.log("历史列表数:",histo ry.length);

}

</script>

</body>

8-6-2常见方法

history对象常见的方法如下表:

方法                  描述

back。     加载history列表中的前一个URL

forward。  加载history列表中的下一^ URL

go。       加载history列表中的某个具体页面

window.history.go。方法可以用来导航到指定的页面,0代表是当前页面

vscript>

window.histo ry.go(1);//向前一个页面

window.histo ry.go(0);//重新加载当

window.histo ry.go(-1);//回退一个页

</script>

还有window.histo ry.fo rwa rd()和window.histo ry.back()方法可以分别用来向前或者回退 —个页面,就像浏览器的前进和后退按钮一样。

8-7 screen 对象

有时脚本需要获取浏览器或者显示器的一些信息,例如分辨率,有效分辨率,DPI等。这个时候 我们就可以使用scree n对象。该对象提供了一组属性,供我们来获取到这些有用的信息。

|注意:目前没有应用于screen对象的公开标准,不过所有浏览器都支持该对象。

screen对象属性如下表:

属性                                     说明

height

屏幕的像素高度

width

屏幕的像素宽度

availHeight

屏幕的像素高度减去系统部件高度之后的值(只读)

availWidth

屏幕的像素宽度减去系统部件宽度之后的值(只读)

left

当前屏幕距左边的像素距离[firefox返回0, chrome和IE不支持]

top

当前屏幕距上方的像素距离[firefox返回0, chrome和IE不支持]

availLeft

未被系统部件占用的最左侧的像素值(只读)[chrome和firefox返回0, I E不支持]

availTop

未被系统部件占用的最上方的像素值(只读)[chrome和firefox返回0, I E不支持]

bufferDepth

读、写用于呈现屏外位图的位数[IE返回0, chrome和firefox不支持]

colorDepth

用于表现颜色的位数(只读)[IE8-返回32,其他浏览器返回24]

pixelDepth

屏幕的位深(只读)[IE8 -不支持,其他浏览器返回24]

deviceXDPI

屏幕实际的水平DPI(只读)[IE返回96, chrome和firefox不支持]

deviceYDPI

屏幕实际的垂直DPI(只读)[IE返回96, chrome和firefox不支持]

logicalXDPI

屏幕逻辑的水平DPI(只读)[IE返回96, chrome和firefox不支持]

logicalYDPI

屏幕逻辑的垂直DPI(只读)[IE返回96, chrome和firefox不支持]

updateInterval

读、写以毫秒表示的屏幕刷新时间间隔[IE返回0, chrome和firefox不 支持]


 

fontSmoothingEnab        是否启用了字体平滑(只读)[IE返回true, chrome和firefox不支持]

led

个别属性示例:

<body> <script>

console.log("屏幕高度:",sc reen.height); console.log("屏幕宽度:",sc reen.width); console.log("调色板比特深度:",sc reen.colo rDepth);

</script>

</body>

效果:

屏幕高度:800

屏幕宽度:1280

调色板比特深度:24

 

8-8 document 对象

在后面的DOM中,我们会专门介绍document相关的大量的方法。这里就先介绍一个即

可。write()方法,用于将一串文本写入页面。如果页面已经加载了,它将完全替换当前的文 档。

示例:

<body>

<p>Lorem ipsum dolor sit amet.</p>

vbutton onclick="test()"> 按钮 </button>

<script>

let test = function(){ document.write("this is a test"); document.write("this is a test,too");

}

</script>

</body>

效果:点击前

Lorem ipsum dolor sit amet.

按钮

点击后

this is a testthis is a test,too

可以看到,使用document.w rite()书写页面的时候,原来的东西会完全被替换掉。并且我们书 写了两行东西,这里两行东西是在一行里面显示的。与document.w ri te()对应的有一

个document.writeln(),这个方法就可以实现换行输出,但是这里的换行指的是代码里面会换 行,页面上仍然是显示成一行的。不过多了一个空格,因为html存在空白折叠现象。书写的新的 内容仍然会将之前的内容给替换掉。

<body>

<p>Lorem ipsum dolor sit amet.</p>

<button onclick="test()"> 按钮 </button>

<script>

let test = function(){

document.writeln("this is a test"); document.writeln("this is a test,too");


cookie (扩展)

cookie是保存在用户计算机上的小文件,是网景公司发明的。之所以当时发明cookie这个东西, 是因为HTTP协议是一种无状态的协议,这意味着从一个请求转到另一个请求后,浏览器不记得 前一个请求的任何东西。于是每次用户访问一个页面,都记不住任何以前的访问。

所以网景公司就发明了 cookie,用它来存储一些信息,从而避免了无状态这个问题。使用cookie 我们可以实现个性化用户的浏览体验,例如存储用户偏好,跟踪用户选择(购物车),身份验证和 跟踪用户等。

近年来,用于追踪目的的cookie已经被滥用,所以它们在被用作数据存储的情况下渐渐的被新的 HTML5 localStorage API所取代,因为它允许存储更多的数据。不过目前来讲,cookie对于保留 状态信息(例如用户登录)仍然有用,因为每次HTTP请求发生时,它们都会在客户端和服务器端之 间进行传递。

  1. 创建 cookie

要创建一个cookie,只需要将要保存的信息赋值给document.cookie属性即可,如下:

<body>

<button onclick="setCookie()"> 设置 cookiev/button> vbutton onclick="showCookie()"> 显示 cookiev/button> vscript>

let setCookie = function(){ document.cookie = "name = xiejie";

}

let showCookie = function(){ console.log(document.cookie);

}

</script>

</body>

效果:

设置cookie           显示cookie

首先点击设置cookie进行设置,然后点击显示cookie

name=xiej ie

需要注意谷歌浏览器下面需要搭建服务器环境才能看到效果(火狐浏览器不需要),这里涉及 至U了事件的相关知识,关于事件我们会在第9章做详细的介绍。

可以追加cookie内容,只需要添入新的键值对即可

<body>

<button onclick="setCookie()"> 设置 cookie</button>

<button onclick="showCookie()"> 显示 cookie</button>

<button onclick="addCookie()"> 追加 cookie</button>

<script>

let setCookie = function(){

document.cookie = "name = xiejie";

}

let showCookie = function(){ console.log(document.cookie);

}

let addCookie = function(){

document.cookie = "age = 18";

}

</script>

</body>

效果:先点击设置cookie,接下来显示cookie,然后点击追加cookie,然后再次显示

name=xiej ie

name=xiej ie; age=18

  1. 修改 cookie

如果要修改cookie的值也非常简单,只需要对已有的键重新赋值就可以了。示例如下:

<body>

<button onclick="setCookie()"> 设置 cookiev/button>

<button onclick="showCookie()"> 显示 cookiev/button>

<button onclick="changeCookie()"> 修改 cookiev/button> vscript>

let setCookie = function(){

document.cookie = "name = xiejie";

let showCookie = function(){ console.log(document.cookie);

}

let changeCookie = function(){ document.cookie = "name = yajing";

} </script> </body>

效果:先点击设置cookie,然后显示cookie,接下来点击修改cookie,再显示cookie

name=xiej ie

name=yajing

  1. 读取 cookie

读取cookie只需要键入document.cookie即可,这个前面已经用过了。我们可以使用split。方法将 cookie的字符串拆分成数组,然后使用for-of进行循环遍历

<body>

<button onclick="setCookie()"> 设置 cookie</button>

<button onclick="showCookie()"> 显示 cookie</button>

<button onclick="changeCookie()"> 遍历 cookie</button> vscript> let setCookie = function(){

//注意设置多个cookie的时候,只能这么多次赋值才进行设置 document.cookie = "name = xiejie"; document.cookie = "age = 18"; document.cookie = "gender = male";

}

let showCookie = function(){ console.log(document.cookie);

}

let changeCookie = function(){ let cookies = document.cookie.split("; ");//分隔符为;加上一个空格 for(let i of cookies)

{

let [key,value] = i.split("=");//解构 console.log("cookie 的键为:",key,"值为:",value);

} } v/script>

</body>

效果:

 

name=xiej ie; age=18; gender二male

cookie的键为:name 值为:xiejie

cookie的键为:age值为:18

cookie的键为:gender 值为:male

如果要随意查看cookie的示例,可以访问任意网站,打开浏览器控制台,键入document.cookie 即可。

4. cookie失效时间

cookie默认是会话的cookie,也就是说,一旦浏览器会话完成(也就是用户关闭浏览器标签页或者 窗口时),cookie就会被删除。

不过,cookie可以变成持久的,只需在设置cookie的时候,在cookie末尾添加';expires=日期 值'来设置失效日期即可,示例如下:

<body>

<button onclick="setCookie()"> 设置 cookie</button>

<button onclick="showCookie()"> 显示 cookie</button> <script>

let setCookie = function(){

//获取当前的日期时间

let expiryDate = new Date();

//在当前的日期时间上添加上1天

let tomorrow = expiryDate.getTime() + 86400;

//重新设置日期时间 expiryDate.setTime(tomorrow);

//设置该cookie的失效时间

document.cookie = 、name=xiejie;expires=${expiryDate.toUTCString(

)}';

document.cookie = "age = 18";

}

let showCookie = function(){ console.log(document.cookie);

}

</script>

</body>

另一种方案是设置max-age值。这个值的单位为秒,不过IE10之前的版本不支持

document.cookie = "name = xiejie; max-age = 86400";//86400=

5. cookie的路径和域
默认情况下,cookie只能通过与设置它的文件在相同的目录和域中的页面来读取。这是出于安全 的原因,所以访问cookie是有限制的。

路径可以进行修改。例如我们要让根目录中的任何页面都可以读取cookie。可以通过在设置 cookie时,在cookie的末尾添加;path=/来实现,如下:

document.cookie = "name = xiejie; path = /";

除此之外,我们还可以在cookie的末尾添加;domain = domainName来设置域:

document.cookie = "name = xiejie; domain = syaketu.com";

原来的cookie,只能被创建它的域所读取,不过像上面这样我们手动设置了域之后,就可以让一 个域下面的所有子域(例如:html.syaketu.com, ruby.syaketu.com)都可以读取这个cookie。

  1. 保护cookie安全

这个也非常简单,在一个cookie的末尾添加上字符串';secure '即可,这样可以确保它只能通过安 全的H TTPS网络来进行传输

<body>

<button onclick="setCookie()"> 设置 cookie</button>

<button onclick="showCookie()"> 显示 cookie</button> <script>

let setCookie = function(){

//注意设置多个cookie的时候,只能这么多次赋值才进行设置

document.cookie = "name = xiejie"; document.cookie = "age = 18"; document.cookie = "gende r = male;secu re";//只通过 HTTPS 网络传输

}

let showCookie = function(){ console.log(document.cookie);

}

</script>

</body>

效果:由于gender=male添加了secure,所以只能通过HTTPS网络来传输

name=xiej ie; age=18

  1. 删除 cookie

要删除一个cookie的方法非常简单,只需要将cookie的失效时间设置在过去的某个时间过期即

可。如下:

<body>

<button onclick="setCookie()"> 设置 cookie</button>

<button onclick="showCookie()"> 显示 cookie</button>

<button onclick="deleCookie()"> 删除 cookie</button> <script>

let setCookie = function(){

//注意设置多个cookie的时候,只能这么多次赋值才进行设置

document.cookie = "name = xiejie";

document.cookie = "age = 18"; document.cookie = "gender = male";

}

let showCookie = function(){ console.log(document.cookie);

}

let deleCookie = function(){

document.cookie = "age = 18;expires = Thu,01 Jan 1990 00:00:01 G MT";

}

</script>

</body>

效果:先点击设置,然后显示,接下来删除,再显示,可以看到键为name的cookie已被删除掉 了

name=xiej ie; age=18; gender=male

name=xiej ie; gender=male

 

posted @   沐子李  阅读(1253)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示