创建互动照片墙:HTML、CSS 和 JavaScript 实战

news2025/1/11 10:09:18

在这个数字化时代,照片已经成为我们生活中不可或缺的一部分。无论是记录重要时刻,还是分享日常生活,我们都离不开照片。今天,我们将一起探索如何使用 HTML、CSS 和 JavaScript 创建一个互动的照片墙程序,让您可以轻松展示和浏览您珍藏的照片。
“C:\Users\86182\Downloads\photo-wall-program.html”

结果如下

在这里插入图片描述
在这里插入图片描述

全部代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>照片墙程序</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            margin: 0;
            padding: 20px;
            background-color: #f0f0f0;
        }
        h1 {
            text-align: center;
        }
        #file-input {
            display: block;
            margin: 20px auto;
        }
        #view-toggle {
            display: block;
            margin: 20px auto;
            padding: 10px 20px;
            font-size: 16px;
            cursor: pointer;
        }
        #photo-container {
            max-width: 1000px;
            margin: 0 auto;
        }
        .tile-view {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
        }
        .tile-view img {
            width: 200px;
            height: 200px;
            object-fit: cover;
            margin: 10px;
            border: 2px solid #fff;
            box-shadow: 0 0 5px rgba(0,0,0,0.3);
        }
        .carousel-view {
            display: none;
            position: relative;
            width: 100%;
            height: 400px;
            overflow: hidden;
        }
        .carousel-view img {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            object-fit: contain;
            opacity: 0;
            transition: opacity 0.5s ease-in-out;
        }
        .carousel-view img.active {
            opacity: 1;
        }
        .carousel-button {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background-color: rgba(0,0,0,0.5);
            color: #fff;
            border: none;
            padding: 10px;
            cursor: pointer;
            font-size: 18px;
        }
        #prev-button {
            left: 10px;
        }
        #next-button {
            right: 10px;
        }
    </style>
</head>
<body>
    <h1>照片墙程序</h1>
    <input type="file" id="file-input" multiple accept="image/*">
    <button id="view-toggle">切换视图</button>
    <div id="photo-container">
        <div class="tile-view"></div>
        <div class="carousel-view">
            <button id="prev-button" class="carousel-button">&#10094;</button>
            <button id="next-button" class="carousel-button">&#10095;</button>
        </div>
    </div>

    <script>
        const fileInput = document.getElementById('file-input');
        const viewToggle = document.getElementById('view-toggle');
        const photoContainer = document.getElementById('photo-container');
        const tileView = photoContainer.querySelector('.tile-view');
        const carouselView = photoContainer.querySelector('.carousel-view');
        const prevButton = document.getElementById('prev-button');
        const nextButton = document.getElementById('next-button');

        let currentView = 'tile';
        let currentIndex = 0;
        let photos = [];

        fileInput.addEventListener('change', handleFileSelect);
        viewToggle.addEventListener('click', toggleView);
        prevButton.addEventListener('click', showPreviousPhoto);
        nextButton.addEventListener('click', showNextPhoto);

        function handleFileSelect(event) {
            const files = event.target.files;
            photos = [];
            tileView.innerHTML = '';
            carouselView.innerHTML = '';
            carouselView.appendChild(prevButton);
            carouselView.appendChild(nextButton);

            for (let i = 0; i < files.length; i++) {
                const file = files[i];
                if (file.type.startsWith('image/')) {
                    const reader = new FileReader();
                    reader.onload = function(e) {
                        const img = document.createElement('img');
                        img.src = e.target.result;
                        tileView.appendChild(img);
                        carouselView.insertBefore(img.cloneNode(), nextButton);
                        photos.push(img);
                    }
                    reader.readAsDataURL(file);
                }
            }
        }

        function toggleView() {
            if (currentView === 'tile') {
                tileView.style.display = 'none';
                carouselView.style.display = 'block';
                currentView = 'carousel';
                showPhoto(currentIndex);
            } else {
                tileView.style.display = 'flex';
                carouselView.style.display = 'none';
                currentView = 'tile';
            }
        }

        function showPhoto(index) {
            const carouselPhotos = carouselView.querySelectorAll('img');
            carouselPhotos.forEach(photo => photo.classList.remove('active'));
            carouselPhotos[index].classList.add('active');
        }

        function showNextPhoto() {
            currentIndex = (currentIndex + 1) % photos.length;
            showPhoto(currentIndex);
        }

        function showPreviousPhoto() {
            currentIndex = (currentIndex - 1 + photos.length) % photos.length;
            showPhoto(currentIndex);
        }
    </script>
</body>
</html>

项目概述

我们的照片墙程序具有以下特点:

  1. 允许用户选择多张照片
  2. 以平铺方式显示所有照片
  3. 提供轮播视图,可以逐张浏览照片
  4. 响应式设计,适应不同屏幕尺寸

听起来很有趣,对吧?让我们一步步来看看如何实现这个程序。

HTML 结构

首先,我们需要创建基本的 HTML 结构:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>照片墙程序</title>
    <!-- CSS 样式将在这里 -->
</head>
<body>
    <h1>照片墙程序</h1>
    <input type="file" id="file-input" multiple accept="image/*">
    <button id="view-toggle">切换视图</button>
    <div id="photo-container">
        <div class="tile-view"></div>
        <div class="carousel-view">
            <button id="prev-button" class="carousel-button">&#10094;</button>
            <button id="next-button" class="carousel-button">&#10095;</button>
        </div>
    </div>
    <!-- JavaScript 代码将在这里 -->
</body>
</html>

这个结构包括了文件输入、视图切换按钮和两个不同的视图容器。

CSS 样式

接下来,我们需要添加一些 CSS 样式来美化我们的照片墙:

body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 20px;
    background-color: #f0f0f0;
}

/* 其他样式... */

.carousel-view img.active {
    opacity: 1;
}

这些样式为我们的照片墙提供了美观的布局和平滑的过渡效果。

JavaScript 功能

最后,我们需要添加 JavaScript 来使我们的照片墙具有交互性:

const fileInput = document.getElementById('file-input');
const viewToggle = document.getElementById('view-toggle');
const photoContainer = document.getElementById('photo-container');
// 其他变量声明...

fileInput.addEventListener('change', handleFileSelect);
viewToggle.addEventListener('click', toggleView);
// 其他事件监听器...

function handleFileSelect(event) {
    // 处理文件选择逻辑
}

function toggleView() {
    // 切换视图逻辑
}

// 其他函数...

这些 JavaScript 函数处理文件选择、视图切换和照片导航等功能。

结语

通过这个项目,我们不仅创建了一个有趣的照片墙程序,还学习了如何结合 HTML、CSS 和 JavaScript 来创建交互式 Web 应用。这个程序可以作为一个起点,您可以在此基础上添加更多功能,比如照片编辑、分享功能等。

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

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

相关文章

四步构建App跨渠道归因分析方法

通常来讲&#xff0c;在互联网场景中&#xff0c;最简单也最常用的App归因模型就是基于最后一次点击来源进行归因转化&#xff0c;因为越靠近决策环节的时刻通常影响就越大。 不过有机构对营销测量的研究发现&#xff0c;只有11%的营销人员对他们的归因模型的准确性感到“非常…

大语言模型(LLM)快速理解

自2022年&#xff0c;ChatGPT发布之后&#xff0c;大语言模型&#xff08;Large Language Model&#xff09;&#xff0c;简称LLM掀起了一波狂潮。作为学习理解LLM的开始&#xff0c;先来整体理解一下大语言模型。 一、发展历史 大语言模型的发展历史可以追溯到早期的语言模型…

视频孪生:如何有效利用智慧机房里的视频监控系统?

机房是存储设备和数据的重要场所。常见的机房安全隐患有电源不稳定、设备温度异常、空调及新风系统故障、机房漏水等&#xff0c;因此需要管理人员全天轮班值守巡检。传统机房运维工作繁琐且效率低下&#xff0c;对监控设备的利用率不高&#xff0c;而视频孪生技术能很好地解决…

02 pip指令的使用

pip 是一个现代的&#xff0c;通用的 Python 包管理工具 。提供了对Python 包的查找、下载、安装、卸载的功能。 1. 在安装好的python环境下&#xff0c;进入以下目录可以查看到pip命令。 同样在windows命令窗口进行测试&#xff0c;pip命令是否可用。WindowsR键&#xff0c;使…

“职场中,不要和上司作对”,真的很重要吗?你认同这句话吗?

在职场上&#xff0c;领导对下属的期望永远都只有两个字&#xff0c;不是忠诚&#xff0c;也不是能力&#xff0c;而是省心。 领导对下属的要求就是别让我操心。 在职场中&#xff0c;通常面临的首要问题就是如何与领导相处。 把职场中的前辈当作老师来尊重&#xff0c;你尊…

基础复习(多线程)

线程创建方式 1.继承Thread类 2.实现Runable接口 3.Callable接口实现有返回值的线程 &#xff08;1&#xff09;第一种 提供了一个类叫做Thread&#xff0c;此类的对象用来表示线程。创建线程并执行线程的步骤如下 1.定义一个子类继承Thread类&#xff0c;并重写run方法 2.创建…

无密码sudo

文件路径&#xff1a;/etc/sudoers 修改sudoers文件 进去root 权限&#xff1a;sudo su 加入sudoers 写权限&#xff1a;chmod w sudoers 修改sudoers文件&#xff1a;vim sudoers 根据下面图片修改 wq退出编辑

华为LTC流程体系详解

LTC&#xff0c;全称Lead to Cash&#xff0c;中文翻译为从线索到现金&#xff0c;是一种企业运营管理思想&#xff0c;也是一个集成的业务流程。它涵盖了企业从接触客户到收到客户回款的整个流程&#xff0c;通过科学化管理&#xff0c;实现更高效地将线索客户转化为付费客户。…

学习web前端三大件之HTML篇

HTML的全称为超文本标记语言&#xff0c;是一种标记语言。它包括一系列标签&#xff0c;通过这些标签可以将网络上的文档格式统一&#xff0c;使分散的Internet资源连接为一个逻辑整体。HTML文本是由HTML命令组成的描述性文本&#xff0c;HTML命令可以说明文字&#xff0c;图形…

每日一面系列之美团面试拷打:ConcurrentHashMap 为何不能插入 null?HashMap 为何可以

ConcurrentHashMap 为什么 key 和 value 不能为 null&#xff1f; ConcurrentHashMap 的 key 和 value 不能为 null 主要是为了避免二义性。null 是一个特殊的值&#xff0c;表示没有对象或没有引用。如果你用 null 作为键&#xff0c;那么你就无法区分这个键是否存在于 Concu…

1. shiro的基本使用

一、现存问题 1. 认证&#xff08;登录&#xff09;&#xff1a;认证操作流程都差不多&#xff0c;但是每次都需要手动的基于业务代码去实现&#xff0c;很麻烦&#xff01; 2. 授权&#xff1a;如果权限控制粒度比较粗&#xff0c;可以自身去实现&#xff0c;但是如果控制粒度…

fastadmin插件市场暂不可用,是否切换到本地插件

今天调试时需要安装一个富文本插件&#xff0c;结果在插件管理模块提示如下错误&#xff1a; 经过参考网上资料&#xff0c;最终解决方案&#xff1a; 修改backend/config目录下&#xff0c;fastadmin.php 中代码&#xff1a; //API接口地址 api_url > https://api.iuok.c…

canopenfestival生成字典使用的总结

添加地图变量 1、不带索引计数的 子索引的值类型固定 2、带索引计数 子索引的值类型固定,子索引名字不可更改 3、带索引计数 子索引的值类型不固定&#xff0c;子索引名字可更改

HarmonyOS多目标产物构建最佳实践

背景 在Android或iOS开发时经常会有打“马甲”包的场景&#xff0c;就是一套代码打出不同主题的包&#xff0c;一个公司的产品可能针对不同用户提供不同的应用&#xff0c;比如抖音有国内版也有国外版&#xff0c;滴滴有个人版还有企业版&#xff0c;同样的在鸿蒙平台也有类似…

百元内性价比最高的随身WiFi!格行随身WiFiVS京东云VS先机随身WiFi真实测评!哪个随身WiFi网速最快?口碑最好的随身WiFi!

随身WiFi是大家都熟知的便携式上网设备不管是出差旅行✈还是学生党租房都非常合适。但是现在市面上的随身WiFi产品良莠不齐‼价格也千差万别&#xff01;今天给大家挑选三款百元内性价比最高的随身WiFi出期测评看下哪款最好用——先机、格行和京东云的详细测评&#xff0c;帮助…

深度学习6--深度神经网络

1.VGG网络 在图像分 类这个领域中&#xff0c;深度卷积网络一般由卷积模块和全连接模块组成。 (1)卷积模块包含卷积层、池化层、Dropout 层、激活函数等。普遍认为&#xff0c;卷积模块是对 图像特征的提取&#xff0c;并不是对图像进行分类。 (2)全连接模块跟在卷积模块之后&…

Selenium安装WebDriver:ChromeDriver谷歌浏览器驱动下载安装与使用最新版116/117/118/119/120/121/122/123

Selenium安装WebDriver&#xff1a;ChromeDriver谷歌浏览器驱动下载安装与使用最新版116/117/118/119/120/121/122/123 文章目录 Selenium安装WebDriver&#xff1a;ChromeDriver谷歌浏览器驱动下载安装与使用最新版116/117/118/119/120/121/122/1230. 背景1. 确定Chrome版本2.…

大模型系统和应用——自然语言处理大模型基础_大模型和自然语言处理的相互影响

引言 最近在公众号中了解到了刘知远团队退出的视频课程《大模型交叉研讨课》&#xff0c;看了目录觉得不错&#xff0c;因此拜读一下。 观看地址&#xff1a; https://www.bilibili.com/video/BV1UG411p7zv 目录&#xff1a; 自然语言处理&大模型基础神经网络基础Transf…

新款奔驰G350升级动态通风按摩座椅有哪些功能

奔驰大 G350 升级通风按摩座椅的作用主要包括以下方面&#xff1a; 通风座椅的作用&#xff1a; • 改善空气流通&#xff1a;在炎热天气下&#xff0c;即使车内空调温度设定较低&#xff0c;乘客坐在座椅上时&#xff0c;身体与椅面紧密接触的部分仍可能会感到闷热&#xff…

人大高瓴发布Think-on-Graph 2.0,基于知识图的大模型推理再升级!

经常参加高考的朋友可能会体会到&#xff0c;比起死记硬背知识点&#xff0c;将知识整理成脉络往往会获得事半功倍的效果。其实对于大模型来说也是如此&#xff0c;哪怕被允许“开卷作答”&#xff0c;即通过检索增强&#xff08;Retrieval-augmented generation&#xff0c;RA…