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实现对excel文件进行加密

《利用python实现对excel文件进行加密》由于文件内容的私密性,需要对Excel文件进行加密,保护文件以免给第三方看到,本文将以Python语言为例,和大家讲讲如何对Excel文件进行加密,感兴... 目录前言方法一:使用pywin32库(仅限Windows)方法二:使用msoffcrypto-too

SpringBoot整合mybatisPlus实现批量插入并获取ID详解

《SpringBoot整合mybatisPlus实现批量插入并获取ID详解》这篇文章主要为大家详细介绍了SpringBoot如何整合mybatisPlus实现批量插入并获取ID,文中的示例代码讲解详细... 目录【1】saveBATch(一万条数据总耗时:2478ms)【2】集合方式foreach(一万条数

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py