4 JavaScript基础(2)

简介: JavaScript对象:自定义对象、宿主对象、内建对象内建对象: 由ES标准中定义的对象,在所有ES实现中都可以使用[Math、String、Number…]**宿主对象:**由js环境提供的对象,如[BOM、DOM]**自定义对象:**程序员自定义:::

JavaScript对象:自定义对象、宿主对象、内建对象


内建对象: 由ES标准中定义的对象,在所有ES实现中都可以使用[Math、String、Number…]

**宿主对象:**由js环境提供的对象,如[BOM、DOM]

**自定义对象:**程序员自定义

:::


1 DOM对象(文档对象模型:Document Object Model)


1.1 模型图解


15.png


1.2 节点(node):构成HTML最基本的单元,我们把常用节点分为4类


16.png

(1)文档节点:指HTML文档

(2)元素节点:指HTML中标签

(3)属性节点:指元素的属性

(4)文本节点:HTML中文本内容

2 事件


2.1 常用事件


17.png


2.2 常见问题


js绑定节点后发现值是null,无法进行相应的事件操作

如下:

18.png

原因: 代码执行顺序所导致的,因为js位置在页面代码之前加载,此时页面还未加载,所以找不到节点元素,无法进行其他操作

解决方案: 为window绑定一个onload事件,使得页面先加载

案例:

//windows绑定onload事件,使得js代码在页面加载完之后执行
window.onload = function (){
  // 获取button对象
  var buttonT = document.getElementById("btn2");
  // button绑定点击事件
  buttonT.onclick = function(){
  // 更换button文本内容
  buttonT.innerHTML = "buttonTest";
  }
}


2.3 获取元素节点


需要通过document对象获取元素节点


方法名 说明

getElementById() 通过id获取元素节点对象

getElementsByTagName() 通过标签名获取一组,元素节点对象

getElementsByName() 通过name属性获取一组,元素节点对象

案例

需求:做一个图片展示页面,

条件:①有提示语:共多少张图片,此时展示第几张

②通过按钮实现图片切换,当图片到最后一张时再点击下一张跳回第一张,第一张的上一张跳回最后一张

代码:

HTML页面代码:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title>DOM模型学习</title>
  <script type="text/javascript" src="js/test2.js"></script>
  <style type="text/css">
    *{
    margin: 0;
    padding: 0;
    }
    #outer{
    width: 600px;
    margin: 60px auto;
    padding: 6px;
    background-color: skyblue;
    text-align: center;
    }
    img{
    width: 600px;
    }
  </style>
  </head>
  <body>
  <div id="outer">
    <span>图片展示:共5张,第1张</span>
    <img src="../JavaScript/img/1.jpg" alt="图片">
    <button id="prev"> 上一张</button>  <button id="next">下一张 </button>
  </div>
  </body>
</html>

js代码

window.onload = function(){
  // 通过id获取元素对象
  var pre = document.getElementById("prev");
  var nex = document.getElementById("next");
  // 定义数组存放图片路径
  var arrayImg = ["../JavaScript/img/1.jpg","../JavaScript/img/2.jpg","../JavaScript/img/3.jpg","../JavaScript/img/4.jpg","../JavaScript/img/5.jpg"];
  // 通过标签获取img元素对象
  var imgTest = document.getElementsByTagName("img")[0];
  var textT = document.getElementsByTagName("span")[0];
  var index = 0;
  nex.onclick = function(){
  index ++;
  if(index>4){
    index = 0;
  }
  imgTest.src = arrayImg[index];
  textT.innerHTML = "图片展示:共"+arrayImg.length+"张,第"+(index+1)+"张";
  } 
  pre.onclick = function(){
  index --;
  if(index<0){
    index = 4;
  }
  imgTest.src = arrayImg[index];
  textT.innerHTML = "图片展示:共"+arrayImg.length+"张,第"+(index+1)+"张";
  }
}


2.4 获取元素节点的相关节点


方法\属性 说明

获取子节点

getElementsByTagName() 方法,通过标签获取节点的子节点

childNodes 属性,获取节点的所有子节点(会获取到空字符)

firstChild 属性,获取节点第一个节点(会获取到空字符)

lastChild 属性,获取节点最后一个节点(会获取到空字符)

获取父节点和兄弟节点

parentNode 属性,获取当前节点父节点

previousSibling 属性,当前节点的前一个兄弟元素(不包含空字符,IE8以下不支持)

nextSibling 属性,当前节点的后一个兄弟节点


目录
相关文章
|
7天前
|
人工智能 运维 安全
|
5天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
6天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
596 21
|
12天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
964 110
|
6天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。