Web APIs-01基础:获取元素+操作元素+事件基础

day01 - Web APIs

1.1. Web API介绍

1.1.1 API的概念

API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数。

目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,无需理解其内部工作机制细节,只需直接调用使用即可。

简单理解:API是给程序员提供的一种工具,以便能更轻松的实现想要完成的功能。

1.1.2 Web API的概念

Web API 是浏览器提供的一套操作浏览器功能和页面元素的 API ( BOM 和 DOM )。

现阶段我们主要针对于浏览器讲解常用的 API , 主要针对浏览器做交互效果。比如我们想要浏览器弹出一个警示框, 直接使用 alert(‘弹出’)

MDN 详细 API : https://developer.mozilla.org/zh-CN/docs/Web/API

因为 Web API 很多,所以我们将这个阶段称为 Web APIs。

此处的 Web API 特指浏览器提供的一系列API(很多函数或对象方法),即操作网页的一系列工具。例如:操作html标签、操作页面地址的方法。

1.1.3 API 和 Web API 总结

  1. API 是为我们程序员提供的一个接口,帮助我们实现某种功能,我们会使用就可以了,不必纠结内部如何实现

  2. Web API 主要是针对于浏览器提供的接口,主要针对于浏览器做交互效果

  3. Web API 一般都有输入和输出(函数的传参和返回值),Web API 很多都是方法(函数)

1.2. DOM 介绍

1.2.1 什么是DOM

文档对象模型(Document Object Model,简称DOM),是 W3C 组织推荐的处理可扩展标记语言(html或者xhtml)的标准编程接口

W3C 已经定义了一系列的 DOM 接口,通过这些 DOM 接口可以改变网页的内容、结构和样式。

DOM是W3C组织制定的一套处理 html和xml文档的规范,所有的浏览器都遵循了这套标准。

1.2.2. DOM树

在这里插入图片描述

DOM树 又称为文档树模型,把文档映射成树形结构,通过节点对象对其处理,处理的结果可以加入到当前的页面。

  • 文档:一个页面就是一个文档,DOM中使用document表示
  • 节点:网页中的所有内容,在文档树中都是节点(标签、属性、文本、注释等),使用node表示
  • 标签节点:网页中的所有标签,通常称为元素节点,又简称为“元素”,使用element表示

1.3. 获取元素

1.3.1. 根据ID获取

语法:document.getElementById(id)
作用:根据ID获取元素对象
参数:id值,区分大小写的字符串
返回值:元素对象 或 null

案例代码

<body>
    <div id="time">2019-9-9</div>
    <script>
        // 因为我们文档页面从上往下加载,所以先得有标签 所以我们script写到标签的下面
        var timer = document.getElementById('time');
        console.log(timer);
        console.log(typeof timer);
        // console.dir 打印我们返回的元素对象 更好的查看里面的属性和方法
        console.dir(timer);
    </script>
</body>

1.3.2. 根据标签名获取元素

语法:document.getElementsByTagName('标签名') 或者 element.getElementsByTagName('标签名') 
作用:根据标签名获取元素对象
参数:标签名
返回值:元素对象集合(伪数组,数组元素是元素对象)

案例代码

<body>
    <ul>
        <li>知否知否,应是等你好久11</li>
        <li>知否知否,应是等你好久22</li>
        <li>知否知否,应是等你好久33</li>
        <li>知否知否,应是等你好久44</li>
        <li>知否知否,应是等你好久55</li>
    </ul>
    <ul id="nav">
        <li>生僻字</li>
        <li>生僻字</li>
        <li>生僻字</li>
        <li>生僻字</li>
        <li>生僻字</li>
    </ul>
    <script>
        // 1.返回的是 获取过来元素对象的集合 以伪数组的形式存储的
        var lis = document.getElementsByTagName('li');
        console.log(lis);
        console.log(lis[0]);
        // 2. 我们想要依次打印里面的元素对象我们可以采取遍历的方式
        for (var i = 0; i < lis.length; i++) {
            console.log(lis[i]);
        }
        // 3. element.getElementsByTagName()  可以得到这个元素里面的某些标签
        var nav = document.getElementById('nav'); // 这个获得nav 元素
        var navLis = nav.getElementsByTagName('li');
        console.log(navLis);
    </script>
</body>

注意事项:

  • 因为得到的是一个对象的集合,所以我们想要操作里面的元素就需要遍历

  • 得到元素对象是动态的。

  • getElementsByTagName()获取到是动态集合,即:当页面增加了标签,这个集合中也就增加了元素。

1.3.3. H5新增获取元素方式

1.document.getElementsByClassName('类名'); // 根据类名返回元素对象集合

2.document.querySelector('选择器'); // 根据指定选择器返回第一个元素对象

3.document.querySelectorAll('选择器'); // 根据指定选择器返回

注意事项:

  • querySelector 和 querySelectorAll 里面的选择器需要加符号,例如:
document.querySelector('#nav');
案例代码
<body>
    <div class="box">盒子1</div>
    <div class="box">盒子2</div>
    <div id="nav">
        <ul>
            <li>首页</li>
            <li>产品</li>
        </ul>
    </div>
    <script>
        // 1. getElementsByClassName 根据类名获得某些元素集合
        var boxs = document.getElementsByClassName('box');
        console.log(boxs);

        // 2. querySelector 返回指定选择器的第一个元素对象  切记 里面的选择器需要加符号 .box  #nav
        var firstBox = document.querySelector('.box');
        console.log(firstBox);
        var nav = document.querySelector('#nav');
        console.log(nav);
        var li = document.querySelector('li');
        console.log(li);

        // 3. querySelectorAll()返回指定选择器的所有元素对象集合
        var allBox = document.querySelectorAll('.box');
        console.log(allBox);
        var lis = document.querySelectorAll('li');
        console.log(lis);
    </script>
</body>

1.3.4 获取特殊元素(body,html)

获取body元素
document.body  // 返回body元素对象
获取html元素
document.documentElement  // 返回html元素对象

1.4. 事件基础

1.4.1. 事件概述

网页中的每个元素都可以产生某些可以触发 JavaScript 的事件,例如,我们可以在用户点击某按钮时产生一个 事件,然后去执行某些操作。

1.4.2. 事件三要素

  • 事件源(谁):触发事件的元素
  • 事件类型(什么事件): 例如 click 点击事件
  • 事件处理程序(做啥):事件触发后要执行的代码(函数形式),事件处理函数
案例代码
<body>
    <button id="btn">唐伯虎</button>
    <script>
        // 点击一个按钮,弹出对话框
        // 1. 事件是有三部分组成  事件源  事件类型  事件处理程序   我们也称为事件三要素
        //(1) 事件源 事件被触发的对象   谁  按钮
        var btn = document.getElementById('btn');

        //(2) 事件类型  如何触发 什么事件 比如鼠标点击(onclick) 还是鼠标经过 还是键盘按下
        //(3) 事件处理程序  通过一个函数赋值的方式 完成
        btn.onclick = function() {
            alert('点秋香');
        }
    </script>
</body>

1.4.3. 执行事件的步骤

第一步:获取事件源

第二步:注册事件(绑定事件)

第三步:添加事件处理程序(采取函数赋值形式)

案例代码
<body>
    <div>123</div>
    <script>
        // 执行事件步骤
        // 点击div 控制台输出 我被选中了
        // 1. 获取事件源
        var div = document.querySelector('div');
        // 2.绑定事件 注册事件
        // div.onclick 
        // 3.添加事件处理程序 
        div.onclick = function() {
            console.log('我被选中了');
        }
    </script>
</body>

1.4.4. 常见的鼠标事件

鼠标事件触发条件
onclick鼠标点击左键触发
onmouseover鼠标经过触发
onmouseout鼠标离开触发
onfocus获得鼠标焦点触发
onblur失去鼠标焦点触发
onmousemove鼠标移动触发
onmouseup鼠标弹起触发
onmousedown鼠标按下触发

1.5. 操作元素

JavaScript的 DOM 操作可以改变网页内容、结构和样式,我们可以利用 DOM 操作元素来改变元素里面的内容、属性等。(注意:这些操作都是通过元素对象的属性实现的

1.5.1. 改变元素内容(获取或设置)

element.innerText // 从起始位置到终止位置的内容,但它去除html标签,同时空格和换行也会去掉

element.innerHTML // 起始位置到终止位置的全部内容,包括html标签,同时保留空格和换行
innerText改变元素内容
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>重点案例</title>
  <style>
    div,
    p {
      width: 300px;
      height: 30px;
      line-height: 30px;
      color: #fff;
      background-color: pink;
    }
  </style>
</head>

<body>
  <button>显示当前系统时间</button>
  <div>某个时间</div>
  <p>1123</p>
  <script>
    // 当我们点击了按钮,div里面的文字会发生变化
    // 1. 获取元素  var 谁 = document.querySelector()
    var btn = document.querySelector('button');
    var div = document.querySelector('div');
    // 2.注册事件 谁.怎么做 = 效果  点击后再修改内容
    btn.onclick = function () {
      // div.innerText = '2019-6-6';
      div.innerHTML = getDate();
    }

    // 无参数 必须有返回值
    function getDate() {
      var date = new Date();
      console.log(date) // Tue Aug 25 2020 22:59:50 GMT+0800 (中国标准时间)
      // 我们写一个 2019年 5月 1日 星期三
      var year = date.getFullYear();
      console.log('年', year) // 2020

      var month = date.getMonth() + 1;
      console.log('月', month) // 8

      var dates = date.getDate();
      console.log('日', dates) // 25

      var arr = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
      var day = date.getDay();
      console.log('星期几', day) // 2
      
      return '今天是:' + year + '年' + month + '月' + dates + '日 ' + arr[day];
    }
    // 我们元素可以不用添加事件;不用点击按钮刷新页面就可以修改内容      谁.innerHTML  修改谁里面的内容
    var p = document.querySelector('p');
    p.innerHTML = getDate();
  </script>
</body>

</html>
innerText和innerHTML的区别
  • 获取内容时的区别:

​ innerText会去除空格和换行,而innerHTML会保留空格和换行

  • 设置内容时的区别:

​ innerText不会识别html,而innerHTML会识别

案例代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div>
        <span>显示吗?</span>
    </div>
    <p>
        我是文字
        <span>123</span>
    </p>
    <script>
        // 获取元素里面的内容  document.querySelector()
        // innerText 和 innerHTML的区别  
        // 语法:事件源.innerText 或者 事件源.innerHTML  这两个属性是可读写的

        // 疑惑点:
        // 1. innerText (非标准:平时不常用) 不识别html标签(标签会直接显示) 去除空格和换行
        // 2. innerHTML ( W3C标准:平时常用) 识别html标签(标签不会显示)  保留空格和换行的


        // 1.定义事件源后、直接打印 div里面的内容
        var div = document.querySelector('div');
        console.log(div.innerText); // 显示吗?
        console.log(div.innerHTML); // <span>显示吗?</span>


        // 2.定义事件源后、先修改div里面的内容;再打印div里面的内容
        var div = document.querySelector('div');
        div.innerText = '<strong>今天是:</strong> 2019';
        console.log(div.innerText); // <strong>今天是:</strong> 2019
        console.log(div.innerHTML); // &lt;strong&gt;今天是:&lt;/strong&gt; 2019


        // 正文:
        // 1. innerText (非标准:平时不常用) 不识别html标签(标签会直接显示) 去除空格和换行 
        var div = document.querySelector('div');
        div.innerText = '<strong>今天是:</strong> 2019'; // <strong>今天是:</strong> 2019
        console.log(div.innerText); // <strong>今天是:</strong> 2019
        console.log(div.innerHTML);
        

        // 2. innerHTML ( W3C标准:平时常用) 识别html标签(标签不会显示)  保留空格和换行的
        // div.innerHTML = '<strong>今天是:</strong> 2019'; // 今天是: 2019  注意: 今天是: 会有加粗效果


        // 这两个属性是可读写的  可以获取元素里面的内容  document.querySelector()
        var p = document.querySelector('p');
        console.log(p.innerText); // 我是文字 123    innerText去除空格和换行  让多行内容在一行显示
        console.log(p.innerHTML); // 我是文字  <span>123</span> 这两个内容不再一行显示
    </script>
</body>

</html>

1.5.2. 常用元素的属性操作

  1. innerText、innerHTML 改变元素内容
  2. src、href
  3. id、alt、title

获取属性的值

元素对象.属性名

设置属性的值

元素对象.属性名 = 值

案例代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        img {
            width: 300px;
        }
    </style>
</head>

<body>
    <button id="ldh">刘德华</button>
    <button id="zxy">张学友</button> <br>
    <img src="images/ldh.jpg" alt="" title="刘德华">

    <script>
        // 修改图片的元素属性  src  改变为  对象.属性
        // 1. 获取元素
        var ldh = document.getElementById('ldh');
        var zxy = document.getElementById('zxy');
        var img = document.querySelector('img');
        // 2. 注册事件  处理程序
        zxy.onclick = function() {
            img.src = 'images/zxy.jpg';
            img.title = '张学友思密达';
        }
        ldh.onclick = function() {
            img.src = 'images/ldh.jpg';
            img.title = '刘德华';
        }
    </script>
</body>

</html>

1.5.3. 案例:分时问候

案例:分时显示不同图片,显示不同问候语

根据不同时间,页面显示不同图片,同时显示不同的问候语

  • 如果上午时间打开页面:显示上午好,显示上午的图片

  • 如果下午时间打开页面:显示下午好,显示下午的图片

  • 如果晚上时间打开页面:显示晚上好,显示晚上的图片

案例分析:

  1. 根据系统不同的时间来判断,所以需要用到日期内置对象
  2. 利用多分支语句来设置不同的图片
  3. 需要一个图片,并且根据时间修改图片,就需要用到操作元素src属性
  4. 需要一个div元素,显示不同问候语,修改元素内容即可
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        img {
            width: 300px;
        }
    </style>
</head>

<body>
    <img src="images/s.gif" alt="">
    <div>上午好</div>
    <script>
        // 思路:
        // 根据系统不同时间来判断,所以需要用到日期内置对象
        // 利用多分支语句来设置不同的图片
        // 需要一个图片,并且根据时间修改图片,就需要用到操作元素src属性 img.src
        // 需要一个div元素,显示不同问候语,修改元素内容即可  div.innerHTML


        // 1.获取元素 因为要修改图片和内容,所以需要获取 img 和 div
        var img = document.querySelector('img');
        var div = document.querySelector('div');
        // 2. 得到当前的小时数
        var date = new Date();
        var h = date.getHours();
        // 3. 判断小时数改变图片(img.src) 和 文字信息(div.innerHTML)
        if (h < 12) {
            img.src = 'images/s.gif';
            div.innerHTML = '亲,上午好,好好写代码';
        } else if (h < 18) {
            img.src = 'images/x.gif';
            div.innerHTML = '亲,下午好,好好写代码';
        } else {
            img.src = 'images/w.gif';
            div.innerHTML = '亲,晚上好,好好写代码';

        }
    </script>
</body>

</html>

1.5.4. 表单元素的属性操作

利用Dom可以操作如下表单元素的属性:

type value checked selected disabled

获取属性的值

元素对象.属性名

设置属性的值

元素对象.属性名 = 值

表单元素中有一些属性如:disabled、checked、selected,元素对象的这些属性的值是布尔型。

案例代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <button>按钮</button>
    <input type="text" value="输入内容">
    <script>
        // 1. 获取元素
        var btn = document.querySelector('button');
        var input = document.querySelector('input');
        // 2. 注册事件 处理程序
        btn.onclick = function() {
            // input.innerHTML = '点击了';  这个是 普通盒子 比如 div 标签里面的内容
            // 注意(重点):表单里面的值 文字内容是通过 value 来修改的
            input.value = '被点击了';
            // 如果想要某个表单被禁用 不能再点击 disabled  我们想要这个按钮 button禁用
            // btn.disabled = true; 法1
            this.disabled = true; // 法2(平时经常使用)
            // this 指向的是事件函数的调用者 btn
        }
    </script>
</body>

</html>

1.5.5. 案例:仿京东显示密码

点击按钮将密码框切换为文本框,并可以查看密码明文

案例分析:

  1. 核心思路:点击眼睛按钮,把密码框类型改为文本框就可以看见里面的密码

  2. 一个按钮两个状态,点击一次,切换为文本框,继续点击一次切换为密码框

  3. 算法:利用一个flag变量,来判断flag的值。

    如果是1就切换为文本框,flag设置为0,

    如果是0就切换为密码框,flag设置为1

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .box {
            position: relative;
            width: 400px;
            border-bottom: 1px solid #ccc;
            margin: 100px auto;
        }
        
        .box input {
            width: 370px;
            height: 30px;
            border: 0;
            outline: none;
        }
        
        .box img {
            position: absolute;
            top: 2px;
            right: 2px;
            width: 24px;
        }
    </style>
</head>

<body>
    <div class="box">
        <label for="">
            <img src="images/close.png" alt="" id="eye">
        </label>
        <input type="password" name="" id="pwd">
    </div>
    <script>
        // 1. 获取元素:img 和 input 
        var eye = document.getElementById('eye');
        var pwd = document.getElementById('pwd');
        // 2. 注册事件 处理程序
        var flag = 0;
        // 核心:3.往后同一个按钮有2种操作,需要引用 flag
        // 先点击马上做判断:所以判断语句封装在处理程序里面
        eye.onclick = function() {
            // 注意(核心思路): 点击一次之后, flag 一定要变化 重新给flag赋值
            // 第一次flag = 0,操作完之后;直接重新给flag赋值:flag = 1;
            // 第二次flag直接走else里面的代码;操作完之后;直接重新给flag赋值:flag = 0;
            // 重复走第一次flag = 0时的操作....依次循环
            // flag == 0  睁眼        flag==1  闭眼
            if (flag == 0) {
                pwd.type = 'text';
                eye.src = 'images/open.png';
                flag = 1; // 赋值操作
            } else {
                pwd.type = 'password';
                eye.src = 'images/close.png';
                flag = 0;
            }

        }
    </script>
</body>

</html>

1.5.6. 样式属性操作

我们可以通过 JS 修改元素的大小、颜色、位置等样式。

常用方式

element.style  // 行内样式操作

element.className  // 类名样式操作
方式1:通过操作style属性

元素对象的style属性也是一个对象!

元素对象.style.样式属性 = 值;

注意:

  • JS 里面的样式采取驼峰命名法,比如 fontSizebackgroundColor
  • JS 修改 style 样式操作,产生的是行内样式,css权重比较高
案例代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        div {
            width: 200px;
            height: 200px;
            background-color: pink;
        }
    </style>
</head>

<body>
    <div></div>
    <script>
        // 1. 获取元素
        var div = document.querySelector('div');
        // 2. 注册事件 处理程序
        div.onclick = function() {
            // div.style里面的属性 采取驼峰命名法   this.style.属性(属性采取驼峰命名法) = '';
            this.style.backgroundColor = 'purple';
            this.style.width = '250px';
        }
    </script>
</body>

</html>
案例:淘宝点击关闭二维码

案例分析:

  1. 核心思路:利用样式的显示和隐藏完成,display: none 隐藏元素;display: block 显示元素
  2. 点击按钮,就让这个二维码盒子隐藏起来即可
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .box {
            position: relative;
            width: 74px;
            height: 88px;
            border: 1px solid #ccc;
            margin: 100px auto;
            font-size: 12px;
            text-align: center;
            color: #f40;
            /* display: block; */
        }
        
        .box img {
            width: 60px;
            margin-top: 5px;
        }
        
        .close-btn {
            position: absolute;
            top: -1px;
            left: -16px;
            width: 14px;
            height: 14px;
            border: 1px solid #ccc;
            line-height: 14px;
            font-family: Arial, Helvetica, sans-serif;
            cursor: pointer;
        }
    </style>
</head>

<body>
    <div class="box">
        淘宝二维码
        <img src="images/tao.png" alt="">
        <i class="close-btn">×</i>
    </div>
    <script>
        // 1. 获取元素 
        var btn = document.querySelector('.close-btn');
        var box = document.querySelector('.box');
        // 2.注册事件 程序处理  
        btn.onclick = function() {
            box.style.display = 'none';
        }
    </script>
</body>

</html>
案例:循环精灵图背景

在这里插入图片描述

案例分析:

  1. 首先精灵图图片排列有规律的
  2. 核心思路:利用for循环,修改精灵图片的 背景位置:background-position
  3. 剩下的就是考验你的数学功底了
  4. 让循环里面的i索引号 * 44就是每个图片的y坐标
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        li {
            list-style-type: none;
        }
        
        .box {
            width: 250px;
            margin: 100px auto;
        }
        
        .box li {
            float: left;
            width: 24px;
            height: 24px;
            background-color: pink;
            margin: 15px;
            background: url(images/sprite.png) no-repeat;
        }
    </style>
</head>

<body>
    <div class="box">
        <ul>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </div>
    <script>
        // 1. 获取元素 所有的小li 
        var lis = document.querySelectorAll('li');
        for (var i = 0; i < lis.length; i++) {
            // 核心思路1: 让索引号 乘以 44 就是每个li 的背景y坐标  index就是我们的y坐标
            var index = i * 44;
            // 核心2:'0 -44px' 然后把44删除,采用引引加加'+index+' 效果是: '0 -' + index + 'px'
            lis[i].style.backgroundPosition = '0 -' + index + 'px';
        }
    </script>
</body>

</html>
案例:显示隐藏文本框内容

在这里插入图片描述

案例分析:

  1. 首先表单需要2个新事件,获得焦点onfocus失去焦点 onblur
  2. 如果获得焦点,判断表单里面内容是否为默认文字,如果是默认文字,就清空表单内容
  3. 如果失去焦点,判断表单内容是否为空,如果为空,则表单内容改为默认文字
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        input {
            color: #999;
        }
    </style>
</head>

<body>
    <input type="text" value="手机">
    <script>
        // 1.获取元素
        var text = document.querySelector('input');
        // 2.注册事件 获得焦点事件 onfocus 
        text.onfocus = function() {
                // console.log('得到了焦点');
                if (this.value === '手机') {
                    this.value = ''; // 把里面的提示信息清空
                }
                // 获得焦点需要把文本框里面的文字颜色变黑
                // 注意: this.style.color = '#333'; 在if语句之外书写
                this.style.color = '#333';
            }
            // 3. 注册事件 失去焦点事件 onblur
        text.onblur = function() {
            // console.log('失去了焦点');
            // 失去焦点时,如果里面的内容为空,那么显示提示信息'手机'
            if (this.value === '') {
                this.value = '手机';
            }
            // 失去焦点需要把文本框里面的文字颜色变浅色
            // 注意:  this.style.color = '#999'; 在if语句之外书写
            this.style.color = '#999';
        }
    </script>

</body>

</html>
方式2:通过操作className属性

元素对象.className = 值;

注意事项:

  1. 如果样式修改较多,可以采取操作类名方式更改元素样式。
  2. class因为是个保留字,因此使用className来操作元素类名属性
  3. className 会直接更改元素的类名,会覆盖原先的类名。

案例代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        div {
            width: 100px;
            height: 100px;
            background-color: pink;
        }
        
        .change {
            background-color: purple;
            color: #fff;
            font-size: 25px;
            margin-top: 100px;
        }
    </style>
</head>


<body>
    <div class="first">文本</div>
    <script>
        // 1. 使用 element.style 获得修改元素样式  如果样式比较少 或者 功能简单的情况下使用
        var test = document.querySelector('div');
        test.onclick = function() {
            // this.style.backgroundColor = 'purple';
            // this.style.color = '#fff';
            // this.style.fontSize = '25px';
            // this.style.marginTop = '100px';
            // 让我们当前元素的类名改为了 change  this.className = 'change';

            // 2. 我们可以通过 修改元素的className更改元素的样式 适合于样式较多或者功能复杂的情况

            // 3. 如果想要保留原先的类名,我们可以这么做 多类名选择器 this.className = 'first change';
            // this.className = 'change';
            this.className = 'first change';
        }
    </script>
</body>

</html>
案例:密码框格式提示错误信息

在这里插入图片描述

案例分析:

  1. 首先判断的事件是表单失去焦点 onblur
  2. 如果输入正确则提示正确的信息颜色为绿色小图标变化
  3. 如果输入不是6到16位,则提示错误信息颜色为红色 小图标变化
  4. 因为里面变化样式较多,我们采取className修改样式
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>仿新浪注册页面</title>
    <style>
        div {
            width: 600px;
            margin: 100px auto;
        }
        
        .message {
            display: inline-block;
            font-size: 12px;
            color: #999;
            background: url(images/mess.png) no-repeat left center;
            padding-left: 20px;
        }
        
        .wrong {
            color: red;
            background-image: url(images/wrong.png);
        }
        
        .right {
            color: green;
            background-image: url(images/right.png);
        }
    </style>
</head>

<body>
    <div class="register">
        <input type="password" class="ipt">
        <p class="message">请输入6~16位密码</p>
    </div>
    <script>
        // 思路:
        // 首先判断的事件是表单失去焦点 onblur
        // 如果输入正确则提示正确的信息   1.颜色为绿色  2.小图标变化
        // 如果输入不是6到16位,则 1.提示错误信息修改(class类名.innerHTML)  2.颜色为红色 3.小图标变化

        // 因为里面变化样式较多,我们采取className修改样式


        // 1.获取元素 input 和 p 
        var ipt = document.querySelector('.ipt');
        var message = document.querySelector('.message');
        //2. 注册事件 失去焦点
        ipt.onblur = function() {
            // 根据表单里面值的长度 ipt.value.length
            if (this.value.length < 6 || this.value.length > 16) {
                // console.log('错误');
                message.className = 'message wrong';
                message.innerHTML = '您输入的位数不对要求6~16位';
            } else {
                message.className = 'message right';
                message.innerHTML = '您输入的正确';
            }
        }
    </script>
</body>

</html>
案例:开关灯
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <button id="btn">开关灯</button>
    <script>
        var btn = document.getElementById('btn');
        var flag = 0;
        btn.onclick = function() {
            if (flag == 0) {
                document.body.style.backgroundColor = 'black';
                flag = 1;
            } else {
                document.body.style.backgroundColor = '#fff';
                flag = 0;
            }
        }
    </script>
</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

落花流雨

你的鼓励将是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值