欧美三区四区_av先锋影音资源站_亚洲第一论坛sis_影音先锋2020色资源网_亚洲精品社区_在线免费观看av网站_国产一区二区伦理_亚洲欧美视频一区二区_99视频精品全部免费在线_精精国产xxxx视频在线

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

編輯Tag賺U幣

推薦:突襲HTML5之Javascript API擴(kuò)展2—地理信息服務(wù)及地理位置API學(xué)習(xí)
在HTML5中,加入了新的地理位置API用來確定和分享地理位置。這一類服務(wù)就是企業(yè)利用某點(diǎn)(例如用戶所在的位置)坐標(biāo)附近的區(qū)域提供服務(wù)的信息,比如常見的地圖相關(guān)服務(wù),本文詳細(xì)介紹下,感興趣的朋友可以了解下,或許對(duì)你有所幫助

因?yàn)闃?biāo)題寫的是實(shí)例,所以本次就不做講解了,因?yàn)檫@個(gè)實(shí)例我也算是東拼西湊整出來的,參考了大概5、6款拖拽上傳的插件和demo,然后把其中好的地方挑出來,最后就成了這么一個(gè)實(shí)例,一起來看下吧(地址不能保證長久有效,如果失效請(qǐng)?jiān)谖恼伦詈簏c(diǎn)擊demo下載):
 
界面樣式我是參考了一個(gè)國外的相冊(cè)網(wǎng)站,改動(dòng)不大,只是把鳥語轉(zhuǎn)換成中文,以及上傳時(shí)的樣式也進(jìn)行了改動(dòng),之所以選這個(gè)的原因就是,我很容易做擴(kuò)展,它支持3種方式添加圖片,一種拖拽上傳,一種常規(guī)的選擇文件上傳,另外的就是添加網(wǎng)絡(luò)圖片。它很巧妙的把三種上傳模式整合到了一起,而且你可以用IE瀏覽器瀏覽下,如果不支持HTML5,是沒有拖拽上傳圖片的提示的,如圖:
 
拖拽上傳最重要的就是js部分的代碼,它實(shí)現(xiàn)了70%的功能,另外30%僅僅是把圖片信息提交到后臺(tái),然后做對(duì)應(yīng)的處理,比如壓縮啊,裁剪啊云云。所以先來看下js實(shí)現(xiàn)代碼吧。

復(fù)制代碼 代碼如下:m.ghpqjb.com

$().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');
//檢測(cè)是否是拖拽文件到頁面的操作
if(fileList.length == 0){
$('.dashboard_target_box').removeClass('over');
return;
}
//檢測(cè)文件是不是圖片
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對(duì)象
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();
}
});

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

復(fù)制代碼 代碼如下:m.ghpqjb.com

$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最終會(huì)返回一個(gè)JSON格式的數(shù)組,我返回的信息就是圖片地址、名稱,還有段img的html代碼,最后在js那邊獲取到j(luò)son數(shù)組并處理,至此,操作結(jié)束。
文章最開始提到,還有點(diǎn)擊選擇文件上傳和網(wǎng)絡(luò)圖片,因?yàn)檫@2個(gè)不屬于這次的主題范圍內(nèi),就不說了。況且這2個(gè)功能實(shí)現(xiàn)起來都不麻煩。
demo下載

分享:html5新增的屬性和廢除的屬性簡要概述
HTML5中,在新增加和廢除很多元素的同時(shí),也增加和廢除了很多屬性比如表單相關(guān)的屬性/鏈接相關(guān)屬性是新增的而HTML4中一些屬性就被廢除掉了,感興趣的你可以了解下,或許對(duì)你學(xué)習(xí)html5有所幫助

來源:未知//所屬分類:HTML5教程/更新時(shí)間:2013-04-22
相關(guān)HTML5教程
www.色就是色| 欧美一区二区三区免费视| 一区二区免费电影| 欧美色图亚洲天堂| 一区二区美女| 亚洲国产精品精华液ab| 久久中文字幕在线| 一区二区传媒有限公司| 亚洲精品一区二区二区| 日韩精品电影一区二区三区| 男人添女人荫蒂国产| 香蕉视频成人在线| 久久99精品国产| 精品国产免费视频| 欧美黑人xxxxx| 国产黄色小视频网站| 亚洲国产欧美日韩在线观看第一区| 久久久久88色偷偷免费| 免费av一区二区| 国产裸体舞一区二区三区| 97免费观看视频| 亚洲一区黄色| 欧美一区二区在线不卡| 欧美极品色图| 国产亚洲精品av| 欧美激情理论| 日韩欧美精品网址| 91大片在线观看| 久久视频一区二区三区| 久久精品国产亚洲5555| 国产精品久久久久久久久果冻传媒| 午夜精品久久久久久99热软件 | 红桃视频国产一区| 欧美亚洲一区二区在线观看| 国产一区喷水| 农村黄色一级片| 日韩一区二区中文| 色综合久久久久网| 国产另类第一区| 男人的天堂久久久| 999精品色在线播放| 91成人在线观看喷潮| 国产精品手机视频| 久久久久久久久久91| 91超碰成人| 欧美日韩一区二区三区不卡| 久久99精品久久久久久秒播放器 | 亚洲一区二区精品| 国产在线精品91| 性色av蜜臀av| 国产福利视频一区二区三区| 日韩在线观看精品| 中文字幕 91| 日韩黄色三级在线观看| 国产精品久久久久婷婷| 国产成人一区三区| 免费福利视频网站| 九九免费精品视频在线观看| 精品日韩视频在线观看| 国内视频一区二区| 中文字幕在线观看免费视频| 亚洲国产高清视频| 亚洲福利在线观看| 无码人妻丰满熟妇区96| 亚洲av成人精品日韩在线播放| av在线不卡免费看| 欧美亚洲国产视频| 欧美特黄一区二区三区| 成人3d精品动漫精品一二三| 欧美色爱综合网| 中文字幕中文字幕99| 国产精品探花视频| 粉嫩av一区二区三区粉嫩| 色综合视频网站| 在线观看亚洲免费视频| 欧美一区自拍| 日韩欧美在线播放| 小说区图片区图片区另类灬| 一道本无吗一区| 国产尤物一区二区| 高清一区二区三区日本久| 日韩片在线观看| 第一会所sis001亚洲| 欧美二区在线观看| 国产精品又粗又长| 国产98色在线|日韩| 麻豆久久一区二区| 久久精品最新地址| 国产伦理在线观看| 西野翔中文久久精品字幕| 色婷婷精品久久二区二区蜜臀av| 日韩在线电影一区| 国产av一区二区三区| 91在线码无精品| 国产精品黄页免费高清在线观看| 久草手机视频在线观看| 精品动漫3d一区二区三区免费版| 国产视频久久网| 国产亚洲视频一区| 蜜臀av一区| 欧美日韩在线三级| 久久久久久www| 日韩毛片一区| 亚洲一区二区黄色| 日本不卡免费新一二三区| 国产精品成熟老女人| 看欧美ab黄色大片视频免费| 精品麻豆剧传媒av国产九九九| 亚洲午夜激情网页| 日韩欧美一区二区视频在线播放| 国内精品国产成人国产三级| 91性感美女视频| 亚洲自拍另类欧美丝袜| 加勒比在线一区| 国产不卡在线视频| 国产精品美女www爽爽爽视频| 欧美被狂躁喷白浆精品| 蜜臀精品一区二区三区在线观看| 久久久久久久久久久人体 | 国产女主播在线一区二区| 成人激情直播| 欧美 亚洲 另类 激情 另类| 成人激情黄色小说| 成人国产亚洲精品a区天堂华泰| 中国一级免费毛片| 国产风韵犹存在线视精品| 国产精品久久久久9999| 91视频免费网址| 国产精品538一区二区在线| 国产精品国产三级国产专播精品人 | 4438成人网| 91av在线免费播放| 久久午夜影院| 精品久久久久久最新网址| 亚洲一区精品视频在线观看| 欧美亚洲精品在线| 国产香蕉一区二区三区在线视频 | 久久久久久久片| 亚洲制服一区| 亚洲成人黄色网址| 国产在线观看免费播放| 中文不卡在线| 久久精品国产亚洲精品| 毛片久久久久久| 免费精品99久久国产综合精品| 日本成人免费在线| 人妻 日韩精品 中文字幕| av亚洲精华国产精华| 懂色av一区二区三区在线播放| 亚洲一区在线观| 国产精品久久久久久久久果冻传媒| 欧美精品七区| 韩国女主播一区二区| 欧美性黄网官网| 已婚少妇美妙人妻系列| 欧美激情在线精品一区二区三区| 亚洲精品一区二三区不卡| 国产成人精品无码片区在线| 国产精品老牛| 国产成人av在线播放| 老熟妇仑乱一区二区av| 久久久精品黄色| 日韩啊v在线| 不卡亚洲精品| 欧美精品丝袜久久久中文字幕| 日韩高清第一页| 久久久久久美女精品| 精品成人18| 欧美日韩午夜剧场| avav在线看| 欧美色图一区| 色av中文字幕一区| 青青操在线视频观看| 国产在线视频一区二区| 97碰碰视频| 天天射天天色天天干| 一本色道综合亚洲| 精品亚洲一区二区三区四区| 亚洲国产一区二区在线观看| 欧美日韩xxx| 久久青青草视频| 国产精品区一区二区三区| 在线视频91| 久久a级毛片毛片免费观看| 亚洲视频在线观看| 暗呦丨小u女国产精品| 国产成人自拍在线| 好看的日韩精品视频在线| 欧美色999| 日韩欧美一级特黄在线播放| 99热超碰在线| 男男视频亚洲欧美| 高清不卡日本v二区在线| 午夜成人免费影院| 欧美日韩一区在线观看| 日本少妇一区二区三区| 中文精品在线| 国产色视频一区| 国产自产一区二区| 欧美性猛片xxxx免费看久爱| 成人免费黄色av| 久久午夜电影| 91精品国产综合久久久久久丝袜| 五月色婷婷综合| 91麻豆精品国产91久久久更新时间 | 激情综合网av| 欧美日韩免费精品| 一区二区免费| 一个人www欧美| 日韩欧美a级片| 亚洲欧美激情小说另类| 免费av网址在线| 国内精品久久久久久久影视蜜臀| 国产精品va在线播放| 亚洲成人中文字幕在线| 欧美日韩国产一区| 亚洲天堂网一区二区| 国产精品91一区二区| 日韩欧美视频一区二区三区四区| 综合中文字幕| www.亚洲一区| 岛国av中文字幕| 黄色精品一区二区| 激情av中文字幕| 狠狠色伊人亚洲综合成人| 欧美一区二区三区在线免费观看| 亚洲综合色婷婷在线观看| 丝袜亚洲另类欧美重口| 在线观看日韩中文字幕| 亚洲午夜久久久久久久久电影网 | 亚州国产精品| 欧美激情一级精品国产| 国产精品视频一区二区三区,| 欧洲精品在线观看| 99久久人妻无码中文字幕系列| 国产精品91xxx| 亚洲免费av网| 99国产**精品****| 国产精品视频区1| h1515四虎成人| 中文字幕精品av| 丁香社区五月天| 在线看国产一区| 国产熟妇搡bbbb搡bbbb| 97久久精品人人做人人爽50路| 搞av.com| 在线精品福利| 国产在线播放一区二区| 国产乱人伦丫前精品视频| 欧美精品福利在线| 好吊色一区二区三区| 精品福利一二区| 日本天堂网在线观看| 亚洲成人av一区| 男女性杂交内射妇女bbwxz| 成人高清在线视频| 91免费视频网站在线观看| 99综合精品| 欧美日韩三区四区| 日韩精品一区二区三区免费观影| 国产精品尤物福利片在线观看| 四虎视频在线精品免费网址| 久久在线免费观看视频| av小说天堂网| 精品日产卡一卡二卡麻豆| 久久亚洲成人av| 欧美日韩国产中文字幕 | 亚洲丁香婷深爱综合| 日韩精品国产一区二区| 欧美色另类天堂2015| 久久久视频6r| 综合亚洲深深色噜噜狠狠网站| 亚洲第一成肉网| 国产麻豆精品久久一二三| 精品视频在线观看一区二区| 在线综合亚洲| 亚洲mv在线看| 国产精品第十页| 免费国产在线精品一区二区三区| 国产99久久| 91九色国产社区在线观看| 国产成人福利av| 日韩男女性生活视频| 久久精品资源| 欧美高跟鞋交xxxxhd| 欧美性xxx| 久久伊人色综合| 国产精品迅雷| 久久亚洲精品网站| 日本黄色一区二区三区| 在线国产精品播放| 国产wwwwwww| 亚洲日本欧美日韩高观看| 一级片在线免费观看视频| 亚洲电影在线看| 一本色道久久综合精品婷婷| 亚洲第一精品久久忘忧草社区| 日本黄色一级视频| 精品三级av在线| 中文字幕在线观看欧美| 亚洲激情视频在线播放| 一区二区 亚洲| 日韩精品日韩在线观看| 91九色蝌蚪91por成人| 日韩av一区二区在线| 国产一区二区在线不卡| 日韩精品中文字幕在线播放| 91欧美日韩麻豆精品| 亚洲人a成www在线影院| 亚洲第一精品网站| 日韩视频第一页| 免费电影日韩网站| 欧美激情影音先锋| 99er精品视频| 日产精品99久久久久久| 国产精品毛片av| 91老司机精品视频| 成人羞羞视频在线看网址| 国产在线一区二区三区四区 | 国产一区二区中文字幕免费看| 日本在线电影一区二区三区| 国产自产精品| 国内视频精品| 欧美交换配乱吟粗大25p| 美女脱光内衣内裤视频久久网站| 国产成人精品视频免费看| 成人亚洲一区二区一| 91av视频免费观看| 国产精品免费视频网站| 3d动漫精品啪啪一区二区下载 | 国产91美女视频| 风间由美一区二区三区在线观看| 亚洲欧美日韩精品一区| 国产日韩成人精品| 男女黄床上色视频| 黑丝美女久久久| 中文字幕一区二区三区精品 | 99久久国产综合精品女不卡| 天天爽夜夜爽视频| 亚洲色图在线看| 青青青手机在线视频| 欧美色国产精品| 少妇又紧又色又爽又刺激视频| 亚洲欧美中文字幕在线一区| 亚洲人妻一区二区三区| 欧美亚洲另类在线| 亚洲老女人视频免费| 欧美午夜视频在线| 久久久久久久波多野高潮日日| 黄色免费福利视频| 99re热视频精品| 国产美女精品久久| 在线观看网站黄不卡| 中文字幕在线观看视频免费| 国产亚洲一区二区在线| 性感美女一区二区在线观看| 日本不卡免费高清视频| 欧美在线免费看视频| 亚洲午夜激情| 国产曰批免费观看久久久| 一本之道在线视频| 亚洲一区二区成人在线观看| 国产第一页在线播放| 亚洲精品国产精品国产自| 国产精品av一区二区三区| 国产精品第2页| 国产韩国精品一区二区三区| 黄色一级片av| 成人av在线播放网站| 三级黄色片网站| 欧美日韩中文精品| 国产精品一区二区人人爽| 欧美第一淫aaasss性| 伊人久久大香线蕉综合网站| 日韩理论片在线观看| 国产伦精品一区二区三区免费| 精品伦一区二区三区| 色94色欧美sute亚洲13| 国产有码在线观看| 97人人做人人爱| 日韩精品一卡| a级免费在线观看| 国产亚洲欧美日韩日本| 人与动物性xxxx| 亚洲成人激情在线| 日本高清不卡一区二区三区视频 | 秋霞综合在线视频| 亚洲精品日韩在线观看| 国产1区2区3区精品美女| 蜜桃av免费看| 日韩欧美国产三级| av有声小说一区二区三区| 亚洲va电影大全| 久久久久久亚洲精品杨幂换脸| 免费成年人高清视频| 岛国av一区二区| 91精品网站| 超碰97久久国产精品牛牛| 欧美精品国产精品久久久| 国产一区二区不卡老阿姨|