因為標題寫的是實例,所以本次就不做講解了,因為這個實例我也算是東拼西湊整出來的,參考了大概5、6款拖曳上傳的插件和demo,然後把其中好的地方挑出來,最後就成了這麼一個實例,一起來看下吧(地址不能保證長久有效,如果失效請在文章最後點擊demo下載):
界面樣式我是參考了一個國外的相簿網站,改動不大,只是把鳥語轉換成中文,以及上傳時的樣式也進行了改動,之所以選這個的原因就是,我很容易做擴展,它支持3種方式添加圖片,一種拖曳上傳,一種常規的選擇檔案上傳,另外的就是添加網路圖片。它很巧妙的把三種上傳模式整合到了一起,而且你可以用IE瀏覽器瀏覽下,如果不支援HTML5,是沒有拖曳上傳圖片的提示的,如圖:
拖曳上傳最重要的就是js部分的程式碼,它實現了70%的功能,另外30%只是把圖片資訊提交到後台,然後做對應的處理,例如壓縮啊,裁剪啊雲雲。所以先來看下js實作程式碼吧。
$().ready(function().ready(function().ready(function().ready(function().ready(function().ready(function().ready(function().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);
});
//功能實作
$(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('html5 拖曳上傳圖片實例示範_html5教學技巧') === -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();
}
});
開始我是先判斷瀏覽器類型,因為剛才介紹過,不同瀏覽器看到的是不同介面。主要實作程式碼是從「功能實現」開始的,這塊具體為何這樣操作,原理是什麼,我就不多說了,大家可以參考下這篇文章:《人人網首頁拖曳上傳詳解(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('/html5 拖曳上傳圖片實例示範_html5教學技巧/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('html5 拖曳上傳圖片實例示範_html5教學技巧/png', 'html5 拖曳上傳圖片實例示範_html5教學技巧/gif', 'html5 拖曳上傳圖片實例示範_html5教學技巧/jpeg');
if(in_array($_FILES['xfile'] ['type'], $types)){
$source = file_get_contents($_FILES["xfile"]["tmp_name"]);
html5 拖曳上傳圖片實例示範_html5教學技巧resize($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 = '
echo json_encode($ r);
function html5 拖曳上傳圖片實例示範_html5教學技巧resize($source, $destination, $width = 0, $height = 0, $crop = false, $quality = 80) {
$quality = $quality ? $quality : 80;
$html5 拖曳上傳圖片實例示範_html5教學技巧 = html5 拖曳上傳圖片實例示範_html5教學技巧createfromstring($source);
if ($html5 拖曳上傳圖片實例示範_html5教學技巧) {
// Get dimensions
$w = html5 拖曳上傳圖片實例示範_html5教學技巧sx($html5 拖曳上傳圖片實例示範_html5教學技巧);
$h = html5 拖曳上傳圖片實例示範_html5教學技巧sy($html5 拖曳上傳圖片實例示範_html5教學技巧 );
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 $new_height = $width / $ratio;
$new_width = $width;
} else {
$new_width = $heightwidth = $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 = html5 拖曳上傳圖片實例示範_html5教學技巧createtruecolor(round($new_width), round($new_height));
html5 拖曳上傳圖片實例示範_html5教學技巧copyresampled($new, $html5 拖曳上傳圖片實例示範_html5教學技巧, 0, 0, 0, 0, $new_heightth, $new_new. , $w, $h);
// Crop
if ($crop) {
$crop = html5 拖曳上傳圖片實例示範_html5教學技巧createtruecolor($width ? $width : $new_width, $height ? $height : $new_height);
html5 拖曳上傳圖片實例示範_html5教學技巧copyresampled($crop, $new, 0, 0, ($x_mid - ($width * .5)), 0, $width, $height, $width, $height);
//($ y_mid - ($height * .5))
}
// Output
// Enable interlancing [for progressive JPEG]
html5 拖曳上傳圖片實例示範_html5教學技巧interlace($crop ? $crop : $new, true);
$dext = strtolower(pathinfo($destination, PATHINFO_EXTENSION));
if ($dext == '') {
$dext = $ext;
$destination .= '.' . $ ext;
}
switch ($dext) {
case 'jpeg':
case 'jpg':
html5 拖曳上傳圖片實例示範_html5教學技巧jpeg($crop ? $crop : $new, $destination, $quality );
break;
case 'png':
$pngQuality = ($quality - 100) / 11.111111;
$pngQuality = round(abs($pngQuality))
$pngQuality = round(abs($pngQuality)); $crop ? $crop : $new, $destination, $pngQuality);
break;
case 'gif':
html5 拖曳上傳圖片實例示範_html5教學技巧gif($crop ? $crop : $new, $destination);
break;
}
@html5 拖曳上傳圖片實例示範_html5教學技巧destroy($html5 拖曳上傳圖片實例示範_html5教學技巧);
@html5 拖曳上傳圖片實例示範_html5教學技巧destroy($new);
@html5 拖曳上傳圖片實例示範_html5教學技巧destroy($crop);
}
}
PHP最後會回傳一個JSON格式的數組,我回傳的資訊就是圖片位址、名稱,還有段img的html程式碼,最後在js那邊取得到json數組並處理,至此,操作結束。
文章最開始提到,還有點擊選擇檔案上傳和網路圖片,因為這2個不屬於這次的主題範圍內,就不說了。況且這2個功能實現起來都不麻煩。
demo下載

HTML5的關鍵元素包括、、、、、等,用於構建現代網頁。 1.定義頭部內容,2.用於導航鏈接,3.表示獨立文章內容,4.組織頁面內容,5.展示側邊欄內容,6.定義頁腳,這些元素增強了網頁的結構和功能性。

HTML5和H5沒有區別,H5是HTML5的簡稱。 1.HTML5是HTML的第五個版本,增強了網頁的多媒體和交互功能。 2.H5常用於指代基於HTML5的移動網頁或應用,適用於各種移動設備。

HTML5是超文本標記語言的最新版本,由W3C標準化。 HTML5引入了新的語義化標籤、多媒體支持和表單增強,提升了網頁結構、用戶體驗和SEO效果。 HTML5引入了新的語義化標籤,如、、、等,使網頁結構更清晰,SEO效果更好。 HTML5支持多媒體元素和,無需第三方插件,提升了用戶體驗和加載速度。 HTML5增強了表單功能,引入了新的輸入類型如、等,提高了用戶體驗和表單驗證效率。

如何寫出乾淨高效的HTML5代碼?答案是通過語義化標籤、結構化代碼、性能優化和避免常見錯誤。 1.使用語義化標籤如、等,提升代碼可讀性和SEO效果。 2.保持代碼結構化和可讀性,使用適當縮進和註釋。 3.優化性能,通過減少不必要的標籤、使用CDN和壓縮代碼。 4.避免常見錯誤,如標籤未閉合,確保代碼有效性。

H5通過多媒體支持、離線存儲和性能優化提升網頁用戶體驗。 1)多媒體支持:H5的和元素簡化開發,提升用戶體驗。 2)離線存儲:WebStorage和IndexedDB允許離線使用,提升體驗。 3)性能優化:WebWorkers和元素優化性能,減少帶寬消耗。

HTML5代碼由標籤、元素和屬性組成:1.標籤定義內容類型,用尖括號包圍,如。 2.元素由開始標籤、內容和結束標籤組成,如內容。 3.屬性在開始標籤中定義鍵值對,增強功能,如。這些是構建網頁結構的基本單位。

HTML5是構建現代網頁的關鍵技術,提供了許多新元素和功能。 1.HTML5引入了語義化元素如、、等,增強了網頁結構和SEO。 2.支持多媒體元素和,無需插件即可嵌入媒體。 3.表單增強了新輸入類型和驗證屬性,簡化了驗證過程。 4.提供了離線和本地存儲功能,提升了網頁性能和用戶體驗。

H5代碼的最佳實踐包括:1.使用正確的DOCTYPE聲明和字符編碼;2.採用語義化標籤;3.減少HTTP請求;4.使用異步加載;5.優化圖像。這些實踐能提升網頁的效率、可維護性和用戶體驗。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

SublimeText3漢化版
中文版,非常好用