jsWEB Apis 01下

本文介绍了如何通过JavaScript操作DOM元素的CSS样式,包括直接设置样式、通过className和classList操作,以及在表单元素上的应用。还探讨了使用自定义属性和定时器(间歇函数)来实现动态变化,如轮播图和倒计时。最后展示了实际的动态轮播图案例,利用间歇函数实现图片切换和指示器动态更新。
摘要由CSDN通过智能技术生成

1.如何操作元素的CSS样式

对象.style.样式属性名称='属性值'。

案例1 修改box的部分属性值 

<style>
    .box{
        width: 200px;
        height: 200px;
        background-color: palevioletred;
    }
</style>
<body>
    <div class="box">
        <p>1</p>
    </div>
    <script>
        // 获取元素
        const box =  document.querySelector('.box')
        //2 设置样式
        // console.dir(box) 输出 box的所有属性及属性值
        console.dir(box.style);
        box.style.width='380px';
        box.style.height='380px';
        box.style.margin='0 auto'
        box.style.paddingleft='100px'

    </script>
</body>

2.c

2.通过className 操作CSS (不常用 有弊端)

语法 :元素.className = 'nav'

注意 如果写的过程不带之前的类名,新增的类名会将这个类名覆盖 所以一般 写的时候都是元素.className = 'box nav' 带原来的类名 下面案例有详细说明

因此比较麻烦 所以在以后的使用频率不是很高。

案例1

 <style>
        .nav{
            color: red;
        }
        .box{
            width: 200px;
            height: 200px;
            background-color: aqua;
            margin: 100px auto;
            padding: 10px;
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>
    <div class="box">
        1
    </div>
    <script>
        // 获取元素
        const  box =  document.querySelector('div');

        // 通过类名给div设置样式
        // box.className = 'nav box'
        //  box.className = box.className +' box'
        // 注意事项 会覆盖原有的类名  所有需要将原有的类名复制

    </script>

3.通过classlist 操作元素属性值  是目前比较常用的

1.常见的classlist属性

add添加属性、remove移除属性、toggle切换(如果存在就删除 ,如果不存在就添加)

classList contains() 方法解释
该contains()方法将检查元素的class属性并检查它是否包含特定的类名。

您需要将要检查的类名作为其参数传递。true如果类名存在或false不存在,该方法将返回。

例如,以下是检查元素是否"navbar"存在类的方法:


const div = document.getElementById("header");
div.classList.contains("navbar"); // true
div.classList.contains("lg-block"); // false

案例

综合案例 - 利用随机数+操作元素属性值实现 动态变化

<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;
    }

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





    setInterval(function(){
      
      
    },1000);

    // 随机数
 const random = Math.floor(Math.random() * sliderData.length);
// 获取图片
const img = document.querySelector('.slider-wrapper img');
// 修改图片
img.src=sliderData[random].url;


// 获取文字要存放的位置
const p = document.querySelector('.slider-footer p');
// 修改文字
p.innerHTML=sliderData[random].title;


// 获取背景要存放的位置
const bj = document.querySelector('.slider-footer');
// 修改背景
bj.style.background=sliderData[random].color;

// 获取小圆点存放位置
const li = document.querySelector(`.slider-indicator li:nth-child(${random + 1})`);
// 添加小圆点
li.classList.add('active');




   
  </script>

4.操作表单元素的属性

1.设置input输入框的Value 值必须使用。元素.value=‘’,进行赋值

设置多选框的默认选中 元素.checked='true'  属性有true  false(关闭) 两个属性值!

设置按钮的关闭属性 。元素.disabled='true'  属性和上方一样,但是这里的true是关闭  而false是打开。

 5.通过自定义属性来 操作DOM

新的语法都是 通过data - 来进行定义

6.定时器  - 间歇函数 的使用

setInterval(函数,间隔时间)这里需要注意 间隔时间的单位是毫秒。

 <script>
      //开启定时器
        // 写法1
        // setInterval(function (){
        //     console.log('我执行了');
        // },100);
        // setInterval(function (){
        //     console.log('我执行了');
        //  },100)  100是想设置的毫秒数
        //  写法二
    //     function fn(){
    //         console.log('哈哈头发多')
    //     }
    //     // fn();//这也卸载定时器里面 得到的是函数的返回值 undefinde
    //     setInterval(fn(),1000);
    // 关闭定时器
    function fn(){
            console.log('哈哈头发多')
        }
        const  num  = setInterval(fn,1000)
    clearInterval(num) //关闭计时器。
 


    // 联系  
    let  i  = 0;
    setInterval(function(){

        i++;
        console.log(i);
    },1000)
    </script>

 

7.间歇函数的停止-关闭定时器

间歇函数综合案例1 网页时钟效果的实现

<!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>
         *{
            box-sizing: border-box;
         }
         .clock {
            width: 600px;
            height: 600px;
            background: url(./images/clock.jpg) no-repeat;
            margin:  0 auto;
            position: relative;
            transform: rotate(0deg);
         }
         .hh,
         .mm,
         .ss {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;
            background: url(./images/hour.png) no-repeat center;
            transform: rotate(0deg);
         }
         .mm {
            background: url(./images/minute.png) no-repeat center;
            transform: rotate(270deg);
         }
         .ss {
            background: url(./images/second.png) no-repeat center;
            transform: rotate(0deg);
         }
    </style>

</head>
<body>
    <div class="clock">
        <div class="hh" id="h"></div>
        <div class="mm" id="m"></div>
        <div class="ss" id="s"></div>
    </div>
     <script>
        const miao = document.querySelector('.ss');
        let rota=0;
        let rotas = 270;
        let rotas2=0;
        let i=0;
        const fen = document.querySelector('.mm');
        const shi = document.querySelector('.hh')

        setInterval(function(){
            if(rota ==360){
                rota = 0;
                i++;
                if(i >=1 && i<=60){

                rotas +=6;
                fen.style.transform=`rotate(${rotas}deg)`;
                if(i==60){
                    i=0;
                    rotas2+=6;
                    shi.style.transform=`rotate(${rotas2}deg)`;
                }
                
            }
            }
            rota +=6;

           

            miao.style.transform=`rotate(${rota}deg)`;
            console.log(rota)
            

        },1000)
     </script>
</body>
</html>

效果图  实现,秒针  分针  时针的运行 仅展示代码   所需素材 自行下载

间歇函数案例2 - 用户注册倒计时实现

 <textarea name="" id="" cols="30" rows="10">
        用户注册协议
        欢迎注册成为京东用户!在您注册过程中,您需要完成我们的注册流程并通过点击同意的形式在线签署以下协议,请您务必仔细阅读、充分理解协议中的条款内容后再点击同意(尤其是以粗体或下划线标识的条款,因为这些条款可能会明确您应履行的义务或对您的权利有所限制)。
        【请您注意】如果您不同意以下协议全部或任何条款约定,请您停止注册。您停止注册后将仅可以浏览我们的商品信息但无法享受我们的产品或服务。如您按照注册流程提示填写信息,阅读并点击同意上述协议且完成全部注册流程后,即表示您已充分阅读、理解并接受协议的全部内容,并表明您同意我们可以依据协议内容来处理您的个人信息,并同意我们将您的订单信息共享给为完成此订单所必须的第三方合作方(详情查看
    </textarea>
    <br>
    <button class="btn" disabled>我已经阅读用户协议(5)</button>
 

    <script>
        const btn =document.querySelector('.btn');
        let i = 5;

        const timer= setInterval(function(){
            i--;
            console.log(i)
            btn.innerHTML=`我已阅读用户协议(${i})`;

            
            // 3.随着数字递减 改变button  按钮的文字
            if(i===0){

                // 如果等于0 就用停止计时器
                clearInterval(timer)
               
                btn.innerHTML='同意';
                btn.disabled=false;
                
            }
        },1000)
        
    </script>

 综合案例- 动态轮播图 使用间歇函数实现

  <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;
    }

    .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="./images/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: './images/slider01.jpg', title: '对人类来说会不会太超前了?', color: 'rgb(100, 67, 68)' },
      { url: './images/slider02.jpg', title: '开启剑与雪的黑暗传说!', color: 'rgb(43, 35, 26)' },
      { url: './images/slider03.jpg', title: '真正的jo厨出现了!', color: 'rgb(36, 31, 33)' },
      { url: './images/slider04.jpg', title: '李玉刚:让世界通过B站看到东方大国文化', color: 'rgb(139, 98, 66)' },
      { url: './images/slider05.jpg', title: '快来分享你的寒假日常吧~', color: 'rgb(67, 90, 92)' },
      { url: './images/slider06.jpg', title: '哔哩哔哩小年YEAH', color: 'rgb(166, 131, 143)' },
      { url: './images/slider07.jpg', title: '一站式解决你的电脑配置问题!!!', color: 'rgb(53, 29, 25)' },
      { url: './images/slider08.jpg', title: '谁不想和小猫咪贴贴呢!', color: 'rgb(99, 72, 114)' },
    ]


// 获取图片
const img = document.querySelector('.slider-wrapper img');



// 获取文字要存放的位置
const p = document.querySelector('.slider-footer p');



// 获取背景要存放的位置
const bj = document.querySelector('.slider-footer');



  let i = 0;
    setInterval(function(){
          i++;
          if(i>= sliderData.length){
            i=0;

            // const li1 = document.querySelector(`.slider-indicator li:nth-child()`).classList.remove('active');

          }
        // 修改图片
        img.src=sliderData[i].url;
        // 修改文字
        p.innerHTML=sliderData[i].title;
    // 修改背景
        bj.style.background=sliderData[i].color;
 // 获取小圆点存放位置 并且删除
 const li1 = document.querySelector(`.slider-indicator .active`).classList.remove('active');
    // 获取小圆点存放位置 并且添加
        const li = document.querySelector(`.slider-indicator li:nth-child(${i + 1})`).classList.add('active');
       

        
    },1000);







   
  </script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值