前端学习--JS入门(4) dom/操作元素内容和属性/定时器

本文介绍了JavaScript中的WebAPI基本概念,包括DOM和BOM的作用与分类。详细讲解了如何通过DOM获取和操作页面元素,如使用querySelector和querySelectorAll,以及innerText和innerHTML属性修改元素内容。还涉及元素属性、样式操作以及自定义属性的使用,并提供了定时器的使用示例和一个轮播图的综合案例。
摘要由CSDN通过智能技术生成

变量声明

有变量先给const,如果后面发现它是要被修改的,再改为let

一、Web API基本认知

1.1 作用和分类

作用:使用js操作HTML和浏览器

分类:DOM(文档对象模型-控制标签)BOM(浏览器对象模型-)

1.2 DOM

Document Object Model--用来呈现以及与任意HTML或XML文档交互的API

操作网页内容

作用:开发网页特效实现和用户的交互

1.3 DOM树

将HTML以树状结构直观的表达出来,称之为文档树或DOM树

直观的体现了标签与标签的关系

1.4 DOM对象

浏览器根据html标签生成的js对象

即把html中的标签当作js中的对象来处理

document对象

网页所有内容都在document里面,它提供的属性和方法用来访问和操作网页内容 

二、获取DOM对象 

2.1 根据CSS选择器来获取DOM元素

1.选择匹配的第一个元素

//字符串中的写法和css选择器一致
//返回的是一个对象
//可以直接修改操作
const box = document.querySelector('div') //按照标签选择
const box = document.querySelector('.box') //按照类选择
const box = document.querySelector('#nav') //按照id选择

 2.选择匹配的所有元素

//返回一个对象数组
//遍历修改操作
 const liArr = document.querySelectorAll('ul li')
        //得到的是伪数组
        //有长度索引号,但是没有pop() push()等方法
        for(let i=0; i < liArr.length; i++){
            console.log(liArr[i])
        }

 三、操作元素内容

 修改元素的文本更换内容

3.1 对象.innerText

    <div class="box">我是文字内容</div>
    <script>
        const box = document.querySelector('.box')
        console.log(box.innerText)
        //innerText不解析标签 只能显示纯文本
        box.innerText = '我的内容变了'
        console.log(box.innerText)
    </script>

 3.2 对象.innerHTML

//解析标签
box.innerHTML = '<strong>我要变粗</strong>'
console.log(box.innerHTML)

案例-年会抽奖

<!DOCTYPE html>
<html lang="en">
<head>
    <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>Document</title>
    <style>
        .wrapper{
            width: 480px;
            height: 420px;
            margin: 100px auto;
            box-sizing: border-box;
        }
        span{
            display: inline-block;
        }
    </style>
</head>
<body>
    <div class="wrapper">
        <strong>年会抽奖</strong>
        <h1>一等奖:<span id="one">??</span></h1>
        <h3>二等奖:<span id="two">??</span></h3>
        <h5>三等奖:<span id="three">??</span></h5>
    </div>
    <script>
        const personArr = ['小麦','小黑','小白','小红','小明','小张','小何','小程']
        function selectPrice(arr,id){
            let rand = Math.floor(Math.random()*arr.length)
            let span = document.querySelector(id)
            span.innerHTML = arr[rand]
            arr.splice(rand,1)
        }
        selectPrice(personArr,'#one')
        selectPrice(personArr,'#two')
        selectPrice(personArr,'#three')
    </script>
</body>
</html>

 四、操作元素属性

4.1 操作元素常用属性

常见属性:href / title /src

对象.属性 = 值

<img src="./images/1.webp" alt="">
<script>
    const img = document.querySelector('img')

    img.src = './images/2.webp'
    img.title = 'pink老师的艺术照'
</script>

4.2 操作元素样式属性

1. 通过style属性操作css

对象.style.样式属性 =  值

const box = document.querySelector('.box')
//修改元素样式
box.style.width = '200px'
//有连接符-的属性采用小驼峰命名法
box.style.marginTop = '15px'
box.style.backgroundColor = 'pink'

2.通过操作类名操作css 

元素.className = '类名'

同时修改多个类名,直接使用会覆盖以前的类名

3. 通过classList操作css

追加和删除类名

element.classList.add('类名') //追加一个类
element.classList.remove('类名') //删除一个类
element.classList.toggle('类名') //切换一个类 有就删掉 没有就加上

4.3 操作表单元素属性

    <input type="checkbox">
    <button>按钮</button>
    <script>
        const ipt = document.querySelector('input')
        ipt.checked = true

        const bt = document.querySelector('button')
        bt.disabled = true
    </script>

4.4 自定义属性

data- 开头的都是自定义属性

DOM上以dataset对象方式获取

<div data-id="1" data-spm="dd">1</div>
<script>
    const one = document.querySelector('div')
    console.log(one.dataset.id)
</script>

五、定时器-间歇函数

网页中每隔一段时间自动执行一段代码

//开启定时器

setInterval(函数名, 间隔时间)

//函数名不能加小括号


//关闭定时器

let 变量名 = setInterval(函数名, 间隔时间)

clearInterval(变量名)

综合案例 

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

<head>
  <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>
  <style>
    * {
      box-sizing: border-box;
    }

    .slider {
      width: 560px;
      height: 400px;
      overflow: hidden;
    }

    .slider-wrapper {
      width: 100%;
      height: 320px;
    }

    .slider-wrapper img {
      width: 100%;
      height: 100%;
      display: block;
      /* transition: all 1s; */
    }

    .slider-footer {
      height: 80px;
      background-color: rgb(100, 67, 68);
      padding: 12px 12px 0 12px;
      position: relative;
    }

    .slider-footer .toggle {
      position: absolute;
      right: 0;
      top: 12px;
      display: flex;
    }

    .slider-footer .toggle button {
      margin-right: 12px;
      width: 28px;
      height: 28px;
      appearance: none;
      border: none;
      background: rgba(255, 255, 255, 0.1);
      color: #fff;
      border-radius: 4px;
      cursor: pointer;
    }

    .slider-footer .toggle button:hover {
      background: rgba(255, 255, 255, 0.2);
    }

    .slider-footer p {
      margin: 0;
      color: #fff;
      font-size: 18px;
      margin-bottom: 10px;
    }

    .slider-indicator {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      align-items: center;
    }

    .slider-indicator li {
      width: 8px;
      height: 8px;
      margin: 4px;
      border-radius: 50%;
      background: #fff;
      opacity: 0.4;
      cursor: pointer;
    }

    .slider-indicator li.active {
      width: 12px;
      height: 12px;
      opacity: 1;
    }
  </style>
</head>

<body>
  <div class="slider">
    <div class="slider-wrapper">
      <img src="./image/slider01.jpg" alt="" />
    </div>
    <div class="slider-footer">
      <p>对人类来说会不会太超前了?</p>
      <ul class="slider-indicator">
        <li class="active"></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
      </ul>
      <div class="toggle">
        <button class="prev">&lt;</button>
        <button class="next">&gt;</button>
      </div>
    </div>
  </div>
  <script>
    // 1. 初始数据
    const sliderData = [
      { url: './image/slider01.jpg', title: '对人类来说会不会太超前了?', color: 'rgb(100, 67, 68)' },
      { url: './image/slider02.jpg', title: '开启剑与雪的黑暗传说!', color: 'rgb(43, 35, 26)' },
      { url: './image/slider03.jpg', title: '真正的jo厨出现了!', color: 'rgb(36, 31, 33)' },
      { url: './image/slider04.jpg', title: '李玉刚:让世界通过B站看到东方大国文化', color: 'rgb(139, 98, 66)' },
      { url: './image/slider05.jpg', title: '快来分享你的寒假日常吧~', color: 'rgb(67, 90, 92)' },
      { url: './image/slider06.jpg', title: '哔哩哔哩小年YEAH', color: 'rgb(166, 131, 143)' },
      { url: './image/slider07.jpg', title: '一站式解决你的电脑配置问题!!!', color: 'rgb(53, 29, 25)' },
      { url: './image/slider08.jpg', title: '谁不想和小猫咪贴贴呢!', color: 'rgb(99, 72, 114)' },
    ]

    const img = document.querySelector('.slider-wrapper img')
    const p = document.querySelector('.slider-footer p')
    let i = 0
    setInterval(function(){
      i++
      if(i > sliderData.length) i = 0
      img.src = sliderData[i].url
      p.innerHTML = sliderData[i].title

      document.querySelector(`.slider-indicator .active`).classList.remove('active')
      document.querySelector(`.slider-indicator li:nth-child(${i + 1})`).classList.add('active')
    },1000)
  </script>
</body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值