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ù)制代碼 代碼如下:www.wf0088.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ù)制代碼 代碼如下:www.wf0088.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教程