婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > html5 拖拽上傳圖片實(shí)例演示

html5 拖拽上傳圖片實(shí)例演示

熱門標(biāo)簽:臨海地圖標(biāo)注app 四川移動電銷外呼客戶管理系統(tǒng) 400開頭的電話好申請不 智能芯電話機(jī)器人 小朱地圖標(biāo)注 咸陽穩(wěn)定外呼系統(tǒng)軟件 百度地圖標(biāo)注為什么總是封號 地圖標(biāo)注柱狀圖 怎么做百度地圖標(biāo)注
因為標(biāo)題寫的是實(shí)例,所以本次就不做講解了,因為這個實(shí)例我也算是東拼西湊整出來的,參考了大概5、6款拖拽上傳的插件和demo,然后把其中好的地方挑出來,最后就成了這么一個實(shí)例,一起來看下吧(地址不能保證長久有效,如果失效請在文章最后點(diǎn)擊demo下載):
 
界面樣式我是參考了一個國外的相冊網(wǎng)站,改動不大,只是把鳥語轉(zhuǎn)換成中文,以及上傳時的樣式也進(jìn)行了改動,之所以選這個的原因就是,我很容易做擴(kuò)展,它支持3種方式添加圖片,一種拖拽上傳,一種常規(guī)的選擇文件上傳,另外的就是添加網(wǎng)絡(luò)圖片。它很巧妙的把三種上傳模式整合到了一起,而且你可以用IE瀏覽器瀏覽下,如果不支持HTML5,是沒有拖拽上傳圖片的提示的,如圖:
 
拖拽上傳最重要的就是js部分的代碼,它實(shí)現(xiàn)了70%的功能,另外30%僅僅是把圖片信息提交到后臺,然后做對應(yīng)的處理,比如壓縮啊,裁剪啊云云。所以先來看下js實(shí)現(xiàn)代碼吧。

復(fù)制代碼
代碼如下:

$().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);
});
//功能實(shí)現(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{
//實(shí)例化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();
}
});

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

復(fù)制代碼
代碼如下:

$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那邊獲取到j(luò)son數(shù)組并處理,至此,操作結(jié)束。
文章最開始提到,還有點(diǎn)擊選擇文件上傳和網(wǎng)絡(luò)圖片,因為這2個不屬于這次的主題范圍內(nèi),就不說了。況且這2個功能實(shí)現(xiàn)起來都不麻煩。
demo下載

標(biāo)簽:南平 公主嶺 陜西 黃石 平頂山 山南 黃石

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html5 拖拽上傳圖片實(shí)例演示》,本文關(guān)鍵詞  html5,拖拽,上傳,圖片,實(shí)例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html5 拖拽上傳圖片實(shí)例演示》相關(guān)的同類信息!
  • 本頁收集關(guān)于html5 拖拽上傳圖片實(shí)例演示的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91麻豆国产香蕉久久精品| 91在线视频免费91| 99久久精品久久久久久清纯| 在线影院国内精品| 久久久99免费| 日韩精品色哟哟| 91成人免费在线| 中文字幕一区二| 国产一区二区三区在线观看免费| 色乱码一区二区三区88| 国产精品网站在线观看| 久久 天天综合| 3d成人h动漫网站入口| 亚洲猫色日本管| 懂色一区二区三区免费观看 | 欧美日韩一区不卡| 国产欧美日韩一区二区三区在线观看 | 亚洲一区二区高清| 不卡一区二区三区四区| 2023国产精华国产精品| 男人的j进女人的j一区| 欧美日韩国产在线播放网站| 亚洲欧美色一区| 99久久久久久| 国产精品国产自产拍高清av| 国产剧情在线观看一区二区| 欧美xxxx在线观看| 日韩影院免费视频| 91麻豆精品国产自产在线观看一区 | 97精品久久久午夜一区二区三区| 精品国产伦一区二区三区观看体验 | 日韩电影在线免费| 欧美精品乱码久久久久久| 亚洲福利电影网| 欧美巨大另类极品videosbest | 日韩免费看网站| 日本三级韩国三级欧美三级| 欧美一区二区三区视频在线| 视频在线在亚洲| 日韩欧美高清一区| 国产一区二区三区四区五区入口| 久久综合久久综合九色| 懂色一区二区三区免费观看| 亚洲日穴在线视频| 一本一道久久a久久精品 | 国产99一区视频免费| 久久精品人人做人人综合| 国产69精品久久777的优势| 日韩一区日韩二区| 日韩女同互慰一区二区| 国产91在线|亚洲| 日韩免费观看高清完整版| 激情综合色综合久久| 精品国产伦一区二区三区观看体验| 国产精一品亚洲二区在线视频| 国产精品久线在线观看| 欧美日韩在线播| 国内成人免费视频| 亚洲女同女同女同女同女同69| 欧美在线观看视频一区二区| 免费成人在线影院| 中文字幕在线观看一区| 欧美色综合网站| 国产一区二区三区电影在线观看| 中文字幕一区日韩精品欧美| 欧美一区午夜精品| 成人黄色电影在线| 日韩中文字幕一区二区三区| 日本一区二区三区免费乱视频 | 日韩视频在线你懂得| 5858s免费视频成人| 久久综合999| 色视频成人在线观看免| 免费观看一级特黄欧美大片| 日韩理论片一区二区| 91精品国产综合久久小美女| av不卡一区二区三区| 日精品一区二区三区| 亚洲天天做日日做天天谢日日欢| 欧美精品日日鲁夜夜添| 99久久婷婷国产综合精品| 美女www一区二区| 亚洲自拍欧美精品| 国产精品嫩草影院com| 日韩一级黄色片| 欧美亚洲尤物久久| 丁香另类激情小说| 精品亚洲免费视频| 亚洲成在人线在线播放| 亚洲免费在线看| 亚洲国产岛国毛片在线| 精品免费视频一区二区| 亚洲午夜视频在线观看| 成人听书哪个软件好| 日韩视频免费观看高清完整版| 不卡的电视剧免费网站有什么| 蜜臀av一区二区| 亚洲成人精品一区| 一区二区三区在线视频观看| 国产精品乱人伦中文| 久久这里都是精品| 精品免费国产一区二区三区四区| 欧美日韩另类一区| 99国产精品久久久久久久久久久| 成人黄动漫网站免费app| 国产成人在线看| 国产精品69毛片高清亚洲| 国产一区二区三区在线观看免费视频 | 久久精品欧美一区二区三区麻豆| 91精品国产91久久久久久最新毛片 | 天天影视网天天综合色在线播放| 亚洲精品伦理在线| 欧美剧在线免费观看网站| 美女诱惑一区二区| 欧美视频一区在线观看| 99re免费视频精品全部| 成人av在线网站| 不卡视频在线观看| 91视频国产资源| 欧美亚洲日本国产| 欧美女孩性生活视频| 欧美一区二区在线播放| 日韩欧美在线1卡| 久久先锋影音av| 亚洲国产精品99久久久久久久久| 国产精品成人免费精品自在线观看| 17c精品麻豆一区二区免费| 中文字幕中文字幕一区| 亚洲制服丝袜av| 日韩国产在线观看一区| 精品一区二区三区在线视频| 国产乱码精品一区二区三区av | 依依成人综合视频| 一区二区成人在线观看| 欧美日韩在线三级| 高清shemale亚洲人妖| 99精品视频在线免费观看| 一本到不卡免费一区二区| 欧美肥胖老妇做爰| 久久久综合激的五月天| 97久久超碰国产精品| 风流少妇一区二区| 一本久久a久久精品亚洲| 69堂精品视频| 久久久久亚洲蜜桃| 亚洲一区二区三区精品在线| 青青青伊人色综合久久| 国产成+人+日韩+欧美+亚洲| 91网页版在线| 日韩美女在线视频| 国产精品免费视频网站| 一区二区三区欧美久久| 日韩精品一区第一页| 91免费小视频| 亚洲综合激情小说| 国产黄色成人av| 欧美日韩成人激情| 国产亚洲美州欧州综合国| 亚洲精品视频在线看| 日本亚洲天堂网| 一本色道久久综合亚洲精品按摩| 日韩一区二区三区电影| 国产精品欧美一区喷水| 美女在线视频一区| 欧美系列一区二区| 综合在线观看色| 国产精品亚洲一区二区三区妖精| 欧美视频中文一区二区三区在线观看| 91精品国产免费久久综合| 亚洲国产精品99久久久久久久久| 午夜精品久久久久久久| 成人av免费网站| 91精品免费在线| 一区二区三区四区在线播放 | 欧美a一区二区| 91色视频在线| 国产精品天美传媒| 精品在线播放午夜| 日韩亚洲欧美在线观看| 亚洲综合一区二区| 色综合久久中文字幕| 国产欧美一区二区精品性色超碰 | 成人av资源网站| 26uuu精品一区二区| 秋霞午夜av一区二区三区| 欧美高清激情brazzers| 亚洲精品国产a久久久久久| 成人免费观看av| 国产精品久久久久一区二区三区共| 精品一区免费av| 欧美va亚洲va香蕉在线| 日本vs亚洲vs韩国一区三区二区| 欧美另类z0zxhd电影| 亚洲一区二区美女| 欧美最猛黑人xxxxx猛交| 一片黄亚洲嫩模| 欧美亚洲综合另类| 丝袜脚交一区二区| 制服丝袜av成人在线看| 久久国内精品视频|