JavaScript网页设计案例:互动式简历网站

JavaScript网页设计案例:互动式简历网站

在现代网页设计中,JavaScript 是实现交互和动态效果的关键技术。本文将通过一个完整的案例,展示如何使用 JavaScript 构建一个交互式的个人简历网页。本文不仅会涵盖 HTML 和 CSS 的使用,还会详细介绍如何利用 JavaScript 实现丰富的用户交互功能,如导航切换、动态加载内容、滚动动画等。
在这里插入图片描述

一、项目概述

本项目是一个互动式简历网站,它包含以下功能:

  1. 动态导航菜单:点击导航时页面会平滑滚动到对应的部分。
  2. 动态内容加载:点击按钮后,展示更多关于个人信息的详细内容。
  3. 动画效果:页面加载时内容淡入、滚动时元素渐入,增加用户体验。
    在这里插入图片描述

二、项目结构

首先,我们需要定义项目的基本结构。为了简洁,项目文件可以包括:

  • index.html:主页面文件,定义网页的结构。
  • style.css:CSS 文件,包含页面的样式和布局。
  • script.js:JavaScript 文件,实现交互效果。
    在这里插入图片描述

1. HTML 页面结构

以下是 HTML 页面结构的示例,包括头部、个人简介、技能展示、项目经验、联系信息等常见的简历部分。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Interactive Resume</title><link rel="stylesheet" href="style.css">
</head>
<body><!-- 导航栏 --><nav id="navbar"><ul><li><a href="#home">Home</a></li><li><a href="#about">About</a></li><li><a href="#skills">Skills</a></li><li><a href="#projects">Projects</a></li><li><a href="#contact">Contact</a></li></ul></nav><!-- 首页部分 --><section id="home"><h1>Welcome to My Resume</h1><p>Hi, I'm a web developer with a passion for creating interactive web experiences.</p></section><!-- 关于我部分 --><section id="about"><h2>About Me</h2><p>I'm a web developer with over 5 years of experience...</p><button id="more-info-btn">More Info</button><div id="more-info" style="display: none;"><p>Here is some additional information about my background and experience...</p></div></section><!-- 技能部分 --><section id="skills"><h2>Skills</h2><ul><li>JavaScript</li><li>HTML & CSS</li><li>React.js</li><li>Node.js</li></ul></section><!-- 项目部分 --><section id="projects"><h2>Projects</h2><div class="project"><h3>Project 1: Interactive Webpage</h3><p>Built a dynamic webpage using JavaScript, HTML, and CSS...</p></div><div class="project"><h3>Project 2: E-commerce Site</h3><p>Developed a fully functional e-commerce site using React and Node.js...</p></div></section><!-- 联系方式部分 --><section id="contact"><h2>Contact Me</h2><p>Email: example@example.com</p><p>Phone: 123-456-7890</p></section><script src="script.js"></script>
</body>
</html>

2. CSS 样式

接下来,我们来定义页面的样式。我们会使用基础的 CSS 来定义页面的布局,并为导航栏、各个部分添加样式。

/* 全局样式 */
body {font-family: Arial, sans-serif;line-height: 1.6;margin: 0;padding: 0;background-color: #f4f4f4;
}/* 导航栏样式 */
#navbar {background-color: #333;color: #fff;padding: 1rem;position: fixed;top: 0;width: 100%;display: flex;justify-content: center;z-index: 1000;
}#navbar ul {list-style: none;margin: 0;padding: 0;display: flex;
}#navbar ul li {margin: 0 15px;
}#navbar ul li a {color: #fff;text-decoration: none;padding: 10px 15px;display: inline-block;
}#navbar ul li a:hover {background-color: #555;border-radius: 5px;
}/* 部分样式 */
section {padding: 60px 20px;margin-top: 60px;
}#home {background-color: #00aaff;color: #fff;text-align: center;
}#about, #skills, #projects, #contact {background-color: #fff;margin: 20px 0;
}button {padding: 10px 20px;background-color: #333;color: white;border: none;cursor: pointer;border-radius: 5px;
}button:hover {background-color: #555;
}/* 动画 */
.fade-in {opacity: 0;transition: opacity 1s ease-in;
}.fade-in.show {opacity: 1;
}

3. JavaScript 动态效果

为了实现交互效果,我们将使用 JavaScript 来控制页面滚动、动态加载内容以及添加一些简单的动画效果。

// script.js// Smooth scroll for navigation links
document.querySelectorAll('#navbar a').forEach(link => {link.addEventListener('click', function(e) {e.preventDefault();const targetId = this.getAttribute('href').substring(1);const targetSection = document.getElementById(targetId);window.scrollTo({top: targetSection.offsetTop - 50, // Subtract height of navbarbehavior: 'smooth'});});
});// Toggle additional information in About section
const moreInfoBtn = document.getElementById('more-info-btn');
const moreInfoDiv = document.getElementById('more-info');moreInfoBtn.addEventListener('click', function() {if (moreInfoDiv.style.display === 'none') {moreInfoDiv.style.display = 'block';} else {moreInfoDiv.style.display = 'none';}
});// Fade-in effect when sections come into view
const sections = document.querySelectorAll('section');
const options = {threshold: 0.5
};const observer = new IntersectionObserver((entries, observer) => {entries.forEach(entry => {if (entry.isIntersecting) {entry.target.classList.add('show');}});
}, options);sections.forEach(section => {section.classList.add('fade-in');observer.observe(section);
});

三、项目讲解

1. 平滑滚动

在这个项目中,我们为导航栏中的链接添加了平滑滚动效果。通过 JavaScript 的 window.scrollTo 方法,我们可以控制页面在点击导航链接时平滑地滚动到对应的部分。此功能可以增强用户的导航体验,特别是在多段内容的页面中。

2. 动态内容加载

“关于我”部分中实现了动态内容加载的效果。通过控制 display 样式,我们可以在用户点击按钮时显示或隐藏额外的信息。这种功能在实际项目中非常常见,尤其是在展示简历或文章详情时,用户可以根据需要查看更多的内容。

3. 动画效果

为了增强网页的视觉体验,使用了 IntersectionObserver API 来检测用户何时滚动到页面的某个部分,并为这些部分添加渐入效果。这种效果可以让页面看起来更加动感,提升用户的使用体验。
在这里插入图片描述

四、总结

通过本案例,我们展示了如何使用 JavaScript、HTML 和 CSS 设计一个简洁而功能丰富的互动式简历网页。在这个过程中,我们实现了平滑滚动、动态加载内容以及滚动动画等常见的 Web 交互功能。

这些技术不仅适用于简历网站,在任何需要用户交互的 Web 项目中都可以使用。希望通过这篇博客,你可以学习到如何构建动态、互动的网页,并在实际项目中灵活运用。
在这里插入图片描述

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

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

相关文章

android和ios双端应用性能的测试工具

1.工具介绍 基于日常工作的需要&#xff0c;开发了一款新的android和ios端应用性能测试工具&#xff0c;本工具在数据测试方面与所流行的工具没有区别。欢迎下载使用体验。 本工具为筋斗云&#xff0c;工具说明 本工具无侵入&#xff0c;不需要root&#xff0c;低延迟…

(十七)、Mac 安装k8s

文章目录 1、Enable Kubernetes2、查看k8s运行状态3、启用 kubernetes-dashboard3.1、如果启动成功&#xff0c;可以在浏览器访问3.2、如果没有跳转&#xff0c;需要单独安装 kubernetes-dashboard3.2.1、方式一&#xff1a;一步到位3.2.2、方式二&#xff1a;逐步进行 1、Enab…

如何恢复被删除的 GitLab 项目?

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料&#xff1a; 极狐GitLab 官网极狐…

time命令:轻松测量Linux命令执行时间!

一、命令简介 用途&#xff1a; 用于测量 Linux 命令执行的时间&#xff0c;包括实际时间、用户 CPU 时间和系统 CPU 时间。刚开始以为是用来“看现在几点钟”的 &#x1f972;。标签&#xff1a; 实用工具&#xff0c;性能分析。 ‍ 二、命令参数 2.1 命令格式 time [选项…

进程的那些事--实现shell

目录 前言 一、预备知识 二、实现步骤 1.思路 2.实现 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 学习的本质就是变现 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、预备知识 char * fgets ( char * str, i…

讯飞星火编排创建智能体学习(二)决策节点

目录 概述 决策节点 文生图节点 连接节点 测试结果 概述 在上一篇博文讯飞星火编排创建智能体学习&#xff08;一&#xff09;最简单的智能体构建-CSDN博客&#xff0c;我介绍了编排创作智能体&#xff0c;这篇来介绍一下“决策节点”。 决策节点 在编排创作智能体中&…

MQTT.fx 1.7.1使用说明篇(OneNET-MQTT-API调试)

&#xff08;代码完美实现&#xff09;stm32 新版 onenet mqtt物联网(保姆级教程) &#xff08;代码完美实现&#xff09;stm32 新版 onenet mqtt物联网(保姆级教程)https://blog.csdn.net/Wang2869902214/article/details/142501323 MQTT.fx 1.7.1使用教程 下载地址 MQ…

巧用switch-case消除条件判断

shigen坚持更新文章的博客写手&#xff0c;记录成长&#xff0c;分享认知&#xff0c;留住感动。个人IP&#xff1a;shigen 在之前的文章中&#xff0c;我们有提交消除if-else代码的方法&#xff1a; 结合HashMap与Java 8的Function和Optional消除ifelse判断巧用枚举消除逻辑判…

一文上手SpringSecuirty【六】

自定义认证流程完成之后,前端收到了后端生成的token,那么在之后的所有请求当前,都必须携带token.作为服务器来说,得验证这个token,是否合法. 一、验证token是否合法 1.1 OncePerRequestFilter过滤器 OncePerRequestFilter是 Spring 框架中的一个过滤器&#xff0c;用于确保在…

抖音支付回调验签 go 版本

序言 最近在做抖音小程序支付&#xff0c;由于抖音开放平台的文档写的较为简陋&#xff0c;让人踩了不少坑&#xff0c;在这里整理一下做小程序支付的整个过程&#xff0c;以通用交易系统为例子。 准备条件 1&#xff09;申请小程序&#xff0c;开通支付功能 这里需要明确你小…

鸿蒙开发(NEXT/API 12)【硬件(传感器开发)】传感器服务

使用场景 Sensor Service Kit&#xff08;传感器服务&#xff09;使应用程序能够从传感器获取原始数据&#xff0c;并提供振感控制能力。 Sensor&#xff08;传感器&#xff09;模块是应用访问底层硬件传感器的一种设备抽象概念。开发者可根据传感器提供的相关接口订阅传感器…

Mitsuba 渲染基础

Mitsuba 渲染基础 0. Abstract1. 安装 Mitsuba21.1 下载 Mitsuba2 源码1.2 选择后端 (variants)1.3 编译 2. [Mitsuba2PointCloudRenderer](https://github.com/tolgabirdal/Mitsuba2PointCloudRenderer)2.1 Mitsuba2 渲染 XML2.2 Scene 场景的 XML 文件格式2.2.1 chair.npy to…

Comfyui 学习笔记2

在潜空间放大&#xff0c;三种方法&#xff1a;NNLatentUpscale、Upscale Latent、Upscale Latent&#xff0c;其中只有NNLatentUpscale自带模型优化&#xff0c;其他两种需要KSample重新绘画&#xff0c;NNLatentUpscale后也可以接KSmaple。 像素空间放大&#xff0c;同理&am…

大模型推理任务Nvidia GPU选型指南

大型语言模型 (LLM)&#xff08;如 GPT-4、BERT 和其他基于 Transformer 的模型&#xff09;彻底改变了 AI 格局。这些模型需要大量计算资源来进行训练和推理。选择合适的 GPU 进行 LLM 推理可以极大地影响性能、成本效益和可扩展性。 在本文中&#xff0c;我们将探索最适合 L…

Spring的热部署工具和数据库密码加盐操作

1.布置热部署 引言&#xff1a;在程序运行起来后&#xff0c;如果我们对代码进行了修改&#xff0c;需要重新测试修改后的程序&#xff0c;就得重新启动程序&#xff0c;这样很麻烦。于是引入热部署之后&#xff0c;我们就不需要重新启动程序&#xff0c;会自动更正。 1.配置po…

牛顿迭代法求解x 的平方根

牛顿迭代法是一种可以用来快速求解函数零点的方法。 为了叙述方便&#xff0c;我们用 C C C表示待求出平方根的那个整数。显然&#xff0c; C C C的平方根就是函数 f ( x ) x c − C f(x)x^c-C f(x)xc−C 的零点。 牛顿迭代法的本质是借助泰勒级数&#xff0c;从初始值开始快…

前端大模型入门:使用Transformers.js手搓纯网页版RAG(二)- qwen1.5-0.5B - 纯前端不调接口

书接上文&#xff0c;本文完了RAG的后半部分&#xff0c;在浏览器运行qwen1.5-0.5B实现了增强搜索全流程。但受限于浏览器和模型性能&#xff0c;仅适合于研究、离线和高隐私场景&#xff0c;但对前端小伙伴来说大模型也不是那么遥不可及了&#xff0c;附带全部代码&#xff0c…

【深度学习】(5)--搭建卷积神经网络

文章目录 搭建卷积神经网络一、数据预处理1. 下载数据集2. 创建DataLoader&#xff08;数据加载器&#xff09; 二、搭建神经网络三、训练数据四、优化模型 总结 搭建卷积神经网络 一、数据预处理 1. 下载数据集 在PyTorch中&#xff0c;有许多封装了很多与图像相关的模型、…

vue3 通过 axios + jsonp 实现根据公网 ip, 查询天气信息

前提 安装 axios 的 jsonp 适配器。 pnpm install pingtou/axios-jsonp 简单使用说明&#xff1a;当与后端约定的请求 callback 参数名称不为为 callback 时&#xff0c;可修改。一般无需添加。 1. 获取当前电脑 ip 和城市信息 请求地址&#xff1a; https://whois.pconl…

Linux之我不会

一、常用命令 1.系统管理 1.1 systemctl start | stop | restart | status 服务名 案例实操 1 查看防火墙状态 systemctl status firewalld2 停止防火墙服务 systemctl stop firewalld3 启动防火墙服务 systemctl start firewalld4 重启防火墙服务 systemctl restart f…