【Javascript】-一些原生的网页设计案例

news2024/11/13 0:47:27

JavaScript 网页设计案例

1. 动态时钟
  • 功能描述:在网页上显示一个动态更新的时钟,包括小时、分钟和秒。
  • 实现思路
    • 使用 setInterval 函数每秒更新时间。
    • 获取当前时间并更新页面上的文本。
  • 代码示例
    <div id="clock"></div>
    <script>
      function updateClock() {
        const now = new Date();
        const hours = now.getHours().toString().padStart(2, '0');
        const minutes = now.getMinutes().toString().padStart(2, '0');
        const seconds = now.getSeconds().toString().padStart(2, '0');
        document.getElementById('clock').textContent = `${hours}:${minutes}:${seconds}`;
      }
      setInterval(updateClock, 1000);
      updateClock(); // 初始化时立即更新一次
    </script>
    
2. 菜单切换效果
  • 功能描述:点击菜单项时,显示或隐藏相应的内容区域。
  • 实现思路
    • 使用事件监听器监听点击事件。
    • 根据点击的菜单项显示或隐藏相应的内容。
  • 代码示例
    <ul id="menu">
      <li onclick="showContent('home')">首页</li>
      <li onclick="showContent('about')">关于我们</li>
      <li onclick="showContent('contact')">联系我们</li>
    </ul>
    <div id="content">
      <div id="home" class="content-item">欢迎来到首页!</div>
      <div id="about" class="content-item" style="display: none;">关于我们的一些信息。</div>
      <div id="contact" class="content-item" style="display: none;">联系方式和地址。</div>
    </div>
    <script>
      function showContent(id) {
        const contentItems = document.querySelectorAll('.content-item');
        contentItems.forEach(item => item.style.display = 'none');
        document.getElementById(id).style.display = 'block';
      }
    </script>
    
3. 表单验证
  • 功能描述:在用户提交表单前进行简单的输入验证。
  • 实现思路
    • 使用 addEventListener 监听表单的提交事件。
    • 检查输入是否符合要求,如非空、邮箱格式等。
  • 代码示例
    <form id="myForm">
      <label for="name">姓名:</label>
      <input type="text" id="name" required>
      <br>
      <label for="email">邮箱:</label>
      <input type="email" id="email" required>
      <br>
      <button type="submit">提交</button>
    </form>
    <script>
      document.getElementById('myForm').addEventListener('submit', function(event) {
        event.preventDefault(); // 阻止表单默认提交行为
        const name = document.getElementById('name').value;
        const email = document.getElementById('email').value;
    
        if (name === '' || email === '') {
          alert('姓名和邮箱不能为空!');
          return;
        }
    
        if (!email.includes('@')) {
          alert('请输入有效的邮箱地址!');
          return;
        }
    
        alert('表单提交成功!');
        this.submit(); // 提交表单
      });
    </script>
    
4. 图片轮播
  • 功能描述:在网页上实现图片轮播效果。
  • 实现思路
    • 使用 setInterval 定时切换图片。
    • 使用 CSS 控制图片的显示和隐藏。
  • 代码示例
    <div id="carousel">
      <img src="image1.jpg" class="carousel-image" style="display: block;">
      <img src="image2.jpg" class="carousel-image" style="display: none;">
      <img src="image3.jpg" class="carousel-image" style="display: none;">
    </div>
    <script>
      let currentIndex = 0;
      const images = document.querySelectorAll('.carousel-image');
    
      function showNextImage() {
        images[currentIndex].style.display = 'none';
        currentIndex = (currentIndex + 1) % images.length;
        images[currentIndex].style.display = 'block';
      }
    
      setInterval(showNextImage, 3000); // 每3秒切换一次图片
    </script>
    
5. 模态框(Modal)
  • 功能描述:点击按钮后弹出一个模态框,模态框内可以显示内容或表单。
  • 实现思路
    • 使用 CSS 控制模态框的显示和隐藏。
    • 使用 JavaScript 监听按钮点击事件,显示或隐藏模态框。
  • 代码示例
    <button id="openModal">打开模态框</button>
    <div id="modal" class="modal">
      <div class="modal-content">
        <span class="close">&times;</span>
        <p>这是一个模态框</p>
      </div>
    </div>
    
    <style>
      .modal {
        display: none;
        position: fixed;
        z-index: 1;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        overflow: auto;
        background-color: rgba(0,0,0,0.4);
      }
      .modal-content {
        background-color: #fefefe;
        margin: 15% auto;
        padding: 20px;
        border: 1px solid #888;
        width: 80%;
      }
      .close {
        color: #aaa;
        float: right;
        font-size: 28px;
        font-weight: bold;
      }
      .close:hover,
      .close:focus {
        color: black;
        text-decoration: none;
        cursor: pointer;
      }
    </style>
    
    <script>
      const modal = document.getElementById('modal');
      const openModalBtn = document.getElementById('openModal');
      const closeModalBtn = document.querySelector('.close');
    
      openModalBtn.addEventListener('click', () => {
        modal.style.display = 'block';
      });
    
      closeModalBtn.addEventListener('click', () => {
        modal.style.display = 'none';
      });
    
      window.addEventListener('click', (event) => {
        if (event.target == modal) {
          modal.style.display = 'none';
        }
      });
    </script>
    
6. 滚动加载更多
  • 功能描述:当用户滚动到页面底部时,自动加载更多内容。
  • 实现思路
    • 使用 IntersectionObserver API 监听元素是否进入视口。
    • 当元素进入视口时,加载更多内容。
  • 代码示例
    <div id="content">
      <div class="item">内容1</div>
      <div class="item">内容2</div>
      <div class="item">内容3</div>
      <div id="load-more" class="load-more">加载更多</div>
    </div>
    
    <style>
      .item {
        height: 200px;
        border: 1px solid #ccc;
        margin: 10px 0;
      }
    </style>
    
    <script>
      const loadMore = document.getElementById('load-more');
      const observer = new IntersectionObserver((entries) => {
        entries.forEach(entry => {
          if (entry.isIntersecting) {
            loadMoreContent();
          }
        });
      }, { threshold: 0.1 });
    
      observer.observe(loadMore);
    
      function loadMoreContent() {
        const content = document.getElementById('content');
        for (let i = 0; i < 3; i++) {
          const newItem = document.createElement('div');
          newItem.className = 'item';
          newItem.textContent = `新内容${i + 1}`;
          content.appendChild(newItem);
        }
      }
    </script>
    
7. 拖放排序
  • 功能描述:允许用户通过拖放操作对列表项进行排序。
  • 实现思路
    • 使用 dragstartdragoverdrop 事件处理拖放操作。
    • drop 事件中更新列表项的顺序。
  • 代码示例
    <ul id="sortable-list">
      <li draggable="true">项目1</li>
      <li draggable="true">项目2</li>
      <li draggable="true">项目3</li>
    </ul>
    
    <style>
      ul {
        list-style-type: none;
        padding: 0;
      }
      li {
        background-color: #f1f1f1;
        margin: 5px 0;
        padding: 10px;
        cursor: move;
      }
    </style>
    
    <script>
      const sortableList = document.getElementById('sortable-list');
      const items = sortableList.querySelectorAll('li');
    
      items.forEach(item => {
        item.addEventListener('dragstart', dragStart);
        item.addEventListener('dragover', dragOver);
        item.addEventListener('drop', drop);
      });
    
      function dragStart(e) {
        e.dataTransfer.setData('text/plain', e.target.id);
        setTimeout(() => {
          e.target.classList.add('hide');
        }, 0);
      }
    
      function dragOver(e) {
        e.preventDefault();
        e.target.classList.add('over');
      }
    
      function drop(e) {
        e.preventDefault();
        const draggedItem = document.getElementById(e.dataTransfer.getData('text/plain'));
        const dropItem = e.target.closest('li');
        const parent = dropItem.parentNode;
    
        if (dropItem.classList.contains('over')) {
          parent.insertBefore(draggedItem, dropItem);
        } else {
          parent.appendChild(draggedItem);
        }
    
        items.forEach(item => {
          item.classList.remove('over', 'hide');
        });
      }
    </script>
    
8. 实时搜索过滤
  • 功能描述:在用户输入搜索关键词时,实时过滤列表中的项目。
  • 实现思路
    • 使用 input 事件监听搜索框的输入变化。
    • 根据输入的关键词过滤列表项,并更新显示。
  • 代码示例
    <input type="text" id="search" placeholder="搜索...">
    <ul id="list">
      <li>苹果</li>
      <li>香蕉</li>
      <li>橙子</li>
      <li>葡萄</li>
      <li>西瓜</li>
    </ul>
    
    <script>
      const searchInput = document.getElementById('search');
      const list = document.getElementById('list');
      const items = list.querySelectorAll('li');
    
      searchInput.addEventListener('input', filterList);
    
      function filterList() {
        const filterValue = searchInput.value.toLowerCase();
        items.forEach(item => {
          if (item.textContent.toLowerCase().includes(filterValue)) {
            item.style.display = 'block';
          } else {
            item.style.display = 'none';
          }
        });
      }
    </script>
    

所有的现代前端框架,不管是数据驱动还是事件驱动,底层都是基于原生的html和javascript进行封装和管理,所以了解最底层的原理,很重要。

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

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

相关文章

大模型,智能家居的春秋战国之交

智能家居&#xff0c;大家都不陌生。尽管苹果、谷歌、亚马逊等AI科技巨头&#xff0c;以及传统家电厂商都在积极进入这一领域&#xff0c;但发展了十多年之后&#xff0c;智能家居依然长期呈现出一种技术上人工智障、市场上四分五裂的局面。 究其原因&#xff0c;是此前传统家电…

【设计模式】结构型模式(四):组合模式、享元模式

《设计模式之结构型模式》系列&#xff0c;共包含以下文章&#xff1a; 结构型模式&#xff08;一&#xff09;&#xff1a;适配器模式、装饰器模式结构型模式&#xff08;二&#xff09;&#xff1a;代理模式结构型模式&#xff08;三&#xff09;&#xff1a;桥接模式、外观…

众测遇到的一些案列漏洞

文章中涉及的敏感信息均已做打码处理,文章仅做经验分享用途,切勿当真,未授权的攻击属于非法行为!文章中敏感信息均已做多层打码处理。传播、利用本文章所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,作者不为此承担任何责任,一旦造成后果请自行…

算法求解(C#)-- 寻找包含目标字符串的最短子串算法

1. 引言 在字符串处理中&#xff0c;我们经常需要从一个较长的字符串中找到包含特定目标字符串的最短子串。这个问题在文本搜索、基因序列分析等领域有着广泛的应用。本文将介绍一种高效的算法来解决这个问题。 2. 问题描述 给定一个源字符串 source 和一个目标字符串 targe…

ThingsBoard规则链节点:RPC Call Reply节点详解

引言 1. RPC Call Reply 节点简介 2. 节点配置 2.1 基本配置示例 3. 使用场景 3.1 设备控制 3.2 状态查询 3.3 命令执行 4. 实际项目中的应用 4.1 项目背景 4.2 项目需求 4.3 实现步骤 5. 总结 引言 ThingsBoard 是一个开源的物联网平台&#xff0c;提供了设备管理…

动态规划(简单多状态 dp 问题 1.按摩师 2.打家劫舍 II 3. 删除并获得点数 4.粉刷房子 5.买卖股票的最佳时机(全系列))

面试题 17.16. 按摩师213. 打家劫舍 II740. 删除并获得点数LCR 091. 粉刷房子 &#xff08;原&#xff1a;剑指 Offer II 091. 粉刷房子&#xff09;309. 买卖股票的最佳时机含冷冻期714. 买卖股票的最佳时机含手续费123. 买卖股票的最佳时机 III188. 买卖股票的最佳时机 IV 1.…

【VBA实战】用Excel制作排序算法动画续

为什么会产生用excel来制作排序算法动画的念头&#xff0c;参见【VBA实战】用Excel制作排序算法动画一文。这篇文章贴出我所制作的所有排序算法动画效果和源码&#xff0c;供大家参考。 冒泡排序&#xff1a; 插入排序&#xff1a; 选择排序&#xff1a; 快速排序&#xff1a;…

关于Markdown的一点疑问,为什么很多人说markdown比word好用?

markdown和word压根不是一类工具&#xff0c;不存在谁比谁好&#xff0c;只是应用场景不一样。 你写博客、写readme肯定得markdown&#xff0c;但写合同、写简历肯定word更合适。 markdown和word类似邮箱和微信的关系&#xff0c;这两者都可以通信&#xff0c;但微信因为功能…

区块链技术在数字版权管理中的应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 区块链技术在数字版权管理中的应用 区块链技术在数字版权管理中的应用 区块链技术在数字版权管理中的应用 引言 区块链技术概述 …

基于Spring Boot的在线装修管理系统的设计与实现,LW+源码+讲解

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差&#…

Ollama 0.4 发布!支持 Llama 3.2 Vision,实现多模态 RAG

“ 阅读本文大概需要5分钟。 前言 最近&#xff0c;Ollama 推出了 0.4 版本&#xff0c;其中最大的亮点就是支持了 Llama 3.2 Vision 模型&#xff0c;该模型具备多模态特性&#xff0c;也就是说能够理解图像并将图像纳入提示词中进行处理&#xff0c;让模型更智能地处理RAG中…

关于若依500验证码问题的求助

关于若依框架中验证码出现500错误的问题&#xff0c;这通常表示服务器内部错误。以下是一些可能的原因及解决方案&#xff1a; 一、配置文件问题 .env.production文件&#xff1a; 确保.env.production文件中的VUE_APP_BASE_API已经修改成服务器上的域名地址&#xff0c;而不…

使用HtmlAgilityPack+PuppeteerSharp+iText7抓取IdentityServer4帮助文档

需要学习IdentityServer4的用法&#xff0c;但是在IdentityServer4帮助文档网站&#xff08;参考文献1&#xff09;中没有找到下载离线文档的地方&#xff0c;准备使用HtmlAgilityPackPuppeteerSharpiText7将网站内容抓取生成离线PDF文档&#xff0c;便于本机学习、查看。   …

fpga开发原理图设计仿真分析

目录 原理图设计方法的流程 仿真分析 method1. 基于向量波形的仿真方法 method2. 基于testbench的仿真方法 在Quartus Prime开发环境下&#xff0c;进行EDA设计的基本流程如图所示。 包括五个主要任务: (1) 建立工程 (2) 设计输入 (3) 编译、综合与适配 (4) 引脚…

Node.js——fs模块-路径补充说明

1、相对路径&#xff1a; ./座右铭.txt 当前目录下的座右铭.txt座右铭.txt 等效于上面的写法../座右铭.txt 当前目录的上一级目录中的座右铭.txt 2、绝对路径 D&#xff1a;/Program File Windows系统下的绝对路径/usr/bin Linux系统…

从0开始搭建一个生产级SpringBoot2.0.X项目(十)SpringBoot 集成RabbitMQ

前言 最近有个想法想整理一个内容比较完整springboot项目初始化Demo。 SpringBoot集成RabbitMQ RabbitMQ中的一些角色&#xff1a; publisher&#xff1a;生产者 consumer&#xff1a;消费者 exchange个&#xff1a;交换机&#xff0c;负责消息路由 queue&#xff1a;队列…

比流计算资源效率最高提升 1000 倍,“增量计算”新模式能否颠覆数据分析?

作者 | 关涛 云器科技CTO 数据平台领域发展 20 年&#xff0c;逐渐成为每个企业的基础设施。作为一个进入“普惠期”的领域&#xff0c;当下的架构已经完美了吗&#xff0c;主要问题和挑战是什么&#xff1f;在 2023 年 AI 跃变式爆发的大背景下&#xff0c;数据平台又该如何演…

MySQL性能测试方案设计

在现代互联网系统中&#xff0c;数据库性能直接影响到整体应用的速度和用户体验。而MySQL作为广泛使用的关系型数据库&#xff0c;随着数据量和并发请求的增长&#xff0c;其性能问题也日益突出。今天我们将深入探讨如何设计一套高效的MySQL性能测试方案&#xff0c;帮助你精准…

彻底解决单片机BootLoader升级程序失败问题

文章目录 1、引言2、MicroBoot&#xff1a;优雅的解决升级问题问题1&#xff1a;bootloader 在跳转到app前没有清理干净存在的痕迹问题2&#xff1a; 需要 APP 传递信息给 Bootloader问题3&#xff1a; APP单独运行没有问题&#xff0c;通过Bootloader跳转到APP运行莫名死机问题…

Oracle OCP认证考试考点详解082系列17

题记&#xff1a; 本系列主要讲解Oracle OCP认证考试考点&#xff08;题目&#xff09;&#xff0c;适用于19C/21C,跟着学OCP考试必过。 81. 第81题&#xff1a; 题目 81.Examine these SOL statements which execute successfully Which two statements are true after exec…