亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

html5 拖拽上傳圖片實例演示

2020-03-24 19:17:29
字體:
來源:轉載
供稿:網友
因為標題寫的是實例,所以本次就不做講解了,因為這個實例我也算是東拼西湊整出來的,參考了大概5、6款拖拽上傳的插件和demo,然后把其中好的地方挑出來,最后就成了這么一個實例,一起來看下吧(地址不能保證長久有效,如果失效請在文章最后點擊demo下載):

界面樣式我是參考了一個國外的相冊網站,改動不大,只是把鳥語轉換成中文,以及上傳時的樣式也進行了改動,之所以選這個的原因就是,我很容易做擴展,它支持3種方式添加圖片,一種拖拽上傳,一種常規(guī)的選擇文件上傳,另外的就是添加網絡圖片。它很巧妙的把三種上傳模式整合到了一起,而且你可以用IE瀏覽器瀏覽下,如果不支持HTML5,是沒有拖拽上傳圖片的提示的,如圖:

拖拽上傳最重要的就是js部分的代碼,它實現(xiàn)了70%的功能,另外30%僅僅是把圖片信息提交到后臺,然后做對應的處理,比如壓縮啊,裁剪啊云云。所以先來看下js實現(xiàn)代碼吧。

復制代碼代碼如下:
$().ready(function(){
if($.browser.safari || $.browser.mozilla){
$('#dtb-msg1 .compatible').show();
$('#dtb-msg1 .notcompatible').hide();
$('#drop_zone_home').hover(function(){
$(this).children('p').stop().animate({top:'0px'},200);
},function(){
$(this).children('p').stop().animate({top:'-44px'},200);
});
//功能實現(xiàn)
$(document).on({
dragleave:function(e){
e.preventDefault();
$('.dashboard_target_box').removeClass('over');
},
drop:function(e){
e.preventDefault();
//$('.dashboard_target_box').removeClass('over');
},
dragenter:function(e){
e.preventDefault();
$('.dashboard_target_box').addClass('over');
},
dragover:function(e){
e.preventDefault();
$('.dashboard_target_box').addClass('over');
}
});
var box = document.getElementById('target_box');
box.addEventListener("drop",function(e){
e.preventDefault();
//獲取文件列表
var fileList = e.dataTransfer.files;
var img = document.createElement('img');
//檢測是否是拖拽文件到頁面的操作
if(fileList.length == 0){
$('.dashboard_target_box').removeClass('over');
return;
}
//檢測文件是不是圖片
if(fileList[0].type.indexOf('image') === -1){
$('.dashboard_target_box').removeClass('over');
return;
}
if($.browser.safari){
//Chrome8+
img.src = window.webkitURL.createObjectURL(fileList[0]);
}else if($.browser.mozilla){
//FF4+
img.src = window.URL.createObjectURL(fileList[0]);
}else{
//實例化file reader對象
var reader = new FileReader();
reader.onload = function(e){
img.src = this.result;
$(document.body).appendChild(img);
}
reader.readAsDataURL(fileList[0]);
}
var xhr = new XMLHttpRequest();
xhr.open("post", "test.php", true);
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
xhr.upload.addEventListener("progress", function(e){
$("#dtb-msg3").hide();
$("#dtb-msg4 span").show();
$("#dtb-msg4").children('span').eq(1).css({width:'0px'});
$('.show').html('');
if(e.lengthComputable){
var loaded = Math.ceil((e.loaded / e.total) * 100);
$("#dtb-msg4").children('span').eq(1).css({width:(loaded*2)+'px'});
}
}, false);
xhr.addEventListener("load", function(e){
$('.dashboard_target_box').removeClass('over');
$("#dtb-msg3").show();
$("#dtb-msg4 span").hide();
var result = jQuery.parseJSON(e.target.responseText);
alert(result.filename);
$('.show').append(result.img);
}, false);
var fd = new FormData();
fd.append('xfile', fileList[0]);
xhr.send(fd);
},false);
}else{
$('#dtb-msg1 .compatible').hide();
$('#dtb-msg1 .notcompatible').show();
}
});

開始我是先判斷瀏覽器類型,因為剛才介紹過,不同瀏覽器看到的是不同界面。主要實現(xiàn)代碼是從 功能實現(xiàn) 開始的,這塊具體為何這樣操作,原理是什么,我就不多說了,大家可以參考下這篇文章:《人人網首頁拖拽上傳詳解(HTML5 Drag Drop、FileReader API、formdata)》,不過ajax上傳部分的代碼還是有點不一樣的,因為人人那個似乎有點麻煩,我就另尋途徑了。
最后就是上傳部分的PHP代碼了,這里我只是提供個參考,你可以根據項目的需求來自己編寫。

復制代碼代碼如下:
$r = new stdClass();
header('content-type: application/json');
$maxsize = 10; //Mb
if($_FILES['xfile']['size'] ($maxsize * 1048576)){
$r- error = "圖片大小不超過 $maxsize MB";
}
$folder = 'files/';
if(!is_dir($folder)){
mkdir($folder);
}
$folder .= $_POST['folder'] ? $_POST['folder'] . '/' : '';
if(!is_dir($folder)){
mkdir($folder);
}
if(preg_match('/image/i', $_FILES['xfile']['type'])){
$filename = $_POST['value'] ? $_POST['value'] : $folder . sha1(@microtime() . '-' . $_FILES['xfile']['name']) . '.jpg';
}else{
$tld = split(',', $_FILES['xfile']['name']);
$tld = $tld[count($tld) - 1];
$filename = $_POST['value'] ? $_POST['value'] : $folder . sha1(@microtime() . '-' . $_FILES['xfile']['name']) . $tld;
}
$types = Array('image/png', 'image/gif', 'image/jpeg');
if(in_array($_FILES['xfile']['type'], $types)){
$source = file_get_contents($_FILES["xfile"]["tmp_name"]);
imageresize($source, $filename, $_POST['width'], $_POST['height'], $_POST['crop'], $_POST['quality']);
}else{
move_uploaded_file($_FILES["xfile"]["tmp_name"], $filename);
}
$path = str_replace('test.php', '', $_SERVER['SCRIPT_NAME']);
$r- filename = $filename;
$r- path = $path;
$r- img = ' img src="' . $path . $filename . '" alt="image" /
echo json_encode($r);
function imageresize($source, $destination, $width = 0, $height = 0, $crop = false, $quality = 80) {
$quality = $quality ? $quality : 80;
$image = imagecreatefromstring($source);
if ($image) {
// Get dimensions
$w = imagesx($image);
$h = imagesy($image);
if (($width $w $width) || ($height $h $height)) {
$ratio = $w / $h;
if (($ratio = 1 || $height == 0) $width !$crop) {
$new_height = $width / $ratio;
$new_width = $width;
} elseif ($crop $ratio = ($width / $height)) {
$new_height = $width / $ratio;
$new_width = $width;
} else {
$new_width = $height * $ratio;
$new_height = $height;
}
} else {
$new_width = $w;
$new_height = $h;
}
$x_mid = $new_width * .5; //horizontal middle
$y_mid = $new_height * .5; //vertical middle
// Resample
error_log('height: ' . $new_height . ' - width: ' . $new_width);
$new = imagecreatetruecolor(round($new_width), round($new_height));
imagecopyresampled($new, $image, 0, 0, 0, 0, $new_width, $new_height, $w, $h);
// Crop
if ($crop) {
$crop = imagecreatetruecolor($width ? $width : $new_width, $height ? $height : $new_height);
imagecopyresampled($crop, $new, 0, 0, ($x_mid - ($width * .5)), 0, $width, $height, $width, $height);
//($y_mid - ($height * .5))
}
// Output
// Enable interlancing [for progressive JPEG]
imageinterlace($crop ? $crop : $new, true);
$dext = strtolower(pathinfo($destination, PATHINFO_EXTENSION));
if ($dext == '') {
$dext = $ext;
$destination .= '.' . $ext;
}
switch ($dext) {
case 'jpeg':
case 'jpg':
imagejpeg($crop ? $crop : $new, $destination, $quality);
break;
case 'png':
$pngQuality = ($quality - 100) / 11.111111;
$pngQuality = round(abs($pngQuality));
imagepng($crop ? $crop : $new, $destination, $pngQuality);
break;
case 'gif':
imagegif($crop ? $crop : $new, $destination);
break;
}
@imagedestroy($image);
@imagedestroy($new);
@imagedestroy($crop);
}
}

PHP最終會返回一個JSON格式的數(shù)組,我返回的信息就是圖片地址、名稱,還有段img的html代碼,最后在js那邊獲取到json數(shù)組并處理,至此,操作結束。
文章最開始提到,還有點擊選擇文件上傳和網絡圖片,因為這2個不屬于這次的主題范圍內,就不說了。況且這2個功能實現(xiàn)起來都不麻煩。
demo下載html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
久久资源av| 日本福利视频一区| 国产一区视频在线观看免费| 欧美日韩视频免费看| 在线电影av不卡网址| 精品美女久久久久| 91网页版在线登录入口| www.av91| 狠狠躁夜夜躁人人爽天天天天97| 成人黄色免费在线观看| 国产乱xxⅹxx国语对白| 特级xxxxx欧美| 黄色免费视频大全| 黄在线免费看| 国产91在线视频观看| 欧美精品丝袜中出| 国产精品第一视频| 私库av在线播放| 亚洲美女免费在线| 国产精品欧美一区二区| 高清欧美一区二区三区| 美女视频一区二区三区在线| 亚洲色图官网| 国产又黄又猛又粗又爽| 综合网中文字幕| 蜜桃视频一区二区| 国产三级视频在线播放线观看| 国产精品www色诱视频| 精品黑人一区二区三区国语馆| 好操啊在线观看免费视频| 91亚洲国产成人精品性色| 91av在线播放视频| 亚洲欧洲中文天堂| 亚洲人成精品久久久久久| 在线观看自拍| 男女激情网站| 国产亚洲一本大道中文在线| 在线观看美女av| 免费福利片在线观看| 欧美一区二区视频观看视频| 国产极品粉嫩福利姬萌白酱| 男女视频网站| 在线观看区一区二| 懂色av懂色av粉嫩av| 久久亚洲一区| 无码人妻h动漫| 久久国产精品免费一区二区三区| 91精品国产91久久久久久密臀| 欧美在线三区| 网站黄色在线观看| 日韩精品视频免费在线观看| 亚洲国产欧美一区二区丝袜黑人| 亚洲尤物精选| 日本中文字幕精品—区二区| 青春草在线免费视频| 欧美日韩在线观看不卡| 清纯唯美亚洲色图| 亚洲欧美小说色综合小说一区| 亚洲精品怡红院| 国产卡1卡2卡三卡在线| 日韩欧美成人区| 亚洲aaa精品| 国产xxxx在线观看| 日本成人在线网站| 成人综合社区| 欧美一级免费观看| 91麻豆精品国产91久久久久推荐资源| 欧美日韩亚洲一区| 乱精品一区字幕二区| 国产黄色高清在线| 亚洲无线码一区二区三区| 97人妻天天摸天天爽天天| 91麻豆精品秘密入口| 69xxxx视频| 国产精品996| swag国产精品一区二区| 国产综合在线视频| 91福利社在线观看| 麻豆视频观看网址久久| 国偷自产av一区二区三区小尤奈| 日韩免费电影一区二区三区| 青娱乐国产视频| 国产区卡一卡二卡三乱码免费| 中文字幕在线免费观看视频| 韩剧1988免费观看全集| 日韩欧美高清在线视频| av资源种子在线观看| 欧美色欧美亚洲高清在线视频| 欧美成人高潮一二区在线看| 国产精品一区二区三区av麻| 麻豆电影在线| www.三级.com| 国产成人精品一区二区免费看京| 亚洲一级免费在线观看| 色综合一区二区日本韩国亚洲| 成人国产在线| 国产成人精品a视频一区| 欧美日韩p片| 4444免费观看| 精品国产一区二区三区不卡在线| 日本久久高清视频| 精品国产乱码久久久久软件| 免费精品国产自产拍观看| 欧美成人精品h版在线观看| 精品国产午夜肉伦伦影院| 国产精品中出一区二区三区| 免费麻豆国产一区二区三区四区| 久久精品国产精品青草| 中文字幕欧美一区| 欧美久久久久免费| av福利网址网站| 精品中文字幕一区二区三区四区| 在线播放黄色网址| 欧美久久久久久蜜桃| 国产精品pans私拍| 天堂网在线资源| 日韩欧美精品在线观看| 秋霞国产午夜精品免费视频| 国产精品三区在线| 日韩av影片| 黄色污污在线观看| xxx视频在线观看| 影音先锋人妻啪啪av资源网站| 蜜臀av在线| 丁香婷婷综合激情| 亚洲欧美综合图区| 日韩欧美三级一区二区| 亚洲精品成人无码| 毛片av一区二区三区| 久热国产精品视频一区二区三区| 国产成人亚洲欧美电影| a级大片在线观看| 欧洲一区二区视频| 亚洲黄色在线观看视频| 91久久国产综合久久| 97视频在线观看免费高清完整版在线观看| jizz视频18| 手机看片1024日韩| 另类天堂视频在线观看| 99er在线视频| 性高潮久久久久久久久久| 希岛爱理中文字幕| 在线国产视频一区| 成人免费淫片95视频观看网站| 国产一区日韩| 亚洲激情电影在线| 国产精品久久久久av电视剧| 国产无遮挡裸体免费视频| 久久国产婷婷国产香蕉| 国产欧美日韩免费看aⅴ视频| 日韩在线一二三区| 国产精品18久久久久久麻辣| 亚洲最新在线| 你微笑时很美电视剧整集高清不卡| 亚洲日本va中文字幕久久| 天堂va蜜桃一区二区三区| 久久艹在线视频| 国产精品直播网红| 在线视频一区二区三| 国产丝袜视频在线播放| 四虎精品一区二区免费| 亚洲国产精品视频一区| 久久久久久久久久久久久久国产| 亚洲一区二区三区免费在线观看| 日韩欧美中文视频| 国产精品香蕉av| 无码人妻aⅴ一区二区三区69岛| 亚洲精品欧美二区三区中文字幕| 精品在线91| 中文字幕一区二区三区四区视频| 久草中文在线观看| 欧美精品国产精品久久久| 国产男女在线观看| 五月天婷婷色综合| 欧美日韩国产专区| aa一级黄色片| 欧美性xxxx在线播放| 日韩电影在线看| 日韩精品一区二区免费| 日韩国产欧美一区二区| 人人九九精品| 女人18毛片九区毛片在线| hd100%videos日本| 亚洲综合av网| www.91在线观看| 久久久综合九色合综国产精品| 午夜成人在线视频| 成人网在线免费看| 国产精品久久综合| 亚洲欧美另类国产| 亚洲+小说+欧美+激情+另类| 五月天久久综合网| 欧美系列电影免费观看| 成人日韩欧美| 国产传媒免费在线观看| 日韩亚洲欧美中文三级| 一区二区三区精品在线观看| 久久国产视频网站| 国产精品剧情一区二区三区| jizzjizz.con| 久久精品国产亚洲av无码娇色| 最近2019中文字幕一页二页| 欧美午夜在线视频| 亚洲精品国偷自产在线99热| 国产成人精品日本亚洲专区61| 日韩精品一区二区在线观看| 丝袜美腿高跟呻吟高潮一区| 天堂av网在线| 国产成人愉拍精品久久| 久久亚洲无码视频| 日韩av在线播放网址| 日韩福利视频导航| 高清毛片aaaaaaaaa片| 色偷偷www8888| 日韩精品在线中文字幕| 成人黄色av网址| 在线视频国内自拍亚洲视频| 国产精品狼人久久影院观看方式| 一区二区三区免费看| 欧美暴力喷水在线| 久久国产精品视频在线观看| 一区二区视频网| 久久9热精品视频| av免费精品一区二区三区| 久久九九精品视频| 中文字幕综合| 热99精品只有里视频精品| 精品国产免费观看一区| 在线免费黄网| 91精品国产66| 久久久久97| 91精品国产综合久久香蕉最新版| 久久久久久a亚洲欧洲aⅴ| 久久99精品久久久久久| 久久久久成人片免费观看蜜芽| www.日韩高清| 亚洲一区亚洲二区| 欧美有码在线视频| 午夜精品久久久久久久白皮肤| 亚洲综合第一| 欧美一级免费大片| 蜜桃91麻豆精品一二三区| 51午夜精品视频| 美女欧美视频在线观看免费| 最新在线地址| 国语一区二区三区| 精品人妻无码一区二区三区| 69久久夜色精品国产69蝌蚪网| 少妇高潮一区二区三区99小说| 亚洲欧美日韩激情| 日本小视频在线免费观看| 欧美人成在线观看网站高清| 国内精品模特av私拍在线观看| 亚洲瘦老头同性70tv| 9.1人成人免费视频网站| 一区二区在线中文字幕电影视频| 国产不卡视频一区| 亚洲网站视频| 97一区二区三区| 欧美午夜精品久久久久久浪潮| 特黄aaaaaaaaa毛片免费视频| 7777狠狠狠琪琪电影| 国产一区二区三区视频在线播放| 成人小视频在线观看| 欧美丝袜美女中出在线| 国产精品毛片a∨一区二区三区| 欧美影视资讯| √8天堂资源地址中文在线| 成人免费在线小视频| 老司机在线精品视频| 欧美另类69xxxx| 久久亚洲一区二区三区明星换脸| 精品电影一区二区三区| 日韩欧美成人午夜| 亚洲午夜久久久久中文字幕| 老司机精品视频在线观看6| 欧美激情一级片一区二区| 天堂中文在线观看| 午夜a一级毛片亚洲欧洲| 884aa四虎影成人精品一区| 日韩在线精品视频| 国产成人成网站在线播放青青| 日韩亚洲一区在线播放| 欧美日韩国产成人| 国产欧美日韩综合| 国产一级揄自揄精品视频| 欧美视频免费在线观看| 日日夜夜操视频| jizzjizz丝袜老师| 黄网视频午夜青春| 午夜午夜精品一区二区三区文| 久久激情网站| av亚洲产国偷v产偷v自拍| 四虎影院一区二区| 91无套直看片红桃在线观看| 性色av无码久久一区二区三区| 欧美福利网址| 成年人免费在线观看网站| 91香蕉视频免费在线观看| 国产脚交av在线一区二区| 亚洲日本丝袜连裤袜办公室| 看黄网站在线观看| 欧美变态tickle挠乳网站| 国产在视频线精品视频www666| 视频一区中文字幕| 国产丶欧美丶日本不卡视频| 十九岁完整版在线观看好看云免费| 国产精品欧美一区二区三区不卡| 国内精品久久久久久久影视麻豆| 亚洲福利一区二区三区| 四虎精品在线观看| 国产精品中文有码| 国产三级视频在线| 欧美国产综合一区二区| 成人av中文| 色先锋资源网| 日韩欧美另类在线| 污影院在线观看| 精品99又大又爽又硬少妇毛片| 国产亚洲制服色| 国产成人精品一区二区三区四区| 国产经典自拍视频在线观看| 免费在线你懂的| 狠狠爱一区二区三区| 亚洲精品自在久久| 91精品国产高清久久久久久| 国产一区二区三区精品在线观看| 国产一区二区三区自拍|