首先说一下input

大家都知道上传文件,图片是通过input 的file进行上传的。

1. 首先是样式

大家都知道input在HTML的代码为 <input type="file">;在页面的样式是不可以更改的,如下图



但是最为一个投机取巧的前端,一切样式都是可以修改的。

效果图如下



代码:

<input type="file" name="file" id="file" class="inputfile" />

<label for="file" class='btn btn-success'>Choose a file</label>


其中隐藏input原始样式的办法有几种我就随便写几个仅做参考。也就是类.inputfile的css内容

.inputfile {
opacity: 0;
}

或者

.inputfile {
position:absolute;clip:rect(0 0 0 0);
}

也可以

.inputfile {
z-index: -11111; width: 0px; height: 1px;
}
总之有很多办法,只是给大家一个思路。

2. input的file类型控制

input的标签有一个accept属性,accept 属性只能与 <input type="file"> 配合使用。它规定能够通过文件上传进行提交的文件类型。

因为我们需要做的是上传图片所以这里我们是<input type="file" accept="image/*">;效果图如下



但是在Chrome浏览器下,可能会有文件选择窗口打开非常慢点(大约慢5秒左右呢)问题,因此,如果仅仅是上传图片,建议使用:<input type="file" accept="image/png, image/jpeg, image/gif, image/jpg">

当然accept还有一些其他的值,如

        <input type="file" webkitdirectory directory multiple/>

<label for="file">上传文件夹</label>

<br>

<input type="file" accept="application/pdf"/>

<label for="file">上传pdf文件</label>

<br>

<input type="file" accept="audio/x-mpeg"/>

<label for="file">上传mp3文件</label>

<br>

<input type="file" accept="text/html"/>

<label for="file">上传html文件</label>

多个属性值使用逗号分隔<input accept="audio/*,video/*,image/*">

3. 在form中的使用

如果想使用浏览器原生特性实现文件上传(如图片)效果,父级的form元素有个东西不能丢,就是:enctype="multipart/form-data" enctype属性规定在发送到服务器之前应该如何对表单数据进行编码,默认的编码是:”application/x-www-form-urlencoded“。对于普通数据是挺适用的,但是,对于文件什么的,就不能乱编码了,该什么就是什么,只能使用multipart/form-data作为enctype属性值。

4. 图片预览

简单的来说就是,就是替换img的src;而读取URL有filereader 和 URL.createObjectURL 两种预览方式。这两种方式可以获得上传图片的名字(name)


filereader 的方法:

//filereader 的方法
<form action="" enctype="multipart/form-data">

<input id="file" class="filepath" onchange="changepic(this)" type="file"><br>

<img src="" id="show" width="200">

</form>

<script>

function changepic() {

var reads= new FileReader();

f=document.getElementById('file').files[0];

reads.readAsDataURL(f);

reads.onload=function (e) {

document.getElementById('show').src=this.result;

};

}

</script>

createObjectURL的方法

//createObjectURL的方法
<form action="" enctype="multipart/form-data">

<input id="file" class="filepath" onchange="changepic(this)" type="file"><br>

<img src="" id="show" width="200">

</form>

<script>

function changepic(obj) {

//console.log(obj.files[0]);//这里可以获取上传文件的name

var newsrc=getObjectURL(obj.files[0]);

document.getElementById('show').src=newsrc;


}

//建立一個可存取到該file的url

function getObjectURL(file) {

var url = null ;

// 下面函数执行的效果是一样的,只是需要针对不同的浏览器执行不同的 js 函数而已

if (window.createObjectURL!=undefined) { // basic

url = window.createObjectURL(file) ;

} else if (window.URL!=undefined) { // mozilla(firefox)
url = window.URL.createObjectURL(file) ;

} else if (window.webkitURL!=undefined) { // webkit or chrome

url = window.webkitURL.createObjectURL(file) ;

}

return url ;

}

</script>

以上是两种方法,按照前辈们的说法,creatObjectURL可以有更好的性能,或许是浏览器自带接口的原因, 可以处理的更快。

基于上述的了解的方法,自己做了一个demo;效果图如下,



预览图如下:



因为文件太大;详细资源代码请到图片上传预览下载;如急需的请留言。


原文地址:https://blog.csdn.net/weixin_38023551/article/details/78318532

input上传图片并预览的更多相关文章

  1. input上传图片 显示预览信息

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <t ...

  2. input 上传图片显示预览、调用摄像头,ios和Android的兼容性解决

    html代码: <img id="pic" src="img/pic.png"/> </span><input id=" ...

  3. vue 利用原声input上传图片并预览并删除

    <template> <div class="com-upload-img"> <div class="img_group"> ...

  4. vue <input type="file">上传图片、预览、删除

    使用原生<input type="file">上传图片.预览.删除:multiple实现可上传多张 参数名 类型 说明 fileTypes Array 文件类型, 默认 ...

  5. js上传图片及预览功能

    详细内容请点击 参考了网上一些人代码写了一个上传图片及时预览的功能 <img id="imgTag" style="height: 100px;" alt ...

  6. jquery解决file上传图片+图片预览

    js解决file上传图片+图片预览 demo案例中代码为js原生控制,可以根据项目的需求修改为jquery操作 <!DOCTYPE html><html lang="en& ...

  7. js实现上传图片本地预览功能以及限制图片的文件大小和尺寸大小

    方法一: js: /**     * 上传图片本地预览方法     * @param {Object} fileObj 上传文件file的id元素  fresh-fileToUpload      * ...

  8. 上传图片预览JS脚本 Input file图片预览的实现示例

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. 一段上传图片预览JS脚本,Input file图片预览的实现

    在深圳做项目的时候,需要一个用户上传头像预览的功能!是在网上找了好多,都不太满意.要么是flash的,要么是Ajax上传后返回图片路径的,要么压根就是不能用的.幸运的是在这个项目以前有人写过一个图片预 ...

随机推荐

  1. linux 关于网络接口及配置工具说明

    在Linux操作系统中配置网络接口,一般是通过网络配置工具实现的,但最终目的还是通过网络配置工具来达到修改与网络相关的配置文件而起作用的.由此说来,我们配置网络可以直接修改配置文件. 比如网络网络接口 ...

  2. Django中form组件的is_valid校验机制

    先来归纳一下整个流程(1)首先is_valid()起手,看seld.errors中是否值,只要有值就是flase(2)接着分析errors.里面判断_errors是都为空,如果为空返回self.ful ...

  3. UE4物理模块(三)---碰撞查询(上)

    在前一文中介绍了如何在UE4中创建简单碰撞或者直接使用其mesh表示的复杂碰撞: Jerry:UE4物理模块(二)---建立物体碰撞​zhuanlan.zhihu.com 那么在拿到碰撞之后,就可以进 ...

  4. twisted(转)

    reactor.protocol 这两个类都在 twisted.internet 命名空间中 reactor对象是Twisted编程当中的第一步,它就是一个反应器,专门负责与服务端的连接以及监听与服务 ...

  5. Django 配置MySQL数据库 mysql

    Django 配置MySQL数据库 在settings.py中配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # ...

  6. JavaScript 生成32位UUID

    function uuid(){ var len=32; //32长度 var radix=16; //16进制 var chars='0123456789ABCDEFGHIJKLMNOPQRSTUV ...

  7. 加快liferay 7的启动速度

    在启动Liferay的过程中,你会发现在某个时刻,会特别慢,停留了很久,它是停在validate LPKGs,检验LPKG files是否被篡改,这个过程在开发的过程中十分令人头疼. 现在Lifera ...

  8. 云计算、大数据、编程语言学习指南下载,100+技术课程免费学!这份诚意满满的新年技术大礼包,你Get了吗?

    开发者认证.云学院.技术社群,更多精彩,尽在开发者会场 近年来,新技术发展迅速.互联网行业持续高速增长,平均薪资水平持续提升,互联网技术学习已俨然成为学生.在职人员都感兴趣的“业余项目”. 阿里云大学 ...

  9. JS原生实现五角星评价详情demo

    <style> *{margin: 0;padding: 0;} .pingfen{ width: 195px; margin:10px auto; height:20px; positi ...

  10. Linux进程管理(四、 进程终结)

    进程调用exit()会终结当前进程,可以显式调用,也可以隐式: c语言main函数结束时编译器会自动加入exit调用 exit是系统调用,对应内核里的sys_exit() -> do_exit( ...