前端三剑客实验7-8-复盘

实验 7 Javascript DOM - 2操作实验

源代码见文章末尾,免费自提

1、实现如下编程内容:

1. 自行编制案例,使用上排它思想和自定义属性

2. 编制一个留言本,要求如下:

留言信息录入后,按录入的先后顺序,后输入的排在前面。
每条留言的后方都提供了一个“删除”链接,可以删除该留言信息
在这里插入图片描述

2、具体实现

1、第一题(按键的排他实现)

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>按键排他思想实现</title>
  </head>
  <body>
    <button>按钮1</button>
    <button>按钮2</button>
    <button>按钮3</button>
    <button>按钮4</button>
    <button>按钮5</button>
    <script>
      // 获取所有按钮元素
      var btns = document.getElementsByTagName('button');
      // btns得到的是类数组对象,使用btns[i]访问数组里的每一个元素
      for (var i = 0; i < btns.length; i++) {
        btns[i].onclick = function () {
          // (1) 先把所有的按钮背景颜色去掉
          for (var i = 0; i < btns.length; i++) {
            btns[i].style.backgroundColor = '';
          }
          // (2) 然后设置当前的元素背景颜色
          this.style.backgroundColor = 'pink';
        }
      }
    </script>
  </body>
</html>

运行效果
请添加图片描述

2、第二题具体实现

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>简易留言板</title>
    <style>
      * {
        margin: 0;
        padding: 0;
      }

      body {
        padding: 100px;
      }

      textarea {
        width: 200px;
        height: 100px;
        border: 1px solid pink;
        outline: none;
        resize: none;
      }

      ul {
        margin-top: 50px;
      }

      li {
        width: 300px;
        padding: 5px;
        background-color: #eee;
        font-size: 14px;
        margin: 15px 0;
      }

      li a {
        float: right;
      }
    </style>
  </head>
  <body>
    <textarea name="" id=""></textarea>
    <button>发布</button>
    <ul></ul>
    <script>
      // 1. 获取元素
      var btn = document.querySelector('button');
      var text = document.querySelector('textarea');
      var ul = document.querySelector('ul');
      // 2. 注册事件
      btn.onclick = function () {
        if (text.value == '') {
          alert('您没有输入内容');
          return false;
        } else {
          // (1) 创建元素
          var li = document.createElement('li');
          // li.innerHTML = text.value;
          li.innerHTML = text.value + '<a href="javascript:;">删除</a>';
          // (2) 添加元素
          ul.insertBefore(li, ul.children[0]);
          var as = document.querySelectorAll('a');
          for (var i = 0; i < as.length; i++) {
            as[i].onclick = function () {
              ul.removeChild(this.parentNode);
            };
          }
        }
      };
    </script>
  </body>
</html>

运行结果
请添加图片描述

实验 8 Javascript BOM操作实验

1、实现如下编程内容:

1. 自行编制若干网页,以模拟浏览器地址栏、刷新按钮和访问历史的前进、后退按钮的功能。

2. 编制一个精确到秒的文字时钟,时钟每隔1秒数自动更新时间。时钟下方有2个按钮,按钮上的文字分别为“开启时钟”和“关闭时钟”。点击这2个按钮可以分别开启和关闭时钟。

2、具体实现

1、第一题

<!DOCTYPE html>
<html lang="zh-CN">
<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>
    body {
      font-family: Arial, sans-serif;
    }

    #addressBar {
      width: 70%;
      margin: 10px;
      padding: 5px;
      font-size: 16px;
    }

    #navigationButtons {
      margin: 10px;
    }
  </style>
  <script>
    const historyStack = [];
    let currentIndex = -1;

    function navigate() {
      const addressBar = document.getElementById('addressBar');
      const url = addressBar.value;

      if (url.trim() !== '') {
        // 模拟页面加载,这里只是简单输出页面内容
        const contentContainer = document.getElementById('contentContainer');
        contentContainer.textContent = `加载页面:${url}`;

        // 记录历史
        historyStack.push(url);
        currentIndex = historyStack.length - 1;
      }
    }

    function refresh() {
      if (currentIndex >= 0 && currentIndex < historyStack.length) {
        // 模拟页面刷新,这里只是简单输出页面内容
        const contentContainer = document.getElementById('contentContainer');
        contentContainer.textContent = `刷新页面:${historyStack[currentIndex]}`;
      }
    }

    function goBack() {
      if (currentIndex > 0) {
        currentIndex--;
        refresh();
      }
    }

    function goForward() {
      if (currentIndex < historyStack.length - 1) {
        currentIndex++;
        refresh();
      }
    }
  </script>
</head>
<body>
  <input type="text" id="addressBar" placeholder="在此输入网址">
  <button onclick="navigate()">跳转</button>
  <button onclick="refresh()">刷新</button>
  <button onclick="goBack()">后退</button>
  <button onclick="goForward()">前进</button>

  <div id="contentContainer" style="margin-top: 20px; padding: 10px; border: 1px solid #ccc;"></div>
</body>
</html>

运行结果
请添加图片描述

2、第二题

<!DOCTYPE html>
<html lang="zh-CN">
<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>
    body {
      font-family: Arial, sans-serif;
      text-align: center;
    }

    #clock {
      font-size: 40px;
      font-weight: bold;
      color: blue;
      margin-top: 20px;
    }

    #buttons {
      margin-top: 20px;
    }
  </style>
  <script>
    let clockInterval;

    function startClock() {
      // 每秒更新时钟
      clockInterval = setInterval(updateClock, 1000);
    }

    function stopClock() {
      // 停止时钟更新
      clearInterval(clockInterval);
    }

    function updateClock() {
      const clockElement = document.getElementById('clock');
      const currentTime = new Date();
      const hours = currentTime.getHours().toString().padStart(2, '0');
      const minutes = currentTime.getMinutes().toString().padStart(2, '0');
      const seconds = currentTime.getSeconds().toString().padStart(2, '0');
      const formattedTime = `${hours}:${minutes}:${seconds}`;

      clockElement.textContent = formattedTime;
    }
  </script>
</head>
<body>
  <div id="clock" style="color:blue;">00:00:00</div>
  <div id="buttons">
    <button onclick="startClock()">开启时钟</button>
    <button onclick="stopClock()">关闭时钟</button>
  </div>
</body>
</html>

运行结果
请添加图片描述

资料自提(若过期,请留言)

实验 7

链接:https://pan.baidu.com/s/1Z3hbok-AjvpObLDLmkz3Mw?pwd=i7lw
提取码:i7lw

实验 8

链接:https://pan.baidu.com/s/1ZiDyNip6AqIESbksfMaRHA?pwd=re3j
提取码:re3j

  • 33
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

-Z_Nuyoah

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值