input file样式修改以及图片预览删除功能详细概括(推荐)
发布时间 - 2026-01-11 02:50:30 点击率:次本篇对input file进行了修改,改成自己需要的样式,类似验证身份上传身份证图片的功能。

效果图如下:
这里主要展示上传预览图片功能,对于删除功能的html及css写的比较粗糙,对于想要精细表现这块儿的可以在自己添加修改。
<!--点击预览图片--> <div class="picDiv"> <div class="addImages"> <!--multiple属性可选择多个图片上传--> <input type="file" class="file" id="fileInput" multiple accept="image/png, image/jpeg, image/gif, image/jpg" /> <div class="text-detail"> <span>+</span> <p>点击上传</p> </div> </div> </div>
这里需要注意下:如果在input file 标签里写成accept=“image/*”会造成点击按钮后等待时间稍长才会弹出选择文件框,所以写成
accept="image/png, image/jpeg, image/gif, image/jpg"
css代码
.imageDiv{
display: inline-block;
width: 140px;
height: 125px;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
border: 1px dashed darkgray;
background: #f8f8f8;
position: relative;
overflow: hidden;
}
.cover{
position: absolute;
z-index: 1;
top: 0;
left: 0;
width: 140px;
height: 125px;
background-color: rgba(0,0,0,.3);
display: none;
line-height: 125px;
text-align: center;
cursor: pointer;
}
.cover>.delbtn{
color: red;
font-size: 20px;
}
.imageDiv:hover .cover{
display: block;
}
.addImages{
display: inline-block;
width: 140px;
height: 125px;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
border: 1px dashed darkgray;
background: #f8f8f8;
position: relative;
overflow: hidden;
}
.text-detail{
margin-top: 40px;
text-align: center;
}
.text-detail>span{
font-size: 40px;
}
.file{
position: absolute;
top: 0;
left: 0;
width: 140px;
height: 125px;
opacity: 0;
}
里边的加号或者删除字样都可以用成字体或者图片,看自己公司需要。
javascript代码
第一种方式:createObjectURL
//图片上传预览功能
var userAgent = navigator.userAgent;//用于判断浏览器类型
$(".file").change(function () {
//获取选择图片的对象
var docObj =$(this)[0];
var picDiv=$(this).parents(".picDiv");
//得到所有的图片文件
var fileList = docObj.files;
//循环遍历
for (var i = 0; i < fileList.length; i++) {
//动态添加html元素
var picHtml="<div class='imageDiv' > <img id='img" + fileList[i].name + "' /> <div class='cover'><i class='delbtn'>删除</i></div></div>"
picDiv.prepend(picHtml);
//获取图片imgi的对象
var imgObjPreview = document.getElementById("img"+fileList[i].name);
if (fileList && fileList[i]) {
//图片属性
imgObjPreview.style.display = 'block';
imgObjPreview.style.width = '140px';
imgObjPreview.style.height = '125px';
//imgObjPreview.src = docObj.files[0].getAsDataURL();
//火狐7以上版本不能用上面的getAsDataURL()方式获取,需要以下方式
if(userAgent.indexOf('MSIE') == -1){//IE以外浏览器
imgObjPreview.src = window.URL.createObjectURL(docObj.files[i]); //获取上传图片文件的物理路径
}else{//IE浏览器
if(docObj.value.indexOf(",")!=-1){
var srcArr=docObj.value.split(",");
imgObjPreview.src = srcArr[i];
}else{
imgObjPreview.src = docObj.value;
}
}
}
}
});
/*删除功能*/
$(document).on("click",".delbtn",function () {
console.log("click")
var _this=$(this);
_this.parents(".imageDiv").remove();
});
这里有浏览器判断,因为IE和谷歌,火狐等浏览器不同,后两者对于文件路径有浏览器保护,不会显示全文件路径,而IE浏览器则没有,它完整的显示了文件路径,下图可看出。
谷歌浏览器:
IE浏览器:
还有另外一种方式,通过filereader方式预览图片。
JavaScript代码
第二种方式:filereader
$(".file").change(function () {
//获取选择图片的对象
var docObj =$(this)[0];
var picDiv=$(this).parents(".picDiv");
//得到所有的图片文件
var fileList = docObj.files;
for(var i=0;i<fileList.length;i++){
var fr = new FileReader();
var single=fileList[i];
fr.onload = function(single) {
var picHtml = "<div class='imageDiv' > <img id='img" + single.name + "' src='" + single.target.result + "' /> <div class='cover'><i class='delbtn'>删除</i></div></div>"
picDiv.prepend(picHtml);
var imgObjPreview = document.getElementById("img" + single.name);
//图片属性
imgObjPreview.style.display = 'block';
imgObjPreview.style.width = '140px';
imgObjPreview.style.height = '125px';
};
fr.readAsDataURL(single);
}
});
/*删除功能*/
$(document).on("click",".delbtn",function () {
console.log("click")
var _this=$(this);
_this.parents(".imageDiv").remove();
});
另外,删除功能的js代码可以如上面代码一样写在外边,也可以写在change事件for循环外,这样就不用on,可以直接以删除按钮的class来写了,如:
//图片上传预览功能
var userAgent = navigator.userAgent;//用于判断浏览器类型
$(".file").change(function () {
//获取选择图片的对象
var docObj =$(this)[0];
var picDiv=$(this).parents(".picDiv");
//得到所有的图片文件
var fileList = docObj.files;
//循环遍历
for (var i = 0; i < fileList.length; i++) {
//动态添加html元素
var picHtml="<div class='imageDiv' > <img id='img" + fileList[i].name + "' /> <div class='cover'><i class='delbtn'>删除</i></div></div>"
picDiv.prepend(picHtml);
//获取图片imgi的对象
var imgObjPreview = document.getElementById("img"+fileList[i].name);
if (fileList && fileList[i]) {
//图片属性
imgObjPreview.style.display = 'block';
imgObjPreview.style.width = '140px';
imgObjPreview.style.height = '125px';
//imgObjPreview.src = docObj.files[0].getAsDataURL();
//火狐7以上版本不能用上面的getAsDataURL()方式获取,需要以下方式
if(userAgent.indexOf('MSIE') == -1){//IE以外浏览器
imgObjPreview.src = window.URL.createObjectURL(docObj.files[i]); //获取上传图片文件的物理路径
}else{//IE浏览器
if(docObj.value.indexOf(",")!=-1){
var srcArr=docObj.value.split(",");
imgObjPreview.src = srcArr[i];
}else{
imgObjPreview.src = docObj.value;
}
}
}
}
/*删除功能*/
$(".delbtn").click(function () {
var _this=$(this);
_this.parents(".imageDiv").remove();
});
});
此篇主要体现了两点:
1.input file 按钮改成自己想要的样式,就是将原本的input隐藏,用另一个标签<a>,<button>,<div>......代替,css控制他们加上自己需要的样式就可以了;
2.图片预览功能的实现,这里又分两种方法。
好了,到这里这篇就写完了,希望对你有所帮助。
# jq
# input
# file样式修改
# 图片预览删除
# java中File类的使用方法
# input file的默认value清空与赋值方法
# 上传图片预览JS脚本 Input file图片预览的实现示例
# js实现上传图片预览的方法
# js实现上传图片之上传前预览图片
# 火狐
# 图片上传
# 遍历
# 上传
# 不能用
# 写在
# 上传图片
# 好了
# 多个
# 才会
# 两种
# 可以用
# 对你
# 弹出
# 可以直接
# 写了
# 这块
# 这篇
# 可选择
# 需要注意
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何快速搭建高效服务器建站系统?
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
Laravel如何实现API资源集合?(Resource Collection教程)
网站页面设计需要考虑到这些问题
高端智能建站公司优选:品牌定制与SEO优化一站式服务
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
桂林网站制作公司有哪些,桂林马拉松怎么报名?
如何快速搭建支持数据库操作的智能建站平台?
新三国志曹操传主线渭水交兵攻略
郑州企业网站制作公司,郑州招聘网站有哪些?
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】
大同网页,大同瑞慈医院官网?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
如何在阿里云香港服务器快速搭建网站?
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
如何快速建站并高效导出源代码?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
如何在局域网内绑定自建网站域名?
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
如何在宝塔面板中修改默认建站目录?
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
php打包exe后无法访问网络共享_共享权限设置方法【教程】
js实现获取鼠标当前的位置
bootstrap日历插件datetimepicker使用方法
开心动漫网站制作软件下载,十分开心动画为何停播?
如何在Tomcat中配置并部署网站项目?
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
JavaScript如何实现路由_前端路由原理是什么
如何在阿里云通过域名搭建网站?
Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置
Laravel怎么判断请求类型_Laravel Request isMethod用法
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
Laravel怎么使用Intervention Image库处理图片上传和缩放
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
创业网站制作流程,创业网站可靠吗?
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
QQ浏览器网页版登录入口 个人中心在线进入
如何快速生成可下载的建站源码工具?
Python进程池调度策略_任务分发说明【指导】
Bootstrap CSS布局之列表
Laravel如何创建自定义Artisan命令?(代码示例)

