国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

圖片上傳預(yù)覽轉(zhuǎn)壓縮并轉(zhuǎn)base64詳解(dShowImg64.js)

wums / 2615人閱讀

摘要:本次的內(nèi)容是圖片的上傳預(yù)覽。待上傳圖像點(diǎn)擊藍(lán)色框內(nèi),可以選擇文件,移動(dòng)端選擇拍照或選擇圖片進(jìn)行上傳。部分請(qǐng)點(diǎn)擊這層就是加號(hào)圖像是轉(zhuǎn)碼后顯示圖像的地方。最后的預(yù)覽圖像地址以后會(huì)加入更多的小插件。

hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內(nèi)容是圖片的上傳預(yù)覽。最后發(fā)源碼鏈接。
廢話不多說,先上圖。
待上傳圖像

點(diǎn)擊藍(lán)色框內(nèi),pc可以選擇文件,移動(dòng)端選擇拍照或選擇圖片進(jìn)行上傳。

HTML部分

請(qǐng)點(diǎn)擊

.default-box這層就是加號(hào)圖像
up-img是轉(zhuǎn)碼后顯示圖像的地方。
下面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;
        }

內(nèi)部就是定位了。

頁面js

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

我們監(jiān)聽input的change時(shí)間,然后傳入?yún)?shù)

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);              // 不壓縮,直接轉(zhuǎn)base64
            reader.onloadend = function () {
                dom.style.backgroundImage = "url("+this.result+")";
                //如果要上傳的話,在這里調(diào)用ajax
                document.querySelector(".default-box").style.display = "none";
            }
        } else {                                     //壓縮
            var imageUrl = this.getObjectURL(files);      //創(chuàng)造url
            this.convertImg(imageUrl, function (base64Img) {   //調(diào)用壓縮函數(shù)
                dom.style.backgroundImage = "url("+base64Img+")";
                //如果要上傳的話,在這里調(diào)用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倍       //設(shè)置壓縮比例,最后的值越大壓縮越高
            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);                                               //轉(zhuǎn)base64
            var dataURL = canvas.toDataURL(outputFormat || "image/png");
            callback.call(this, dataURL);   //回調(diào)函數(shù)傳入base64的值
            canvas = null;
        };
        img.src = url;
    }
    function getObjectURL(file) {     //創(chuàng)造指向該圖的URL
        var url = null;
        if (window.createObjectURL != undefined) {  //大部分執(zhí)行這個(gè)
            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;
    }

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


最后的預(yù)覽圖像

git地址:https://github.com/Zhoujiando...
以后會(huì)加入更多的小插件。 最后祝大家身體健康,謝謝。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/53114.html

相關(guān)文章

  • 圖片上傳預(yù)覽轉(zhuǎn)壓縮轉(zhuǎn)base64詳解dShowImg64.js

    摘要:本次的內(nèi)容是圖片的上傳預(yù)覽。待上傳圖像點(diǎn)擊藍(lán)色框內(nèi),可以選擇文件,移動(dòng)端選擇拍照或選擇圖片進(jìn)行上傳。部分請(qǐng)點(diǎn)擊這層就是加號(hào)圖像是轉(zhuǎn)碼后顯示圖像的地方。最后的預(yù)覽圖像地址以后會(huì)加入更多的小插件。 hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內(nèi)容是圖片的上傳預(yù)覽。最后發(fā)源碼鏈接。廢話不多說,先上圖。showImg(https://segmentfault.com/img...

    NeverSayNever 評(píng)論0 收藏0
  • 圖片上傳預(yù)覽轉(zhuǎn)壓縮轉(zhuǎn)base64詳解dShowImg64.js

    摘要:本次的內(nèi)容是圖片的上傳預(yù)覽。待上傳圖像點(diǎn)擊藍(lán)色框內(nèi),可以選擇文件,移動(dòng)端選擇拍照或選擇圖片進(jìn)行上傳。部分請(qǐng)點(diǎn)擊這層就是加號(hào)圖像是轉(zhuǎn)碼后顯示圖像的地方。最后的預(yù)覽圖像地址以后會(huì)加入更多的小插件。 hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內(nèi)容是圖片的上傳預(yù)覽。最后發(fā)源碼鏈接。廢話不多說,先上圖。showImg(https://segmentfault.com/img...

    zorro 評(píng)論0 收藏0
  • JS圖片壓縮上傳(單張)

    摘要:環(huán)境,這里的指到實(shí)例一圖片壓縮文件類型是圖片格式,文件壓縮后對(duì)象,,容器或者回調(diào)函數(shù)開始讀取指定對(duì)象中的內(nèi)容讀取操作完成時(shí)返回一個(gè)格式的字符串開始?jí)嚎s利用數(shù)據(jù)化圖片進(jìn)行壓縮圖片轉(zhuǎn)指到默認(rèn)按比例壓縮默認(rèn)圖片質(zhì)量為生成創(chuàng)建屬性節(jié)點(diǎn)圖像質(zhì)量值越 *vue+webpack環(huán)境,這里的that指到vue實(shí)例 一、圖片壓縮 /* file:文件(類型是圖片格式), ...

    KaltZK 評(píng)論0 收藏0
  • 無需Flash實(shí)現(xiàn)圖片裁剪——HTML5中級(jí)進(jìn)階

    摘要:需求就是那么簡(jiǎn)單,在瀏覽器里裁剪圖片并上傳到服務(wù)器。原圖片對(duì)象上傳裁剪后的對(duì)象初始化圖片預(yù)覽根據(jù)裁剪參數(shù)繪制轉(zhuǎn)對(duì)象以下將對(duì)每個(gè)環(huán)節(jié)詳解。或者根據(jù)獲取裁剪信息包括旋轉(zhuǎn)和縮放用進(jìn)行手動(dòng)繪制。 前言 圖片裁剪上傳,不僅是一個(gè)很貼合用戶體驗(yàn)的功能,還能夠統(tǒng)一特定圖片尺寸,優(yōu)化網(wǎng)站排版,一箭雙雕。 需求就是那么簡(jiǎn)單,在瀏覽器里裁剪圖片并上傳到服務(wù)器。 我第一個(gè)想到的方法就是,將圖片和裁剪參數(shù)(x...

    JerryC 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<