html+css+js 实现拍照预览上传图片功能

所属分类: HTML/Xhtml / 网页制作 阅读数: 335
收藏 0 赞 0 分享

前言:我们在做网页时经常会需要有上传图片的需求,可能是选择图片或者拍照上传,如果简单的使用<input type="file"/>这种方式虽然也能实现功能,但用户体验上可能会差了一些,所以本文记录了使用css+js实现图片选中后的预览及压缩上传功能,部分带来来源于网络,此处做了记录整理。

效果预览:

 

1.创建index.html

<!DOCTYPE html><html>
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
        <title>拍照上传</title>
        <link rel="stylesheet" href="index.css"/>
        <script type='text/javascript' src='index.js' charset='utf-8'></script>
    </head>
    <body>
         <form id="mainForm">
            <div class="content">
                <div class="label">身份证</div>
                <div class="img-area">
                    <div class="container">
                        <input type="file" id='id-face' name='face'  accept="image/*" />
                        <div id='face-empty-result'>
                            <img style='width:4rem' src="https://github.com/wangheng3751/my-resources/blob/master/images/camera.png?raw=true" alt="">
                            <p>身份证正面照</p>
                        </div>
                        <img style='width: 100%' id='face-result'/>
                    </div>
                    <div class="container" style='margin-top:0.5rem;'>
                        <input type="file" id='id-back' name='back' accept="image/*" />
                        <div id='back-empty-result'>
                            <img style='width:4rem' src="https://github.com/wangheng3751/my-resources/blob/master/images/camera.png?raw=true" alt="">
                            <p>身份证反面照</p>
                        </div>
                        <img style='width: 100%' id='back-result'/>
                    </div>
                </div>
            </div>
            <div class="btn">
                提交            </div>
         </form>
    </body></html>

2.创建index.css

body{
    margin: 0
}
.content{
    padding:0.5rem;
    display: flex;
    align-items: center;
    border-bottom: 1px #999 solid
}
.label{
    width:5rem;
}
.img-area{
    flex:1
}
.container{
    background-color:#e7e7e7;
    position: relative;
}
.container div{
    text-align: center;
    padding:0.5rem 0
}
.container input{
    opacity:0;
    filter:alpha(opacity=0);
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9;
}
.container p{
    font-size: 0.9rem;
    color:#999
}
.btn{
    background-color: #4363ab;
    color: #fff;
    text-align: center;
    padding: 0.5rem 1rem;
    width:80%;
    border-radius: 0.2rem;
    margin: 2rem auto;
    font-weight: 600;
    font-size: 1.2rem
}

3.创建index.js

window.onload=function(){
    document.getElementById("id-face").addEventListener("change", function(){
               onFileChange(this,"face-result","face-empty-result")    
});

    document.getElementById("id-back").addEventListener("change", function(){
               onFileChange(this,"back-result","back-empty-result")    
});

    document.getElementsByClassName("btn")[0].addEventListener("click", function(){
               submit();
    
});

}
;/** * 选中图片时的处理 * @param {*
}
 fileObj input file元素 * @param {*
}
 el //选中后用于显示图片的元素ID * @param {*
}
 btnel //未选中图片时显示的按钮区域ID */
function onFileChange(fileObj,el,btnel){
    var windowURL = window.URL || window.webkitURL;
    var dataURL;
    var imgObj = document.getElementById(el);
    document.getElementById(btnel).style.display="none";
    imgObj.style.display="block";
    if (fileObj && fileObj.files && fileObj.files[0]) {
        dataURL = windowURL.createObjectURL(fileObj.files[0]);
        imgObj.src=dataURL;
    
}
 else {
        dataURL = fileObj.value;
        imgObj.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
        imgObj.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = dataURL;
    
}

}
/** * 将图片压缩后返回base64格式的数据 * @param {*
}
 image img元素 * @param {*
}
 width 压缩后图片宽度 * @param {*
}
 height 压缩后图片高度 * @param {*
}
 qua //图片质量1-100 */
function compressImageTobase64(image,width,height,qua){
    var quality = qua ? qua / 100 : 0.8;
    var canvas = document.createElement("canvas"),             ctx = canvas.getContext('2d');
         var w = image.naturalWidth,             h = image.naturalHeight;
         canvas.width = width||w;
         canvas.height = height||h;
         ctx.drawImage(image, 0, 0, w, h, 0, 0, width||w, height||h);
    var data = canvas.toDataURL("image/jpeg", quality);
         return data;
}
//提交function submit(){
    //1、form提交    //document.getElementById("mainForm").submit();
    //2、压缩后ajax提交    var face_data=compressImageTobase64(document.getElementById("face-result"),200,100,90);
    var back_data=compressImageTobase64(document.getElementById("back-result"),200,100,90);
    var formData = new FormData();
      formData.append("face",face_data);
    formData.append("back",back_data);
    //需引入jQuery    $.ajax({
        url:"/地址",        type: 'POST',        cache: false,        data: formData,        timeout:180000,        processData: false,        contentType: false,        success:function(r){
        
}
,        error:function(r){
          
}
   
});

}

源码: Github地址

以上所述是小编给大家介绍的html+css+js 实现拍照预览上传图片功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

更多精彩内容其他人还在看

前端html换肤功能的实现代码

50行代码换5种肤色,包含透明先把代码奉上,自取自用。直接创建html文件,直接粘贴进去就能用,不能用随便骂。<!DOCTYPE html><html lang="en"><head><meta charset=&qu... 查看详情
收藏 0 赞 0 分享

详解HTML中字体使用line-height依然不能垂直居中解决办法

以图片所示的效果为例,显然我们不仅要使“下一步”文本水平居中,还要垂直居中,此时我们写代码如下:<!DOCTYPE html><html><head><meta charset="UTF-8"&... 查看详情
收藏 0 赞 0 分享

html直接引用vue和element-ui的方法

代码如下所示:<!DOCTYPE html><html><head> <meta charset="UTF-8"> <link rel="stylesheet" href=&... 查看详情
收藏 0 赞 0 分享

详解html-webpack-plugin使用

最近在react项目中初次用到了html-webapck-plugin插件,用到该插件的两个主要作用:为html文件中引入的外部资源如script、link动态添加每次compile后的hash,防止引用缓存的外部文件问题可以生成创建html入口文件,比如单页面可以生成一个htm... 查看详情
收藏 0 赞 0 分享

html+css 实现图片右上角加删除叉、图片删除按钮

为了纪录下,以后可能用到,有需要的道友也可以用用。不BB,上效果图先 以上就是效果图。 右上角的图片可自己换图片,图片素材我就不放上来了,我就上个代码,挺简单的css和js,初学者应该也看得明白</pre><pre name="code&qu... 查看详情
收藏 0 赞 0 分享

html post请求之a标签的两种用法解析

html post请求之a标签的两种用法举例,具体内容如下:1、使用ajax来发起POST请求HTML代码如下:<a href="https://www.jb51.net/" class="a_post">发起POST请求<... 查看详情
收藏 0 赞 0 分享

浅析HTML 悬浮float的用法

关于float的一些用法左悬浮: float:left; 右悬浮:float:right;float用法float的用途比较广, 这里简单的介绍下集中常有的用法: 在接触到浮动前,我会去设置一些inline-block, block的属性配合着div的镶嵌 去完成页面的排版... 查看详情
收藏 0 赞 0 分享

详解iframe的src指向的内容不刷新的解决办法

问题描述html<iframe id="h5Content" src=""></iframe>js$("#h5Content").attr("src","${h5.u... 查看详情
收藏 0 赞 0 分享

html中dom元素滚动条滚动控制小结详解

不知道大家有没有遇到过这样的需求,在某个 dom 元素中添加新的子元素,然后要求如果新添加的新元素超出容器的范围,那么我们需要自动滚动到新添加的子元素的位置,如下图所示效果:那么接下来我们一边学习一些 dom 元素滚动相关的知识点,一边实现一个上图的效果和一些其他滚动相关的功能。... 查看详情
收藏 0 赞 0 分享

如何为 Element UI 里的 autosize textarea 设置高度

把Element UI里的textarea input设置为autosize之后,文本框的默认高度为33,并不符合设计默认样式在浏览器中查检元素,发现高度是由textarea的height和min-height来控制框内文字的位置是由padding控制尝试直接修改文本框的heig... 查看详情
收藏 0 赞 0 分享
查看更多