nodejs 获取服务器文件夹里面图片,并前端进行幻灯展示

本文主要是介绍nodejs 获取服务器文件夹里面图片,并前端进行幻灯展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在实现一个特别个性的要求,就是读取服务器的文件夹里面的图片,然后前端进行轮播显示,因为客户要求的开发环境特殊一些,纯js的话又实现不了对本地文件夹的读取,所以这里用到了node.js下面我们来看怎么实现的

为了在Node.js中获取服务器文件夹内的图片并在前端进行幻灯展示,我们将采用与之前相似的策略,但这次我会提供一个更加直接的方式,通过后端API来传递图片URL列表给前端,而不是直接解析HTML。这样做的好处是提高了代码的可维护性和安全性。

第一步:设置Node.js服务器
首先,确保你已经安装了Node.jsnpm。接下来,创建一个新的项目目录,初始化npm,并安装Express框架和其它依赖:

mkdir slideshow-server
cd slideshow-server
npm init -y
npm install express multer cors

这里我们额外安装了multer用于处理文件上传(虽然本例中不涉及,但根据需求可能有用),以及cors用于处理跨域问题。

第二步:编写服务器代码
创建一个名为server.js的文件,用于启动Express服务器并提供图片列表API

const express = require('express');
const path = require('path');
const fs = require('fs');
const cors = require('cors');
const app = express();
const port = process.env.PORT || 3000;
const imgDirectory = 'public/images'; // 确保此目录存在且含有图片// 使用CORS中间件
app.use(cors());// 静态文件服务
app.use(express.static(path.join(__dirname, imgDirectory)));// 获取图片列表API
app.get('/api/images', (req, res) => {console.log(req.query.dirs,"传入的参数")const dir = req.query.dirs? req.query.dirs : '';fs.readdir(imgDirectory+'/'+dir, (err, files) => {if (err) {res.status(500).send('无法读取图片目录');} else {// 过滤出图片文件const images = files.filter(file => ['.jpg', '.jpeg', '.png', '.gif'].includes(path.extname(file).toLowerCase()));res.json(images.map(img => `/images/${dir}/${img}`)); // 返回图片URL列表}});
});app.listen(port, () => {console.log(`服务器运行在 http://localhost:${port}`);
});

上面的imgDirectory 指定了图片的根目录,但是我们有时候需要不同的目录层级,所以我默认的添加上了dirs这个参数,但是前提是目录在我们的imgDirectory 这个目录下面

第三步:前端代码
在项目根目录下创建一个public文件夹,用于存放前端资源。然后,在public目录下创建index.htmlscript.js文件。
这里需要注意的是public这个目录就是您的WEB根目录,目录可以随便建立自行修改即可

index.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>会议幻灯展示</title><!-- 引入Swiper CSS --><link rel="stylesheet" href="https://unpkg.com/swiper/swiper-bundle.min.css" /><style>body{padding:0;margin:0}/* 自定义样式 */.swiper-container {width: 100%;height: 100%;overflow: hidden;}.swiper-slide img {display: block;width: 100%;height: 100%;object-fit: cover;}</style>
</head>
<body><!-- Swiper容器 --><div class="swiper-container"><div class="swiper-wrapper"><!-- 图片将由JavaScript动态插入 --></div><div class="swiper-pagination"></div></div><!-- 引入Swiper JS 和 自定义脚本 --><script src="https://unpkg.com/swiper/swiper-bundle.min.js"></script><script src="script.js"></script>
</body>
</html>

script.js

document.addEventListener('DOMContentLoaded', async function() {var swiper = new Swiper('.swiper-container', {autoplay: {delay: 1000, // 单位毫秒,设置为5秒},loop: true,pagination: {el: '.swiper-pagination',dynamicBullets: true,},});try {//这里修改的是dirs=xxx 这里是要指定的目录必须真实存在的const response = await fetch('您服务器的地址:端口/api/images?dirs=a');const images = await response.json();console.log(images,"我是图片的地址");images.forEach(imgUrl => {const slide = document.createElement('div');slide.className = 'swiper-slide';const img = document.createElement('img');img.src = imgUrl;slide.appendChild(img);document.querySelector('.swiper-wrapper').appendChild(slide);});swiper.update();} catch (error) {console.error('获取图片列表失败:', error);}
});

整体来说最后实现的效果就是通过接口返回图片列表的json数据,然后前端动态插入进去,咱们这里用到了swiper您可以自行的修改样式实现更好看的更复杂的要求。

共同进步才是关键

这篇关于nodejs 获取服务器文件夹里面图片,并前端进行幻灯展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036595

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J