摘要:本次的內(nèi)容是圖片的上傳預(yù)覽。待上傳圖像點擊藍(lán)色框內(nèi),可以選擇文件,移動端選擇拍照或選擇圖片進(jìn)行上傳。部分請點擊這層就是加號圖像是轉(zhuǎn)碼后顯示圖像的地方。最后的預(yù)覽圖像地址以后會加入更多的小插件。
hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內(nèi)容是圖片的上傳預(yù)覽。最后發(fā)源碼鏈接。
廢話不多說,先上圖。
待上傳圖像
點擊藍(lán)色框內(nèi),pc可以選擇文件,移動端選擇拍照或選擇圖片進(jìn)行上傳。
HTML部分
請點擊![]()
.default-box這層就是加號圖像
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時間,然后傳入?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í)行這個
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...
以后會加入更多的小插件。 最后祝大家身體健康,謝謝。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/114040.html
摘要:本次的內(nèi)容是圖片的上傳預(yù)覽。待上傳圖像點擊藍(lán)色框內(nèi),可以選擇文件,移動端選擇拍照或選擇圖片進(jìn)行上傳。部分請點擊這層就是加號圖像是轉(zhuǎn)碼后顯示圖像的地方。最后的預(yù)覽圖像地址以后會加入更多的小插件。 hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內(nèi)容是圖片的上傳預(yù)覽。最后發(fā)源碼鏈接。廢話不多說,先上圖。showImg(https://segmentfault.com/img...
摘要:本次的內(nèi)容是圖片的上傳預(yù)覽。待上傳圖像點擊藍(lán)色框內(nèi),可以選擇文件,移動端選擇拍照或選擇圖片進(jìn)行上傳。部分請點擊這層就是加號圖像是轉(zhuǎn)碼后顯示圖像的地方。最后的預(yù)覽圖像地址以后會加入更多的小插件。 hello,大家好,游戲開始了,歡迎大家收看這一期的講解。本次的內(nèi)容是圖片的上傳預(yù)覽。最后發(fā)源碼鏈接。廢話不多說,先上圖。showImg(https://segmentfault.com/img...
摘要:環(huán)境,這里的指到實例一圖片壓縮文件類型是圖片格式,文件壓縮后對象,,容器或者回調(diào)函數(shù)開始讀取指定對象中的內(nèi)容讀取操作完成時返回一個格式的字符串開始壓縮利用數(shù)據(jù)化圖片進(jìn)行壓縮圖片轉(zhuǎn)指到默認(rèn)按比例壓縮默認(rèn)圖片質(zhì)量為生成創(chuàng)建屬性節(jié)點圖像質(zhì)量值越 *vue+webpack環(huán)境,這里的that指到vue實例 一、圖片壓縮 /* file:文件(類型是圖片格式), ...
摘要:需求就是那么簡單,在瀏覽器里裁剪圖片并上傳到服務(wù)器。原圖片對象上傳裁剪后的對象初始化圖片預(yù)覽根據(jù)裁剪參數(shù)繪制轉(zhuǎn)對象以下將對每個環(huán)節(jié)詳解。或者根據(jù)獲取裁剪信息包括旋轉(zhuǎn)和縮放用進(jìn)行手動繪制。 前言 圖片裁剪上傳,不僅是一個很貼合用戶體驗的功能,還能夠統(tǒng)一特定圖片尺寸,優(yōu)化網(wǎng)站排版,一箭雙雕。 需求就是那么簡單,在瀏覽器里裁剪圖片并上傳到服務(wù)器。 我第一個想到的方法就是,將圖片和裁剪參數(shù)(x...
閱讀 1369·2021-11-24 09:39
閱讀 2874·2021-09-28 09:35
閱讀 1282·2019-08-30 15:55
閱讀 1548·2019-08-30 15:44
閱讀 1046·2019-08-29 17:00
閱讀 2119·2019-08-29 12:19
閱讀 3475·2019-08-28 18:28
閱讀 924·2019-08-28 18:10