JS 如何动态获取本地文件夹中的所有图片

1、require.context

最近在帮师哥做一个简单的数据和图片展示的项目,其中有一个需求是要在页面上显示出该项目某一文件夹下的所有图片,图片的数目和文件名不确定,只知道图片存放的目录。

一开始想到的思路是在页面上设置输入框,输入图片的数目和文件名,但是这样不够方便,想优化一下,所以在网上看到了这个 require.context() 方法,下面先对其做一个简单的介绍。

require.context(directory, useSubdirectories, regExp)

//参数:
//directory: 说明需要检索的目录
//useSubdirectories: 是否检索子目录
//regExp: 匹配文件的正则表达式, 一般是文件名

//返回值:require.context返回一个require 函数,此函数可以接收一个参数
function webpackContext(req) {
    return __webpack_require__(webpackContextResolve(req))
};

//函数有三个属性:resolve 、keys、id
//resolve: 是一个函数,他返回的是被解析模块的id ,接受一个参数request。
//keys: 也是一个函数,他返回的是一个数组,该数组是由所有可能被上下文模块解析的请求对象组成
//id:上下文模块的id

2、具体实现步骤

首先我们需要知道图片的路径,图片的路径是相对路径也可以是绝对路径;其次我们需要获取到图片的文件名

let requireModule = require.context(
    "../assets/images",
    false,
    /\.png$/
);

let imagesNameArr = [];
for (var i = 0; i < requireModule.keys().length; i++) {
    imagesNameArr .push(requireModule.keys()[i].substr(2, requireModule.keys()[i].length));
}

然后把对应的文件名和路径拼接起来:

currentImageUrl = require("…/assets/images" + imagesNameArr[i]);
在 HTML 无法直接获取本地文件夹下的文件列表,因为 HTML 运行在浏览器,受到了安全限制,无法直接访问本地文件系统。但是,你可以使用 JavaScript 通过 AJAX 或 Fetch API 向服务器请求文件列表,然后在 HTML 显示。 以下是一个使用 JavaScript 和 HTML 的示例,可以请求服务器上指定文件夹的所有图片文件,并在网页上显示这些图片: ```html <!DOCTYPE html> <html> <head> <title>Show Images</title> </head> <body> <div id="image-container"></div> <script> // 指定要请求的文件夹路径 var folder_path = "/path/to/folder"; // 发送 AJAX 请求,获取文件列表 var xhr = new XMLHttpRequest(); xhr.open("GET", "/get-files.php?path=" + encodeURIComponent(folder_path)); xhr.onload = function() { if (xhr.status === 200) { var files = JSON.parse(xhr.responseText); displayImages(files); } else { console.log("Error retrieving image files: " + xhr.statusText); } }; xhr.send(); // 在网页上显示图片 function displayImages(files) { var container = document.getElementById("image-container"); for (var i=0; i<files.length; i++) { if (files[i].endsWith(".jpg") || files[i].endsWith(".jpeg") || files[i].endsWith(".png")) { var img = document.createElement("img"); img.src = files[i]; container.appendChild(img); } } } </script> </body> </html> ``` 这个 HTML 页面,我们先使用 JavaScript 发送 AJAX 请求,请求服务器上指定文件夹下的所有文件列表。服务器端的代码可以使用 PHP、Python 等语言实现,这里使用 PHP 代码示例: ```php <?php $path = $_GET["path"]; $files = array(); if ($handle = opendir($path)) { while (false !== ($entry = readdir($handle))) { if ($entry != "." && $entry != "..") { $files[] = $path . "/" . $entry; } } closedir($handle); } echo json_encode($files); ?> ``` 这个 PHP 脚本会读取指定文件夹下的所有文件,并将文件列表以 JSON 格式返回给 JavaScript。最后,JavaScript 解析返回的 JSON 数据,筛选出图片文件,并将它们显示在 HTML 页面
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值