麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > HTML > 正文

html+css+js 實現拍照預覽上傳圖片功能

2024-08-26 00:20:21
字體:
來源:轉載
供稿:網友

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

效果預覽:

css,上傳圖片預覽,上傳圖片

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"                            <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"                            <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 實現拍照預覽上傳圖片功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 一区二区三区日韩 | 色悠悠久久久久 | 久久精品99久久久久久2456 | 杏美月av| 2021国产精品视频 | 欧美激情在线播放 | 国产午夜精品一区二区三区不卡 | 手机黄色小视频 | 极品一级片 | 成人啪啪18免费网站 | 大西瓜永久免费av在线 | 在线1区| 日韩精品中文字幕一区二区三区 | 91麻豆精品国产91久久久无需广告 | 麻豆视频在线观看免费网站 | 国产欧美一区二区三区免费看 | 成人毛片100部 | 国产噜噜噜噜噜久久久久久久久 | 亚洲影视中文字幕 | 日本一区二区不卡高清 | 日本一区二区高清不卡 | 成人在线视频一区 | 激情亚洲一区二区三区 | 日本网站在线看 | 一级片久久免费 | 99精品国产在热久久婷婷 | 亚洲黑人在线观看 | 亚洲一区在线视频观看 | 成人一区二区三区在线 | 国产69精品久久久久孕妇黑 | 成人福利网 | xxxeexxx性国产 | 在线视频 欧美日韩 | 小视频免费在线观看 | 亚洲国产超高清a毛毛片 | 国产 视频 一区二区 | 97综合| 成人羞羞网站入口 | 麻豆自拍偷拍视频 | 亚洲精品成人av在线 | 国产一区视频在线观看免费 |