当前位置:   article > 正文

Javaweb之javascript事件案例的详细解析_点击 “点亮”按钮 点亮灯泡,点击“熄灭”按钮熄灭灯泡; (2)输入框鼠标聚焦后,展

点击 “点亮”按钮 点亮灯泡,点击“熄灭”按钮熄灭灯泡; (2)输入框鼠标聚焦后,展

1.6.4 案例

1.6.4.1 需求说明

接下来我们通过案例来加强所学js知识点的掌握。

需求如下3个:

  1. 点击 “点亮”按钮 点亮灯泡,点击“熄灭”按钮 熄灭灯泡

  2. 输入框鼠标聚焦后,展示小写;鼠标离焦后,展示大写。

  3. 点击 “全选”按钮使所有的复选框呈现被选中的状态,点击 “反选”按钮使所有的复选框呈现取消勾选的状态。

效果如图所示:

1.6.4.2 资料准备

在VS Code中创建名为11. JS-事件-案例.html的文件,提前准备如下代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.    <meta charset="UTF-8">
  5.    <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6.    <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7.    <title>JS-事件-案例</title>
  8. </head>
  9. <body>
  10.    <img id="light" src="img/off.gif"> <br>
  11.    <input type="button" value="点亮" >
  12.    <input type="button"  value="熄灭" >
  13.    <br> <br>
  14.    <input type="text" id="name" value="ITCAST" >
  15.    <br> <br>
  16.    <input type="checkbox" name="hobby"> 电影
  17.    <input type="checkbox" name="hobby"> 旅游
  18.    <input type="checkbox" name="hobby"> 游戏
  19.    <br>
  20.    <input type="button" value="全选" >
  21.    <input type="button" value="反选" >
  22. </body>
  23. </html>

浏览器打开如图所示:

1.6.4.3 需求1
  • 需求:

    点击 “点亮”按钮 点亮灯泡,点击“熄灭”按钮 熄灭灯泡

  • 分析:

    点击按钮的时候触发,所以我们需要绑定单击事件。不管是点亮还是熄灭,都是图片的变化,所以我们需要修改图片。但是修改图片我们还需要先获取标签图片标签对象。

  • 步骤:

    • 首先给点亮按钮和熄灭按钮都绑定单击事件。分别绑定函数on()和off()

    • 然后在js中定义on()和off()函数

    • on()函数中,通过id获取img标签对象,然后通过img标签对象的src属性切换点亮的图片

    • off()函数中,通过id获取img标签对象,然后通过img标签对象的src属性切换熄灭的图片

  • 代码实现:

    事件绑定

    1. <input type="button" value="点亮" onclick="on()">
    2. <input type="button"  value="熄灭" onclick="off()">

    on()和off()函数

    1. //1. 点击 "点亮" 按钮, 点亮灯泡; 点击 "熄灭" 按钮, 熄灭灯泡; -- onclick
    2. function on(){
    3.    //a. 获取img元素对象
    4.    var img = document.getElementById("light");
    5.    //b. 设置src属性
    6.    img.src = "img/on.gif";
    7. }
    8. function off(){
    9.    //a. 获取img元素对象
    10.    var img = document.getElementById("light");
    11.    //b. 设置src属性
    12.    img.src = "img/off.gif";
    13. }

1.6.4.4 需求2
  • 需求:

    输入框鼠标聚焦后,展示小写;鼠标离焦后,展示大写。

  • 分析:

    聚焦和失焦的时候完成功能,所以我们需要给input标签绑定onfocus和onblur事件;我们要切换大小写,那么我们可定要获取原本输入框的内容,通过查询资料,需要使用input标签对象的value属性,然后进行大小写切换;切换完成我们需要重新填入,所以还是通过value属性来设置input标签输入框的内容

  • 步骤:

    • 给input标签的onfocus和onblur事件分别绑定lower()和upper()函数

    • 然后在js中定义lower()和upper()函数

    • 对于lower()函数,先通过id获取输入框对象,然后通过输入框的value属性来设置内容,内容的话可以通过字符串的toLowerCase()函数来进行小写转换

    • 对于upper()函数,先通过id获取输入框对象,然后通过输入框的value属性来设置内容,内容的话可以通过字符串的toupperCase()函数来进行大写转换

  • 代码实现:、

    事件绑定:

    <input type="text" id="name" value="ITCAST" onfocus="lower()" onblur="upper()">

    lower()和upper()函数

    1. //2. 输入框聚焦后, 展示小写; 输入框离焦后, 展示大写; -- onfocus , onblur
    2. function lower(){//小写
    3.    //a. 获取输入框元素对象
    4.    var input = document.getElementById("name");
    5.    //b. 将值转为小写
    6.    input.value = input.value.toLowerCase();
    7. }
    8. function upper(){//大写
    9.    //a. 获取输入框元素对象
    10.    var input = document.getElementById("name");
    11.    //b. 将值转为大写
    12.    input.value = input.value.toUpperCase();
    13. }

1.6.4.5 需求3
  • 需求:

    点击 “全选”按钮使所有的复选框呈现被选中的状态,点击 “反选”按钮使所有的复选框呈现取消勾选的状态。

  • 分析:

    点击按钮完成功能,所以我们需要给2个按钮绑定单击事件;我们需要设置所有复选框的状态,通过我们之前的案例,我们知道,我们需要获取所有的复选框,然后遍历,可以通过设置checked属性为true,来设置复选框为选中;那么反之,设置checked属性为false,来设置复选框为未选中。

  • 步骤:

    • 给全选和反选按钮绑定单击事件,分别绑定函数checkAll()和reverse()

    • 在js中定义checkAll()和reverse()函数

    • 对于checkAll()函数,首先通过name属性值为hobby来获取所有的复选框,然后遍历复选框,设置每个复选框的checked属性为true即可

    • 对于reverse()函数,首先通过name属性值为hobby来获取所有的复选框,然后遍历复选框,设置每个复选框的checked属性为false即可

  • 代码实现:

    事件绑定:

    1. <input type="button" value="全选" onclick="checkAll()">
    2. <input type="button" value="反选" onclick="reverse()">

    checkAll()和reverse()函数

    1. //3. 点击 "全选" 按钮使所有的复选框呈现选中状态 ; 点击 "反选" 按钮使所有的复选框呈现取消勾选的状态 ;
    2. function checkAll(){
    3.    //a. 获取所有复选框元素对象
    4.    var hobbys = document.getElementsByName("hobby");
    5.    //b. 设置选中状态
    6.    for (let i = 0; i < hobbys.length; i++) {
    7.        const element = hobbys[i];
    8.        element.checked = true;
    9.   }
    10. }
    11.    
    12. function reverse(){
    13.    //a. 获取所有复选框元素对象
    14.    var hobbys = document.getElementsByName("hobby");
    15.    //b. 设置未选中状态
    16.    for (let i = 0; i < hobbys.length; i++) {
    17.        const element = hobbys[i];
    18.        element.checked = false;
    19.   }
    20. }

1.6.4.6 完整代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.    <meta charset="UTF-8">
  5.    <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6.    <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7.    <title>JS-事件-案例</title>
  8. </head>
  9. <body>
  10.    <img id="light" src="img/off.gif"> <br>
  11.    <input type="button" value="点亮" onclick="on()">
  12.    <input type="button"  value="熄灭" onclick="off()">
  13.    
  14.    <br> <br>
  15.    <input type="text" id="name" value="ITCAST" onfocus="lower()" onblur="upper()">
  16.    <br> <br>
  17.    <input type="checkbox" name="hobby"> 电影
  18.    <input type="checkbox" name="hobby"> 旅游
  19.    <input type="checkbox" name="hobby"> 游戏
  20.    <br>
  21.    <input type="button" value="全选" onclick="checkAll()">
  22.    <input type="button" value="反选" onclick="reverse()">
  23. </body>
  24. <script>
  25.    //1. 点击 "点亮" 按钮, 点亮灯泡; 点击 "熄灭" 按钮, 熄灭灯泡; -- onclick
  26.    function on(){
  27.        //a. 获取img元素对象
  28.        var img = document.getElementById("light");
  29.        //b. 设置src属性
  30.        img.src = "img/on.gif";
  31.   }
  32.    function off(){
  33.        //a. 获取img元素对象
  34.        var img = document.getElementById("light");
  35.        //b. 设置src属性
  36.        img.src = "img/off.gif";
  37.   }
  38.    //2. 输入框聚焦后, 展示小写; 输入框离焦后, 展示大写; -- onfocus , onblur
  39.    function lower(){//小写
  40.        //a. 获取输入框元素对象
  41.        var input = document.getElementById("name");
  42.        //b. 将值转为小写
  43.        input.value = input.value.toLowerCase();
  44.   }
  45.    function upper(){//大写
  46.        //a. 获取输入框元素对象
  47.        var input = document.getElementById("name");
  48.        //b. 将值转为大写
  49.        input.value = input.value.toUpperCase();
  50.   }
  51.    //3. 点击 "全选" 按钮使所有的复选框呈现选中状态 ; 点击 "反选" 按钮使所有的复选框呈现取消勾选的状态 ; -- onclick
  52.    function checkAll(){
  53.        //a. 获取所有复选框元素对象
  54.        var hobbys = document.getElementsByName("hobby");
  55.        //b. 设置选中状态
  56.        for (let i = 0; i < hobbys.length; i++) {
  57.            const element = hobbys[i];
  58.            element.checked = true;
  59.       }
  60.   }
  61.    
  62.    function reverse(){
  63.        //a. 获取所有复选框元素对象
  64.        var hobbys = document.getElementsByName("hobby");
  65.        //b. 设置未选中状态
  66.        for (let i = 0; i < hobbys.length; i++) {
  67.            const element = hobbys[i];
  68.            element.checked = false;
  69.       }
  70.   }
  71. </script>
  72. </html>

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号