zoukankan      html  css  js  c++  java
  • 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 ・ client 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{

    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{

    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

  • 相关阅读:
    LeetCode T98.Validate Binary Search Tree/验证二叉搜索树
    LeetCode T45.Jump Game Ⅱ/跳跃游戏Ⅱ
    LeetCode T53.Maximum Subarray/最大子序和
    LeetCode T3.Longest Substring Without Repeating Characters/无重复最长子串
    LeetCode T21.Merge Two Sorted Lists/合并两个有序链表
    LeetCode T202.Happy Number/寻找快乐数
    LeetCode T1095.Find in Mountain Array/山脉数组中查找目标值
    XCTF-WEB—i-got-id-200:perl网页文件+ARGV上传造成任意文件读取
    思维导图爆破
    UNCTF2020-Reverse:re_checkin
  • 原文地址:https://www.cnblogs.com/lyl-0667/p/11213671.html
Copyright © 2011-2022 走看看