中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript圖片上傳預覽怎么弄

發布時間:2020-10-20 16:56:49 來源:億速云 閱讀:123 作者:小新 欄目:web開發

javascript圖片上傳預覽怎么弄?這個問題可能是我們日常學習或工作經常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家帶來的參考內容,讓我們一起來看看吧!

hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內容是圖片的上傳預覽。最后發源碼鏈接。

廢話不多說,先上圖。

javascript圖片上傳預覽怎么弄

待上傳圖像

點擊藍色框內,pc可以選擇文件,移動端選擇拍照或選擇圖片進行上傳。

HTML部分

<div class="img-box">
    <div class="card-box">
        <div class="default-box" >
            <img class="default-img" src="./cardFactory.png" alt="">
            <div class="default-title">請點擊</div>
            <img class="add-img" src="./add.png" alt="">
        </div>
        <div class="up-img" id="upImg"></div>
        <input type="file" id="addImg"  class="upImg-btn">
    </div>
</div>

.default-box這層就是加號圖像
up-img是轉碼后顯示圖像的地方。
下面input是選擇圖像的地方。

css

        .img-box {
            display: flex;
            justify-content: center;
            align-items: center;
        }
        .card-box {
            width: 7.5rem;
            height: 4rem;
            border: solid .04rem #23a7fe;
            border-radius: 4px;
            box-sizing: border-box;
            position: relative;
        }
        .upImg-btn {
            width: 100%;
            height: 100%;
            opacity: 0;
            position: absolute;
            top: 0;
            left: 0;
        }
        .up-img {
            width: 5.58rem;
            height: 3.12rem;
            margin: .2rem .6rem;
            position: absolute;
            top: .2rem;
            left: 0;
            background-repeat: no-repeat;
            background-position: center center;
            background-size: cover
        }
        .default-box {
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
        }
        .add-img {
            position: absolute;
            top: 50%;
            left: 50%;
            margin-left: -.64rem;
            margin-top: -.64rem;
            width: 1.28rem;
            height: 1.28rem;
        }
        .default-img {
            position: absolute;
            padding: 0 1.1rem;
            bottom: .68rem;
            box-sizing: border-box;
            width: 100%;
            opacity: .5;
        }
        .default-title {
            position: absolute;
            width: 100%;
            bottom: .12rem;
            text-align: center;
            color: #23a7fe;
            font-size: .32rem;
        }

內部就是定位了。

頁面js

    document.querySelector("#addImg").addEventListener("change",function () {
        changeImg({
            id:"addImg",           //input的Id   必須
            imgBox:'upImg',        //顯示位置Id   必須
            limitType:['jpg','png','jpeg'],   //支持的類型   必須
            limitSize:819200          //圖片超過多大開始進行壓縮    可不傳
        });
    });

我們監聽input的change時間,然后傳入參數dShowImg64.js代碼

     //id,limitType,limitSize
    function changeImg(obj = {}) {                          
        if(!obj.id) return;
        if(!obj.limitType)return;
        var dom = document.querySelector("#"+obj.imgBox);
        var files =  document.querySelector("#"+obj.id).files[0];
        var reader = new FileReader();
        var type = files.type && files.type.split('/')[1];           //文件的類型,判斷是否是圖片
        var size = files.size;         //文件的大小,判斷圖片的大小
        if (obj.limitType.indexOf(type) == -1) {
            alert('不符合上傳要求');
            return;
        }
        //判斷是否傳入限制大小。壓不壓縮。
        var limitSize = obj.limitSize ? parseInt(obj.limitSize) : 0;
        if (size < limitSize) {
            reader.readAsDataURL(files);              // 不壓縮,直接轉base64
            reader.onloadend = function () {
                dom.style.backgroundImage = "url("+this.result+")";
                //如果要上傳的話,在這里調用ajax
                document.querySelector(".default-box").style.display = "none";
            }
        } else {                                     //壓縮
            var imageUrl = this.getObjectURL(files);      //創造url
            this.convertImg(imageUrl, function (base64Img) {   //調用壓縮函數
                dom.style.backgroundImage = "url("+base64Img+")";
                //如果要上傳的話,在這里調用ajax
                document.querySelector(".default-box").style.display = "none";
            }, type)
        }
    }
    function convertImg(url, callback, outputFormat) {
        var canvas = document.createElement('CANVAS');  //繪制canvas
        var ctx = canvas.getContext('2d');
        var img = new Image;            //初始化圖片
        img.crossOrigin = 'Anonymous';
        img.onload = function () {
            var width = img.width;
            var height = img.height;
            // 按比例壓縮2倍       //設置壓縮比例,最后的值越大壓縮越高
            var rate = (width < height ? width / height : height / width) / 2;
            canvas.width = width * rate;
            canvas.height = height * rate;           //繪制新圖
            ctx.drawImage(img, 0, 0, width, height, 0, 0, width * rate, height * rate);                                               //轉base64
            var dataURL = canvas.toDataURL(outputFormat || 'image/png');
            callback.call(this, dataURL);   //回調函數傳入base64的值
            canvas = null;
        };
        img.src = url;
    }
    function getObjectURL(file) {     //創造指向該圖的URL
        var url = null;
        if (window.createObjectURL != undefined) {  //大部分執行這個
            url = window.createObjectURL(file);
        } else if (window.URL != undefined) {       // 兼容
            url = window.URL.createObjectURL(file);
        } else if (window.webkitURL != undefined) { // 兼容
            url = window.webkitURL.createObjectURL(file);
        }
        return url;
    }

首先獲取各種屬性如類型、大小
判斷圖片是否小于限制大小、小于的話直接轉base64,大于的話 利用canvas 進行縮小完成壓縮后轉base64 然后將得到的值設置為背景圖。然后隱藏add的樣式。

javascript圖片上傳預覽怎么弄

感謝各位的閱讀!看完上述內容,你們對javascript圖片上傳預覽怎么弄大概了解了嗎?希望文章內容對大家有所幫助。如果想了解更多相關文章內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

延津县| 太康县| 富锦市| 正宁县| 剑川县| 罗城| 富宁县| 灵丘县| 平罗县| 永川市| 克东县| 镇沅| 乳山市| 呼图壁县| 自治县| 雅江县| 白山市| 青田县| 衡东县| 贵港市| 板桥市| 保德县| 莲花县| 井冈山市| 惠来县| 神农架林区| 沿河| 马鞍山市| 宁德市| 沁源县| 怀柔区| 五家渠市| 河间市| 龙胜| 屏山县| 舒兰市| 彭水| 东兰县| 兴安盟| 左贡县| 松江区|