【JavaScript进阶】深入探讨JS中的对象及其事件处理

news2025/1/22 8:48:44

1.JS中的对象(掌握)

1. Array数组对象(重点)

数组对象是使用单独的变量名来存储一系列的值。

1.1创建一个数组

创建一个数组,有三种方法。

【1】常规方式:

let 数组名 = new Array();

【2】简洁方式: 推荐使用

let 数组名 = new Array(数值1,数值2,...);

【3】字面:在js中创建数组使用中括号 推荐使用

let 数组名 = [数值1,数值2,...];

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script type="text/javascript">
    /*
      创建数组对象方式一:
     */
    let arr = new Array(10, 1.2, true, '锁哥');
    //获取数据1.2
    // console.log(arr[1]);//1 表示数组索引
    //遍历数组
    //length 数组数组对象中的属性,表示数组长度
   /* for (let i = 0; i < arr.length; i++) {
        //获取数组数据
        let x = arr[i];
        console.log(x);
    }*/

    //采用方式一即上述方式定义数组 let arr = new Array(10, 1.2, true, '锁哥');注意:如果只给一个number类型的值,那么此时数值表示数组长度,数组中的数据都是empty
    let arr2 = new Array(5);
    //报错:Invalid array length 无效的数组长度
    //采用方式一即上述方式定义数组 let arr = new Array(10, 1.2, true, '锁哥');注意:如果只给一个number类型的值,
    // 那么此时数值表示数组长度,要求不能给小数,数组长度不能是小数
    // let arr3 = new Array(1.2);
    //采用方式一即上述方式定义数组 let arr = new Array(10, 1.2, true, '锁哥');注意:如果只给一个非number类型的值,
    // 那么此时数值表示数组的元素
    let arr4 = new Array('2');

    //向arr数组中存false
    // arr[4] = false;
    // console.log(arr[4]);//false

    //js中的数组长度是可变的

    //向数组中添加数据
    // arr[7] = 100;//[10, 1.2, true, '锁哥', empty × 3, 100]

    console.log(arr.length);//修改前:长度是4
    //修改数组长度
    //修改数组长度
    arr.length = 2;
    console.log(arr.length);//修改前:长度是2,数据是 10 1.2
</script>
</body>
</html>

小结:

创建数组有三种方式:

1.常规方式:let arr=new Array();

2.简写方式:let arr=new Array(数据1,数据2.。。);

注意:如果小括号中只有一个**number类型**的值,表示数组长度,不能是小数。

3.字面:let myCars=[数据1,数据2,数据3,...];

4.js中的数组定义使用中括号,并且可以存储不同类型的数据

1.2数组的特点

1.js中的数组可以存储不同类型的数据

2.js中的数组长度是可变的

3.可以使用数组名[索引]操作数组的数据

4.可以使用循环遍历数组

1.3数组中的函数

方法名

功能

concat()

用于拼接一个或多个数组

reverse()

用于数组的反转

join(separator)

用于将整个数组使用分隔符拼接成一个字符串。相当于split()反操作

sort()

对数组进行排序,不带参数是按照编码值进行排序。
如果不是按照编码值排序,那么必须指定比较器。
说明:由于字符串都是按照编码值比较大小的,所以也可以将这个方法这样理解使用:
如果要对数字进行排序,必须指定比较器。如果是按字符串进行排序,那么就是无参。

pop()

删除并返回数组的最后一个元素

push()

添加一个或者多个元素到数组的最后面

【1】代码演示1

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <script type="text/javascript">
      /*
            数组中的函数:
            1.concat()用于拼接一个或多个数组
            2.reverse()用于数组的反转
            3.join(separator)用于将整个数组使用分隔符拼接成一个字符串。相当于split()反操作
            4.pop()删除并返回数组的最后一个元素
            5.push()添加一个或者多个元素到数组的最后面
         */
      //1.concat()用于拼接一个或多个数组
      //定义数组
      let a1=[10,20,30];
      let a2=[1.1,200,false];
      let a3=['柳岩',3.14,true];
      //拼接 [10, 20, 30, 1.1, 200, false, "柳岩", 3.14, true]
      let a4 = a1.concat(a2,a3);

      //2.reverse()用于数组的反转
      let a5 = a1.reverse();//[30, 20, 10]  此时a1的数据也是[30, 20, 10],a1和a5共享一个数空间

      //3.join(separator)用于将整个数组使用分隔符拼接成一个字符串。相当于split()反操作
      let str = a2.join("_");
      console.log(str);//1.1_200_false

      //4.pop()删除并返回数组的最后一个元素
      console.log(a3.pop());//a3数组的数据是:["柳岩", 3.14]   pop函数返回的是true

      //5.push()添加一个或者多个元素到数组的最后面
      a2.push(10,'杨幂');//[1.1, 200, false, 10, "杨幂"]

      //splice(index,n) 从数组中删除元素  。index表示从哪个索引删除,n表示删除数据个数

      let arr = [10,20,30,40];
      arr.splice(1, 2);
      console.log(arr);

    </script>

  </body>

</html>

【2】代码演示2:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <script type="text/javascript">
        /*
            6.sort()
                    对数组进行排序,不带参数是按照编码值进行排序。
                    如果不是按照编码值排序,那么必须指定比较器。
                    说明:由于字符串都是按照编码值比较大小的,所以也可以将这个方法这样理解使用:
                    如果要对数字进行排序,必须指定比较器。如果是按字符串进行排序,那么就是无参。
         */
        //定义数组
        let a1=['kaja','aha','abclaja','0aa','abcde','ahd','AKAJA'];
        //使用数组对象中的函数对上述数组进行排序
        a1.sort();//["0aa", "AKAJA", "abcde", "abclaja", "aha", "ahd", "kaja"] 默认是大小升序,按照编码值升序排序

        let a2=[10,108,2,9,99,34,345,200];
        /*
           [10, 108, 2, 200, 34, 345, 9, 99] 这里是按照编码值升序排序
         */
        // a2.sort();


        /*
            对上述数组a2进行大小降序排序。
            分析:这里的需求不是按照编码值排序了,是按照数值大小排序,那么我们在sort函数的参数位置必须传递一个比较器,即匿名函数
            function(o1,o2){
                代码
             }
             升序:o1 - o2
             降序:o2 - o1
             最后结果:
             [345, 200, 108, 99, 34, 10, 9, 2] 数值大小降序
         */
        a2.sort(function (o1,o2) {
            return o2 - o1;
        });

    </script>
</body>
</html>

小结:

对于排序函数sort如果操作的数组存储的是字符串,那么就是无参的。按照编码值升序排序。

​ 对于排序函数sort如果操作的数组存储的是数值,那么就是有参的。按照大小排序。

a2.sort(function (o1,o2) {
        //降序排序:o2 - o1
        return o2 - o1;//[456, 123, 100, 30, 9, 8, 2]
    });

2.RegExp正则对象(重点)

1.创建正则对象

有两种方式:

【1】方式一

let 正则对象 = new RegExp("正则表达式");

【2】方式二推荐使用

let 正则对象 = /正则表达式/;
说明:这种写法在双斜杠中不用书写引号

注意:

1.方式二在//中直接书写正则表达式,不用书写单引号 ^0-9$

2.在js中由于一些浏览器兼容问题,书写正则符号的时候最好加上边界词:

以什么开始:^

以什么结尾:$

2.验证函数

使用RegExp中的test函数,使用格式:

let result = 正则对象.test(被验证的字符串);
说明:
如果被验证的字符串满足正则表达式则test函数返回true,否则返回false

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <script type="text/javascript">
      /*
             需求:使用正则表达式验证指定的字符串是否满足长度是6.
         */
      //1.创建正则对象
      /*
            1.在正则表达式中任意字符使用符号: .
            2.在正则中表示出现的次数:
                {n,m} 最少出现n次,最多出现m次
                {n,} 最少出现n次
                {n} 正好出现n次
            3.   .{6}  表示正好出现6位任意字符

            4.  ^  表示以什么开始    $ 表示以什么结尾
         */
      // let reg = new RegExp("^.{6}$");
      let reg =/^.{6}$/;
      //2.使用正则对象调用test函数验证字符串
      let result = reg.test("abj1a9");
      console.log(result);
    </script>

  </body>

</html>

小结:

1.创建正则表达式对象:

1)let reg = new RegExp('正则表达式');
2)let reg = /正则表达式/;
注意:别忘记在正则表达式中加上边界词:
  ^  表示以什么开始
$  表示以什么结尾

2.使用正则调用test函数验证字符串是否满足正则:

let result = reg.test(字符串);

3.String对象

在js中string属于基本类型(原始数据类型),然后js将其包装成了引用类型(复合数据类型)。

【1】创建String对象方式

1.let txt = new String("string"); 使用构造方法创建对象 了解

2.let 对象名 = "字符串"; 使用双引号 理解

3.let 对象名 = '字符串'; 使用单引号 掌握

4.let 对象名 = 字符串; 使用反单引号(键盘上的波浪线,在esc下面) 掌握 从es6开始的目的是为了简化字符串的拼接

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

</head>

<body>
    <script type="text/javascript">
        /*
            【1】创建String对象方式:
                1.let txt = new String("string"); 使用构造方法创建对象 了解
                2.let 对象名 = "字符串"; 使用双引号 理解
                3.let 对象名 = '字符串'; 使用单引号 掌握
                4.let 对象名 = `字符串`; 使用反单引号(键盘上的波浪线,在esc下面) 掌握  从es6开始的目的是为了简化字符串的拼接
         */
        //1.let txt = new String("string"); 使用构造方法创建对象 了解
        let s = new String("柳岩");//s保存地址值
        console.log(s.toString());//柳岩

        // 2.let 对象名 = "字符串"; 使用双引号 理解
        let s1 = "杨幂";
        console.log(s1);//杨幂

        //3.let 对象名 = '字符串'; 使用单引号 掌握

        let s2 = '赵丽颖';
        console.log(s2);//赵丽颖

        // 4.let 对象名 = `字符串`; 使用反单引号(键盘上的波浪线,在esc下面) 掌握  从es6开始的目的是为了简化字符串的拼接
        let i = 10;
        let s3 = '哈哈' + i + '呵呵';//+是拼接
        console.log(s3); //哈哈10呵呵
        //在反单引号中${获取数据的变量名}
        let s4=`嘿嘿${i}嘻嘻`;//es6的新语法
        console.log(s4);//嘿嘿10嘻嘻
    </script>

</body>

</html>

小结:

创建String对象方法:

1.双引号
2.构造方法 了解 let s1=new String("abc");
3.单引号 推荐  let s2='def';
4.反单引号:let s3 = `efg`;

    注意:使用反单引号主要目的为了方便字符串的拼接,省去了字符串+拼接的麻烦
    let s3 = `efg`;
    `${s3}锁哥` 结果是  efg锁哥
    ${变量}这种写法只能书写在反单引号中,${变量}大括号中的变量不一定是反单引号定义的,可以是单引号定义的

4.自定义对象(重要)

  • 格式
let 对象名称 = {
              属性名称1:属性值1,
              属性名称2:属性值2,
              ...
              函数名称:function (形参列表){}
              ...
            };
  • 代码实现
<!-- 文档类型声明标签,告知浏览器这个页面采取html版本来显示页面 -->
<!DOCTYPE html>
<!-- 告诉浏览器这是一个英文网站,本页面采取英文显示,单也可以书写中文 -->
<html lang="en">

<head>
    <!-- 必须书写,告知浏览器以UTF-8编码表编解码中文,如果不书写就会乱码 -->
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!-- 标题标签 -->
    <title>Title</title>
</head>
<body>
<script type="text/javascript">
    /*
        自定义对象:************************************很重要
          let 对象名称 = {
                属性名称1:属性值1,
                属性名称2:属性值2,
                ...
                函数名称:function (形参列表){}
                ...
              };
     */
    //自定义对象 person表示对象名
    let person ={
      username:"柳岩",
      age:20,
      //定义函数
      eat:function(a){//a=100
        //在自定义对象的函数中不能直接使用自定义对象中的属性,否则报错:selfObjectDemo06.html:32 Uncaught ReferenceError: username is not defined
        // console.log(username+"干饭人,干饭魂,a="+a);
        //使用对象person调用属性名可以获取属性值
        // console.log(person.username+"干饭人,干饭魂,a="+a);
        //后期经常使用的方式:这里的this表示当前自定义对象person
        console.log(this.username+"干饭人,干饭魂,a="+a);
      }
    };
    //如果在自定义对象外部获取自定义对象中的属性值,那么格式:对象名.属性名
    // console.log(person.username);//"柳岩"
    // console.log(person.age);//20
    //调用自定义对象中的函数:对象名.函数名(实参);
    person.eat(100);//干饭人,干饭魂,a=100
</script>
</body>
</html>

2.BOM(Browser Object Model)

操作浏览器的。常用的浏览器对象:

1.window对象:Window 对象表示浏览器中打开的窗口。

2.location对象:Location 对象包含有关当前 URL 的信息。Location 对象是 window 对象的一部分,可通过 window.Location 属性对其进行访问。

3.history对象:History 对象包含用户(在浏览器窗口中)访问过的 URL。

History 对象是 window 对象的一部分,可通过 window.history 属性对其进行访问。

1.window对象

表示浏览器窗口对象。属于最大的窗口对象,在js中可以使用window对象调用全局函数,属性以及document history location对象。

1.1方法:消息框

【1】弹出框

window.alert(弹出信息);

【2】确认框 掌握

京东购物车删除商品的弹出确认框:

1.2定时器

  • 定时器setInterval let timer = window.setInterval(code, millisec) 按照指定的周期(间隔)来执行函数或代码片段。
    参数1: code 必须写。 执行的函数名或执行的代码字符串。
    参数2: millisec 必须写。时间间隔,单位:毫秒。
    window可以理解为浏览器窗口。后面会讲解。
    timer 返回值:一个可以传递给 window.clearInterval(定时器的返回值) 从而取消对 code 的周期性执行的值。
    在关闭定时器时需要使用定时器的返回值作为参数,否则不知道关闭哪个定时器。
    例如:
    方式:函数名 , setInterval(show, 100); √ show 表示函数名,100表示每隔100豪秒执行这个函数。

案例:

需求:开启一个定时器,每隔1秒钟输出一次 hello world。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

</head>

<body>
    <script type="text/javascript">
        /*
            1.定时器
            let 返回值 = window.setInterval(调用函数,时间间隔属于毫秒);
            2.取消定时器
            window.clearInterval(定时器返回值);
         */
        //需求:开启一个定时器,每隔1秒钟输出一次 hello world。
        /*
            第一个参数表示匿名函数,传递给setInterval函数底层,底层负责调用,我们只需要书写函数体传递即可
            第二个参数:表示时间间隔单位是毫秒
         */
       /* window.setInterval(function () {
            console.log('hello world');
        }, 1000);*/

        //需求:定时器执行一次hello world就取消定时器
        let timer = window.setInterval(function () {
            console.log('hello world');
            // 取消定时器 timer 表示上述定时器的返回值,执行一次匿名函数体代码之后再执行该代码进行取消定时器
            window.clearInterval(timer);
        }, 1000);
        //取消定时器 timer 表示上述定时器的返回值
        //window.clearInterval(timer);
    </script>

</body>

</html>
  • 定时器setTimeout window.setTimeout(code,millisec)
    参数:
    code 必需。要调用的函数。
    millisec 必需。在执行代码前需等待的毫秒数。
    注意:
    该定时器只执行一次

需求:开启一个定时器 1秒之后输出Hello world,并且只输出一次。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <script type="text/javascript">
      /*
            需求:开启一个定时器 1秒之后输出Hello world,并且只输出一次。
         */
      //window.setTimeout(code,millisec)
      window.setTimeout(function () {
        console.log('hello world');
      }, 1000);
    </script>

  </body>

</html>

小结:

定时器setTimeout(匿名函数,毫秒)页面加载完成过指定的毫秒之后在执行,并且只执行一次.

setInterval()定时器,如果不取消就会一直执行

1.3案例_定时切换图片

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>JavaScript演示</title>

  </head>

  <body>



    <input type="button" onclick="on()" value="开灯">
    <img id="myImage" border="0" src="../imgs/off.gif" style="text-align:center;">
    <input type="button" onclick="off()" value="关灯">


    <script>

      function on(){
        document.getElementById('myImage').src='../imgs/on.gif';
      }

      function off(){
        document.getElementById('myImage').src='../imgs/off.gif'
      }
      var x = 0;

      // 根据一个变化的数字,产生固定个数的值; 2  x % 2     3   x % 3
      //定时器
      setInterval(function (){

        if(x % 2 == 0){
          on();
        }else {
          off();
        }

        x ++;

      },1000);

    </script>


  </body>

</html>

2 Location对象(理解)

1.window.location 对象用于获得当前页面的地址 (URL),并把浏览器重定向到新的页面。

2.对于location对象的属性说明:

例如URL: http://127.0.0.1:8020/day03/定时弹广告/05.location.html?__hbt=150384448335#abc

属性

对应的值

hash:

#abc

host:

127.0.0.1:8020

hostname:

127.0.0.1

href:

http://127.0.0.1:8020/day03/定时弹广告/05.location.html?__hbt=1503844483351#abc,同时也可以跳转到新的url

pathname:

/day03/定时弹广告/05.location.html

port:

8020

protocol:

http:

search:

?__hbt=150384448335

需求:设置location的href值来实现窗口的跳转。

就是在页面加载的时候直接访问百度一下,你就知道

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <script type="text/javascript">
      /*
            需求:设置location的href值来实现窗口的跳转。
            就是在页面加载的时候直接访问http://www.baidu.com
         */
      window.location.href = 'http://www.baidu.com';


    </script>

  </body>

</html>

小结:

location对象表示浏览器url地址,有一个比较重要的属性是href,可以实现跳转到其他服务器

3.History对象(理解)

1.window.history 对象包含浏览器的历史。表示浏览器的历史记录对象。

2.window.history对象在编写时可不使用 window 这个前缀。就是我们在使用的时候可以不写window对象

3.History对象常见的函数:

1.history.back() - 与在浏览器点击后退按钮相同  后退一步
2.history.forward() - 与在浏览器中点击按钮向前相同  前进一步
3.history.go(整数) 如果参数是正整数那么就是前进,如果参数是负整数就是后退。
    举例:
         1  前进一步 2  前进2步。 。。。
        -1  后退一步 -2 后退2步。。。。

4.代码实现:

【1】需求:

【2】技术点

点击事件:onclick,使用格式:

标签对象.onclick = function(){
    js代码
}

【3】步骤

1.创建三个html页面

2.在a页面中书写a标签跳转到b页面,同时定义一个按钮,给按钮绑定单击的js事件,实现前进

3.在b页面中书写a标签跳转到c页面,同时定义两个按钮,给按钮绑定单击的js事件,实现后退和前进

4.在c页面定义一个按钮,给按钮绑定单击的js事件,实现后退

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>a页面</title>

  </head>

  <body>
    <!--2.在a页面中书写a标签跳转到b页面,同时定义一个按钮,给按钮绑定单击的js事件,实现前进-->
    <a href="b.html">到b页面</a>

    <button id="btn">-></button>

    <script type="text/javascript">
      //1.获取上述标签对象
      let oBtn = document.getElementById('btn');
      //2.使用标签对象调用单击事件
      oBtn.onclick = function () {
        //前进到b页面
        // history.forward();
        history.go(2);//前进2步
      };
    </script>

  </body>

</html>

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>b页面</title>

  </head>

  <body>
    <!--3.在b页面中书写a标签跳转到c页面,同时定义两个按钮,给按钮绑定单击的js事件,实现后退和前进-->
    <a href="c.html">到c页面</a>

    <button id="btn1"><-</button>

    <button id="btn2">-></button>

    <script type="text/javascript">
      //1.实现后退
      document.getElementById('btn1').onclick = function () {
        history.back();
      };
      //2.实现前进
      document.getElementById('btn2').onclick = function () {
        history.forward();
      }
    </script>

  </body>

</html>



<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>c页面</title>

  </head>

  <body>
    <!--4.在c页面定义一个按钮,给按钮绑定单击的js事件,实现后退-->
    <button id="btn"><-</button>

    <script type="text/javascript">
      //实现后退
      document.getElementById('btn').onclick = function () {
        history.back();
      };
    </script>


  </body>

</html>

小结:

1.history对象表示浏览的历史记录对象

2.history对象中的常见函数:

1.back()后退一步
2.forward()前进一步
3.go(参数)正数 前进  负数 后退

3.给某个标签绑定点击事件:

标签对象.onclick=function(){

}

3.DOM概述 理解

DOM:document object model 文档对象模型。用来操作html页面中所有html标签的。在使用dom操作html标签之前,浏览器会将html页面中的标签加载到内存中形成一个dom树,上面最大的对象时document。我们可以通过document调用属性或者函数获取html标签。

4.DOM对象中的属性、方法介绍

1标签属性和文本的操作:(了解)

属性名

描述

element.getAttribute(属性的名称);

根据标签的属性的名字来获取属性的值

element.setAttribute(属性的名称, 值);

给标签设置一个属性

element.removeAttribute(属性的名称);

根据标签的属性的名字来删除属性

element.children;

获取当前元素(标签)的子元素注意:获取的子级(一层),不管嵌套(不包括孙子,只包括儿子)

element.nodeName/tagName;

获取标签名 注意:获取的是大写的字符串的标签名

element.innerHTML;

获取当前元素(标签)的文本内容

哈哈

【1】练习1

<input type="text" name="username" id="txt" value="java" />

需求1:获取属性 name的值

需求2: 给文本框设置一个属性 hello, 值是world

需求3:删除属性 value

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <input type="text" name="username" id="txt" value="java" />
    <script type="text/javascript">
      //获取input标签对象
      let oInput = document.getElementById('txt');
      // 需求1:获取属性 name的值
      //name表示input标签的属性名,根据name属性名获取name的属性值  username
      console.log(oInput.getAttribute('name'));
      // 需求2: 给文本框设置一个属性 hello, 值是world
      oInput.setAttribute('hello', 'world');
      // 需求3:删除属性 value element.removeAttribute(属性的名称);

    </script>

  </body>

</html>

【2】

练习二:

<div id="div">我是div</div>

需求一:获取标签体的内容

需求二:设置标签体的内容:

<b>我是加粗的</b>

代码示例(标签体的内容):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

</head>

<body>
<!--练习二:-->

<div id="div">我是div</div>

<script type="text/javascript">
    //1.需求一:获取标签体的内容
    //1.1获取标签对象
    let oDiv = document.getElementById('div');
    //1.2获取文本
    console.log(oDiv.innerHTML);
    console.log(oDiv.innerText);
    //需求二:设置标签体的内容:<b>我是加粗的</b>

    //2.1根据标签对象调用属性修改div的文本内容
    // oDiv.innerHTML = '<b>我是加粗的</b>';
    oDiv.innerText = '<b>我是加粗的</b>';
</script>



</body>

</html>

注意:

1.innerHTML和innerText都是操作标签文本的,但是innerHTML解析html标签的,innerText是不解析html标签的,会原样显示。以后使用innerHTML

【3】练习三:

<ul id="ul1">
  <li>aaa
    <ul>
      <li>111</li>

      <li>222</li>

      <li>333</li>

    </ul>

  </li>

  <li>bbb</li>

</ul>

需求一:获取ID为ul1的所有的子级

需求二:获取ID为ul1下面第一个li的标签名和内容

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <ul id="ul1">
      <li>aaa
        <ul>
          <li>111</li>

          <li>222</li>

          <li>333</li>

        </ul>

      </li>

      <li>bbb</li>

    </ul>

    <script type="text/javascript">
      //需求一:获取ID为ul1的所有的子级
      //1.1获取id为ul1的标签
      let oUl = document.getElementById('ul1');
      //1.2使用标签对象oUl调用属性获取子标签
      let arrLis = oUl.children;
      //1.3遍历
      /* for(let i=0;i<arrLis.length;i++){
        console.log(arrLis[i].innerHTML);
    }*/

      //需求二:获取ID为ul1下面第一个li的标签名和内容
      //获取标签名是大写
      console.log(arrLis[0].tagName);//LI
      //文本内容
      console.log(arrLis[0].innerHTML);

    </script>

  </body>

</html>

小结:

1.标签对象.children 获取指定标签的所有的子标签(儿子)

2.标签对象.innerHTML :获取标签的文本。解析html标签的

3.标签对象.innerHTML = 数据 修改文本值。解析html标签的

4.获取标签的属性值:标签对象.getAttribute(属性名);

2 获取标签(元素) 掌握

方法名

描述

document.getElementById(id属性值);

通过元素(标签)的id属性值获取标签对象,返回的是单个的标签对象注意:只能从document下面去获取

document.getElementsByName(name属性值);

通过元素(标签)的name属性值获取标签对象,返回的是标签对象的数组。注意:只能从document下面去获取

document/parentNode.getElementsByTagName(标签名);

通过元素(标签)的名称获取标签的对象,返回的是标签对象的数组。注意:可以从document或者某一个父级标签下面去获取

document/parentNode.getElementsByClassName(类名);

通过元素(标签)的class属性获取标签对象,返回的是标签对象的数组。注意:可以从document或者某一个父级标签下面去获取

注意:只有对象才可以调用属性和函数,数组不能调用。必须将数组中的每个对象取出才可以调用。

【1】练习一:

<div class="red">div1</div>

<div>div2</div>

<div class="red">div3</div>


<p>p1</p>

<p class="red">p2</p>

<p>p3</p>


<form action="#">
  用户名:<input type="text" name="username" value="suoge"/>
  密码: <input type="password" name="password" value="123"/>
  性别:<input type="radio" name="gender" value="male" />男
  <input type="radio" name="gender" value="female" />女
  <input type="submit" value="提交" />
</form>

​ ​

需求1:让页面上所有div字体颜色变蓝色

需求2:让页面上所有class为red的元素背景色变红色

需求3: 获取页面上name为 username 和 gender的元素,并输出其value属性的值

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <div class="red">div1</div>

    <div>div2</div>

    <div class="red">div3</div>


    <p>p1</p>

    <p class="red">p2</p>

    <p>p3</p>


    <form action="#">
      用户名:<input type="text" name="username" value="suoge"/>
      密码: <input type="password" name="password" value="123"/>
      性别:<input type="radio" name="gender" value="male"/>男
      <input type="radio" name="gender" value="female"/>女
      <input type="submit" value="提交"/>
    </form>

    <script type="text/javascript">
      // 需求1:让页面上所有div字体颜色变蓝色
      //1.1获取页面中所有的div
      let arrDivs = document.getElementsByTagName('div');
      //1.2遍历数组
      for (let i = 0; i < arrDivs.length; i++) {
        let oDiv = arrDivs[i];
        //使用对象oDiv操作css样式
        oDiv.style.color = 'blue';
      }
      // 需求2:让页面上所有class为red的元素背景色变红色
      //2.1根据class属性值获取所有class属性值是red的标签
      let arrReds = document.getElementsByClassName('red');
      //2.2遍历数组取出每个标签
      for (let i = 0; i < arrReds.length; i++) {
        let oRed = arrReds[i];
        //2.3使用对象操作css样式
        oRed.style.backgroundColor = 'red';
      }
      // 需求3: 获取页面上name为 username 和 gender的元素,并输出其value属性的值
      //document.getElementsByName('username')获取的是一个数组,数组中只有一个标签用户名:<input type="text" name="username" value="suoge"/>
      //document.getElementsByName('username')[0] 取出数组索引是0的标签对象
      let oUsername = document.getElementsByName('username')[0];
      //使用标签对象oUsername调用函数获取value属性值
      console.log(oUsername.getAttribute('value'));

      //获取name是gender的元素,并输出其value属性的值
      console.log(document.getElementsByName('gender')[0].getAttribute('value'));//male
      console.log(document.getElementsByName('gender')[1].getAttribute('value'));//female
    </script>

  </body>

</html>

小结:

1.根据标签id属性值获取标签对象:

document.getElementById(id名称);

2.根据标签名获取标签的数组:

let arrDivs = document.getElementsByTagName('标签名');

3.根据name属性值获取标签的数组:

let arr = document.getElementsByName('name属性值')

4.根据class属性值获取的数组:

let arrReds = document.getElementsByClassName('class属性值');

3新增元素(增)了解

方法名

描述

document.createElement(元素名称)

在页面上根据标签名来创建元素,返回创建的标签(元素)对象注意:只能从document下面去创建元素

parentNode.appendChild(要添加的元素对象);

在某一个父级元素(标签)下面去添加一个元素,每次添加到父级元素的最后面,相当于一个追加的操作

parentNode.insertBefore(要添加的元素对象,在谁的前面添加);

在某一个父级元素(标签)下面去添加一个元素,可以指定在哪一个子元素(标签)的前面添加

【1】练习1:

<ul>
  <li>bbb</li>

</ul>

需求1: 创建一个li添加到ul的最后面

需求2: 再次添加一个li要求添加到ul的第一个位置

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <ul>
      <li>bbb</li>

    </ul>

    <script type="text/javascript">
      // 需求1: 创建一个li添加到ul的最后面
      //1.1创建li标签
      let oLi = document.createElement('li');//<li></li>

      //1.2给新创建的li标签添加文本 <li>ccc</li>

      oLi.innerHTML = 'ccc';
      //1.3获取ul标签对象  document.body 获取body标签
      let oUl = document.body.children[0];
      //1.4使用ul标签对象调用函数将创建的li追加到ul的最后的子标签位置
      oUl.appendChild(oLi);

      // 需求2: 再次添加一个li要求添加到ul的第一个位置
      //2.1创建li标签
      let oLi2 = document.createElement('li');//<li></li>

      //2.2给新创建的li标签添加文本 <li>aaa</li>

      oLi2.innerHTML = 'aaa';
      //2.3使用父标签对象oUl调用函数:parentNode.insertBefore(要添加的元素对象,在谁的前面添加);将创建的li标签添加到ul的第一个位置
      // oUl.children[0] 获取的是此时ul中的第一个子标签<li>bbb</li>

      oUl.insertBefore(oLi2, oUl.children[0]);

    </script>

  </body>

</html>

小结:

1.创建标签:

document.createElement('标签名')

2.添加父标签的最后一个孩子位置:

父标签对象.appendChild(子标签对象)

3.向父标签的指定位置添加:

父标签对象.inertBefore(要添加的子标签对象,添加到哪个子标签前面的对象)

4删除元素(删)

方法名

描述

element.remove();掌握

删除当前的元素(标签)掌握

【1】练习1:

<ul>
            <li>aaa</li>

            <li>bbb</li>

            <li>ccc</li>

</ul>

需求:删除第一个li标签。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

  </head>

  <body>
    <ul>
      <li>aaa</li>

      <li>bbb</li>

      <li>ccc</li>

    </ul>

    <script type="text/javascript">
      //需求:删除第一个li标签。 element.remove();掌握删除当前的元素(标签)掌握
      document.getElementsByTagName('li')[0].remove();
    </script>

  </body>

</html>

小结:

删除:删除标签对象.remove();

5.事件(掌握)

1.概述

js事件可以是浏览器行为,也可以是用户行为.

如果是浏览器行为例如是页面加载完成事件。onload

如果是用户行为就是用户的一切操作都是发生的事件,鼠标操作事件(单击,双击,悬浮等),键盘操作事件(键盘录入等)。

2.常见事件

事件名

描述

onload

某个页面或图像被完全加载之后触发

onsubmit

当表单提交时触发该事件---注意事件源是表单form

onclick

鼠标点击某个对象

ondblclick

鼠标双击某个对象

onblur

元素失去焦点(输入框)

onfocus

元素获得焦点(输入框)

onchange

用户改变域的内容。一般使用在select标签中。

onkeydown

某个键盘的键被按下

onkeypress

某个键盘的键被按下或按住,一直按住

onkeyup

某个键盘的键被松开

onmousedown

某个鼠标按键被按下

onmouseup

某个鼠标按键被松开

onmouseover

鼠标被移到某元素之上 除了输入框

onmouseout

鼠标从某元素移开 除了输入框

onmousemove

鼠标被移动

3.html标签绑定事件

标签绑定事件:就是让上述的js事件作用在某个标签上

1.静态绑定

就是将事件名作为标签的属性名,在属性值中调用js函数。

需求:

1、给div标签绑定单击事件,输出div的文本

2、给div标签绑定鼠标悬浮事件,使其背景颜色变红

3、给div标签绑定鼠标移出事件,使其背景颜色变蓝

说明:定义一个div,并给div设置宽、高和背景颜色灰色:#ccc。

设置div的代码:

<style type="text/css">
  div {
  width: 200px;
  height: 200px;
  background-color: #ccc;/*灰色*/
}
</style>

就是将事件名作为html标签的属性名,在属性值中调用js函数。

<标签名 事件名="调用的js函数" 事件名="调用的js函数" 。。。></标签名>

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style type="text/css">
      div {
        width: 200px;
        height: 200px;
        background-color: #ccc;/*灰色*/
      }
    </style>


  </head>

  <body>
    <!--静态绑定事件:就是将事件名作为html标签的属性名,在属性值中调用js函数。-->
    <!--
    这里的this表示当前div标签对象
    -->
    <div onclick="fn1(this);" onmouseover="fn2(this);" onmouseout="fn3(this);">div1</div>

    <script type="text/javascript">
      //需求:
      // 1、给div标签绑定单击事件,输出div的文本
      function fn1(obj) {//obj=this
        //obj接收的是this表示上述的div标签对象
        console.log(obj.innerHTML);
      }
      // 2、给div标签绑定鼠标悬浮onmouseover事件,使其背景颜色变红
      function fn2(obj) {//obj=this
        obj.style.backgroundColor = 'red';
      }
      // 3、给div标签绑定鼠标移出onmouseout事件,使其背景颜色变蓝
      function fn3(obj) {
        obj.style.backgroundColor = 'blue';
      }

    </script>

  </body>

</html>

小结:

html静态绑定js事件:

 <div onclick="fn1(this);" onmouseover="fn2(this);" onmouseout="fn3(this);">div1</div>

2.动态绑定:

就是根据dom技术获取某个标签对象,使用标签对象调用事件名,然后将匿名函数赋值事件名。

标签对象.事件名 = function(){

}

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style type="text/css">
      div {
        width: 200px;
        height: 200px;
        background-color: #ccc;/*灰色*/
      }
    </style>


  </head>

  <body>
    <!--动态绑定事件:就是根据dom技术获取某个标签对象,使用标签对象调用事件名,然后将匿名函数赋值事件名。-->
    <div>div1</div>

    <script type="text/javascript">
      //需求:
      // 1、给div标签绑定单击事件,输出div的文本
      //1.1获取标签对象
      let oDiv = document.getElementsByTagName('div')[0];
      //1.2给div绑定单击事件
      oDiv.onclick = function () {
        //这里的this是调用当前事件onclick的标签对象oDiv
        console.log(this.innerHTML);
      };
      // 2、给div标签绑定鼠标悬浮onmouseover事件,使其背景颜色变红
      oDiv.onmouseover = function () {
        this.style.backgroundColor = 'red';
      };
      // 3、给div标签绑定鼠标移出onmouseout事件,使其背景颜色变蓝
      oDiv.onmouseout = function () {
        this.style.backgroundColor = 'blue';
      };
    </script>

  </body>

</html>

小结:

1.html绑定js事件有两种方式:

​ 1)静态绑定:将事件名作为标签的属性名,在属性值中调用js函数

<div onclick="fn(this);">柳岩</div>

<script type="text/javascript">

  // 1、给div标签绑定单击事件,输出div的文本
  function fn(obj) {//obj=this
    console.log(obj.innerHTML);
  }

</script>

​ 2)动态绑定:使用标签对象调用js事件,使用匿名函数给其赋值

let oDiv = document.getElementsByTagName('div')[0];
//给上述div动态绑定js单击事件
oDiv.onclick = function () {
  //this表示调用当前事件onclick的标签对象oDiv
  // console.log(oDiv.innerHTML);
  console.log(this.innerHTML);
};

2.静态绑定和动态绑定区别?

​ 静态绑定缺点:js和html标签耦合在一起

​ 动态绑定:解耦合。

感谢各位大佬观看,创作不易,还请各位大佬点赞支持!!!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2213465.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

没有接口设计文档怎么做测试?

一、接口是什么&#xff1f; 1.官方解释&#xff1a;API(Application Programming Interface) 即应用程序接口。是一个软件组件&#xff0c;或是一个Web服务与外界进行交互的接口&#xff0c;这里接口可以和API划等号。 2.逐层叠加方式解释&#xff1a; 功能层面&#xff1a…

Vert.x,Web - Restful API

将通过Vert.x Web编写一个前后分离的Web应用&#xff0c;做为Vert.x Web学习小结。本文为后端部分&#xff0c;后端实现业务逻辑&#xff0c;并通过RESTfull接口给前端(Web页面)调用。 案例概述 假设我们要设计一个人力资源(HR)系统&#xff0c;要实现对员工信息的增删改查。…

MybatisPlus+Spring Boot3 分页查询实现

目录 导入依赖 本文的house表 直接复制粘贴运行即可 MybatisConfig配置文件 创建数据库对应的实体类 创建mapper层接口 在service包下创建xxxService接口 controller层创建XXXController类 完成分页查询 导入依赖 <!--注意 SpringBoot3的依赖与Spring Boot2的Mybatis…

时隔11年,再次被纳入标普500指数,戴尔科技股票是否该买入?

猛兽财经核心观点&#xff1a; &#xff08;1&#xff09;9月24日&#xff0c;戴尔科技时隔11年后再次被纳入了标普500指数。 &#xff08;2&#xff09;华尔街分析师普遍很看好戴尔科技&#xff0c;并强调了戴尔科技在人工智能服务器和强劲的收入增长。 &#xff08;3&#xf…

枚举在Java体系中的作用

1. 枚举 枚举是在JDK1.5以后引入的。主要用途是&#xff1a;将一组常量组织起来&#xff0c;在这之前表示一组常量通常使用定义常量的方式&#xff1a; //用public static final修饰常量 public static final int RED 1; public static final int GREEN 2; public static f…

深度学习-24-基于keras的十大经典算法之残差网络ResNet

文章目录 1 残差网络(ResNet)1.1 ResNet简介1.2 ResNet结构2 模型应用2.1 加载数据2.2 构建模型SimpleResNet2.2.1 simple_resnet_block2.2.2 SimpleResNet2.2.3 实例化模型2.2.4 模型训练2.2.5 模型预测2.3 构建模型ResNet182.3.1 residual_block2.3.2 ResNet182.3.3 训练模型…

Redis高并发缓存设计问题与性能优化

1、缓存设计典型问题 1.1、缓存穿透 缓存穿透是指查询一个根本不存在的数据&#xff0c;缓存层和存储层都不会命中&#xff0c;通常出于容错的考虑&#xff0c;如果从存储层查不到数据则不写入缓存层。 缓存穿透将导致不存在的数据每次请求都要到存储层去查询&#xff0c;失…

vue3 Invalid value type passed to callWithAsyncErrorHandling()

vue3 提示警告。页面内点击按钮无响应 原因&#xff1a; <el-form :model"questionPage.queryParam" ref"queryForm" :inline"true"> ... <el-button type"primary" plain click"queryForm">查询</el-butto…

热门超声波清洗机有哪些?双十一适合学生党的清洗机推荐!

十一月十一号的双十一马上就快要到了&#xff0c;在这个一年一度的购物狂欢节中&#xff0c;不少人都期待着能够以优惠的价格购买到心仪的商品。超声波清洗机作为近年来备受关注的家用电器之一&#xff0c;以其清洁效果好、操作简便、价格亲民等特点&#xff0c;成为了大家双十…

leetcode二叉树(五)-二叉树层序遍历

题目 102.二叉树的层序遍历 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20],[15,7…

imx6ull-正点原子阿尔法-uboot-v2.4网络驱动修改

1 修改网络 PHY 地址,修改 PHY 驱动 /*[c] 1 修改网络PHY地址,修改PHY驱动*/ /******************************************************************************/ #if (CONFIG_FEC_ENET_DEV 0) #define IMX_FEC_BASE ENET_BASE_ADDR #define CONFIG_FEC_MXC_PHYADDR …

Electron-(一)创建桌面应用

一、概述 本文通过核心步骤介绍&#xff0c;形成使用Electron进行桌面应用创建的概述性内容。 在当今的软件开发领域&#xff0c;Electron 作为一款强大的工具&#xff0c;为开发者提供了一种便捷的方式来创建跨平台的桌面应用。本文将通过详细介绍核心步骤&#xff0c;带您领…

记一次有趣的发现-绕过堡垒机访问限制

前言 在某一次对设备运维管理的时候&#xff0c;发现的某安全大厂堡垒机设备存在绕过访问限制的问题&#xff0c;可以直接以低权限用户访问多个受控系统&#xff0c;此次发现是纯粹好奇心驱使下做的一个小测试压根没用任何工具。因为涉及到了很多设备和个人信息&#xff0c;所以…

AI大模型引领智慧城市:11个行业应用场景全解析

AI大模型在智慧城市11个行业的应用场景‍‍‍ 人工智能是当今科技领域最前沿的课题&#xff0c;更是新一轮科技革命的重要代表之一。从AlphaGo Zero通过自我学习碾压“AI前辈”AlphaGo&#xff0c;到百度智能无人汽车成功上路、苹果手机开启新的刷脸认证方式……而最近&#x…

老师发期中成绩小程序-易查分一键发布省事~

老师注意&#xff0c;本学期的期中考试即将拉开帷幕。考试结束后&#xff0c;成绩的发布往往是我们觉得最繁琐耗时的工作。逐一私信每个学生家长&#xff0c;告知他们的考试情况。使用我要向老师们推荐一个神器——易查分&#xff0c;能让老师一分钟完成期中成绩发布的工作。 易…

亿赛通与Ping32文档加密功能全面盘点,选择最适合的工具

在信息化迅速发展的今天&#xff0c;文档安全愈发成为企业关注的焦点。为了保护敏感数据不被非法访问或泄露&#xff0c;选择一款高效的文档加密工具至关重要。亿赛通与Ping32作为市场上备受认可的安全解决方案&#xff0c;各自提供了强大的文档加密功能。本文将对这两款软件的…

嘉立创EDA—51最小系统PCB

1&#xff0c;灵活使用 下边栏的库中可以搜索对应需要的型号&#xff0c;如51最小系统板 常用库中有常用的电容和电阻&#xff0c;以及排针等,熟悉一些常用快捷键的使用 设计完电路后可以选用折线进行分区&#xff0c;写好每个网络标号&#xff0c;以及添加一些文字说明 最后可…

C语言复习第5章 操作符

目录 关于和*的优先级问题进一步理解*(p)和*(p) 关于和*的优先级问题 首先明确一点 解引用*的优先级比自增低 区分如下代码: 1.*p:等价于*(p) 先对指针p解引用 再把指针p1(不会对野指针进行解引用操作) 2.*p:等价于*(p) 先把指针p1 再对指针p解引用(可能对野指针解引用 会报错…

前端布局与响应式设计综合指南(末)

​&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;Css篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来Css篇专栏内容:前端布局与响应式设计综合指南(末) 目录 61、为什么要初始化CSS样式 62、CSS3 有哪些新特性 63、…