Javascript 如何在我的HTML中获取图像文件的名称

Javascript 如何在我的HTML中获取图像文件的名称,javascript,html,image,onload,Javascript,Html,Image,Onload,我正在尝试在我的HTML中获取上载图像文件的名称。我尝试在https://stackoverflow.com/questions/1804745/get-the-filename-of-a-fileupload-in-a-document-through-javascript和https://stackoverflow.com/questions/14359913/how-to-get-value-of-img-tag。他们帮了我一点忙,但还不够充分。 所以,我的img标签看起来就像这样: &

我正在尝试在我的HTML中获取上载图像文件的名称。我尝试在
https://stackoverflow.com/questions/1804745/get-the-filename-of-a-fileupload-in-a-document-through-javascript
https://stackoverflow.com/questions/14359913/how-to-get-value-of-img-tag
。他们帮了我一点忙,但还不够充分。 所以,我的img标签看起来就像这样:

 <img id="imgPreview"  src="Anzeige%20erstellen-Dateien/default_offers_photo-edd8e5ff2d549a9fa1a898b23119931ebd0e745.png" width="500px" height="360px" style="padding-left:15px;" onload="imgListener()"/>
function imgListener(imgFile){
    console.log(document.getElementById('imgPreview').src)
}
当我运行这段代码时,它会显示一个包含数千个字母和数字的疯狂长文本。那肯定不是我想要的。 控制台输出看起来像这样,但只长了很多:



我使用的是
src
而不是
value
。我猜这就是原因。但我不知道如何访问这些信息,我现在知道,
value
不用于img标签。如何才能获得文件名?

尝试以下方法:

 <img id="imgPreview"  src="Anzeige%20erstellen-Dateien/default_offers_photo-edd8e5ff2d549a9fa1a898b23119931ebd0e745.png" width="500px" height="360px" style="padding-left:15px;" onload="imgListener()"/>
function imgListener(imgFile){
    console.log(document.getElementById('imgPreview').src)
}
函数imgListener(imgFile){
const el=document.getElementById('imgPreview');
const tmp=document.createElement(“div”);
tmp.appendChild(el);
console.log(tmp.getElementsByTagName(“img”)[0].getAttribute(“src”).split(“/”).reverse()[0])
}

这是可行的,只需在本地文件上进行测试并给出正确的名称即可。只需熟悉img对象上的对象属性即可

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
    </head>
    <img id="imgPreview"  src="Anzeige%20erstellen-Dateien/default_offers_photo-edd8e5ff2d549a9fa1a898b23119931ebd0e745.png" width="500px" height="360px" style="padding-left:15px;" onload="imgListener()"/>
    <script>
        function imgListener(imgFile){
            console.log(document.getElementById('imgPreview').attributes[1].textContent);
        }
    </script>
</html>

函数imgListener(imgFile){
log(document.getElementById('imgPreview').attributes[1].textContent);
}
让我知道这是否有效

另类

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
    </head>
    <img id="imgPreview"  src="Anzeige%20erstellen-Dateien/default_offers_photo-edd8e5ff2d549a9fa1a898b23119931ebd0e745.png" width="500px" height="360px" style="padding-left:15px;" onload="imgListener()"/>
    <script>
        function imgListener(imgFile){
            let name = document.getElementById('imgPreview').attributes[1].textContent;
            let nameSplit = name.split("/");
            let lastSplit = nameSplit[nameSplit.length - 1];
            console.log(lastSplit);
        }
    </script>
</html>

函数imgListener(imgFile){
让name=document.getElementById('imgPreview')。属性[1]。文本内容;
让nameSplit=name.split(“/”);
设lastSplit=nameSplit[nameSplit.length-1];
console.log(lastplit);
}

use
var img=document.getElementById('imgPreview');log(img.src)
获取图像src,这是图像源;它是一个数据URL,将整个图像编码为一个字符串,可以用来代替任何URL。无论脚本如何设置图像的源,它都使用一个数据URL。(试试看:将你得到的整个数据URL复制到浏览器的地址栏中,然后按enter键。你会看到图片。)你的建议和我上面所做的不一样吗?不管怎样,我试过了。同样的结果。正如@IceMetalPunk所说,有一些库/框架/CMS正在转换base64中的图像,以节省磁盘空间。你的问题没有一个简单的答案,你是在创建这些图像标签吗?您可以将src放在alt属性中,然后获取document.getElementById('imgPreview')。alt.Hey,这会给出与我的代码中相同的结果,返回图像源,而不是图像文件的名称。我测试它时使用了jpg而不是png,hmmm,根据格式可能有不同的对象参数列表。让我试试本地png…也可以用png。使用firefox dev editon。可能与你的形象有关。尝试使用另一个png图像进行测试。这是我用过的确切数字<代码>https://clipground.com/images/png-tree-clipart-3.png好的,上面的代码至少有助于显示我的src产权。但每当我加载另一个文件时,它都会显示图像源,而不是文件名。我试过使用几个不同的jpg和png文件…第二个选项返回该图像源中的一些字符。但这看起来不像文件名。同样,它只适用于图像源。顺便说一句,非常感谢你的帮助。我真的很感激