佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > html+css+js 實現(xiàn)拍照預(yù)覽上傳圖片功能

html+css+js 實現(xiàn)拍照預(yù)覽上傳圖片功能

熱門標(biāo)簽:使用U盤裝系統(tǒng) 硅谷的囚徒呼叫中心 智能手機 阿里云 檢查注冊表項 百度競價點擊價格的計算公式 美圖手機 網(wǎng)站建設(shè)

前言:我們在做網(wǎng)頁時經(jīng)常會需要有上傳圖片的需求,可能是選擇圖片或者拍照上傳,如果簡單的使用<input type="file"/>這種方式雖然也能實現(xiàn)功能,但用戶體驗上可能會差了一些,所以本文記錄了使用css+js實現(xiàn)圖片選中后的預(yù)覽及壓縮上傳功能,部分帶來來源于網(wǎng)絡(luò),此處做了記錄整理。

效果預(yù)覽:

 

1.創(chuàng)建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.創(chuàng)建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.創(chuàng)建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 //未選中圖片時顯示的按鈕區(qū)域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格式的數(shù)據(jù)
 * @param {*} image img元素
 * @param {*} width 壓縮后圖片寬度
 * @param {*} height 壓縮后圖片高度
 * @param {*} qua //圖片質(zhì)量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地址

總結(jié)

以上所述是小編給大家介紹的html+css+js 實現(xiàn)拍照預(yù)覽上傳圖片功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

標(biāo)簽:煙臺 山南 湘潭 賀州 湖北 黃山 懷化 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html+css+js 實現(xiàn)拍照預(yù)覽上傳圖片功能》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    鄂托克旗| 永嘉县| 黎城县| 冀州市| 武穴市| 铜川市| 陵水| 喜德县| 沈阳市| 运城市| 平原县| 察隅县| 海原县| 清河县| 东乡族自治县| 泰安市| 平湖市| 兴安县| 盐城市| 藁城市| 靖边县| 上饶市| 达孜县| 十堰市| 漳州市| 徐水县| 涿鹿县| 蒲江县| 讷河市| 西藏| 民和| 神农架林区| 丹阳市| 新民市| 黔江区| 喀喇沁旗| 淳化县| 偏关县| 兰西县| 乌兰浩特市| 太和县|