Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 国产午夜精品一区二区三区不卡 ,亚洲国产精品热久久,国产中文字幕视频

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          JavaScript 文件拖拽上傳

          件拖拽上傳

          使用HTML5的文件API, 可以將操作系統中的文件拖放到瀏覽器的指定區域, 實現文件上傳到服務器。本文將結合實例講解HTML5+jQuery+PHP實現拖拽上傳圖片的過程, 來看下HTML5的魅力吧。

          HTML

          我們在頁面中放置一個拖拽區域#drop_area, 即接收拖拽的區域, #preview用來預覽拖拽上傳的圖片信息。

          <div id="drop_area">將圖片拖拽到此區域</div>
          <div id="preview"></div>

          Javascript

          要想實現拖拽, 頁面需要阻止瀏覽器默認行為, 即四個事件(拖離、拖后放、拖進、拖來拖去), 因為我們要阻止瀏覽器默認將圖片打開的行為, 這里我們使用jQuery來完成。

          $(function(){
          //阻止瀏覽器默認行。
          $(document).on({
              dragleave:function(e){ //拖離
              e.preventDefault();
          },
          drop:function(e){ //拖后放
              e.preventDefault();
          },
          dragenter:function(e){ //拖進
              e.preventDefault();
          },
          dragover:function(e){ //拖來拖去
              e.preventDefault();
          }
          });
          ...
          });

          接下來我們來了解下文件API。HTML5的文件API有一個FileList接口, 它可以通過e.dataTransfer.files拖拽事件傳遞的文件信息, 獲取本地文件列表信息

          var fileList = e.dataTransfer.files;

          在本例中, 我們用javascript來偵聽drop事件, 首先要判斷拖入的文件是否符合要求, 包括圖片類型、大小等, 然后獲取本地圖片信息, 實現預覽, 最后上傳。

          $(function(){
          /// ...接上部分
          var box = document.getElementById('drop_area'); //拖拽區域
          box.addEventListener("drop",function(e){
          e.preventDefault(); //取消默認瀏覽器拖拽效果
          var fileList = e.dataTransfer.files; //獲取文件對象
          //檢測是否是拖拽文件到頁面的操作
          if(fileList.length == 0){
              return false;
          }
          //檢測文件是不是圖片
          if(fileList[0].type.indexOf('image') === -1){
          alert("您拖的不是圖片!");
          return false;
          }
          
          //拖拉圖片到瀏覽器,可以實現預覽功能
          var img = window.URL.createObjectURL(fileList[0]);
          var filename = fileList[0].name; //圖片名稱
          var filesize = Math.floor((fileList[0].size)/1024);
          if(filesize>500){
          alert("上傳大小不能超過500K.");
          return false;
          }
          var str = "<img src='"+img+"'><p>圖片名稱:"+filename+"</p><p>大小:"+filesize+"KB</p>";
          $("#preview").html(str);
          
          //上傳
          xhr = new XMLHttpRequest();
          xhr.open("post", "upload.php", true);
          xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
          
          var fd = new FormData();
          fd.append('mypic', fileList[0]);
          
          xhr.send(fd);
          },false);
          });

          我們用FormData模擬表單數據, 直接將數據append到formdata對象中, 實現了ajax上傳。

          PHP

          upload.php用于接收上傳的文件信息, 完成上傳, 實現代碼如下:

          <?php
          $mypic = $_FILES["mypic"];
          if(!empty($mypic)){
          $picname = $_FILES['mypic']['name'];
          $picsize = $_FILES['mypic']['size'];
          if ($picsize > 512000) {
          echo '圖片大小不能超過500k';
          exit;
          }
          $type = strstr($picname, '.');
          if ($type != ".gif" && $type != ".jpg") {
          echo '圖片格式不對!';
          exit;
          }
          $pics = 'helloweba' . $type;
          //上傳路徑
          $pic_path = "pics/". $pics;
          move_uploaded_file($mypic["tmp_name"],$pic_path);
          }
          ?>

          下邊這幾句可以沒有

          <meta charset="utf-8">
          <form action="" method="post" enctype="multipart/form-data">
          <input type="file" name="mypic">
          <input type="submit" value="上傳">
          </form>

          最后總結下HTML5實現拖拽上傳的技術要點:

          1、監聽拖拽:監聽頁面元素的拖拽事件, 包括:dragenter、dragover、dragleave和drop, 一定要將dragover的默認事件取消掉, 不然無法觸發drop事件。如需拖拽頁面里的元素, 需要給其添加屬性draggable=”true”;

          2、獲取拖拽文件:在drop事件觸發后通過e.dataTransfer.files獲取拖拽文件列表, .length屬性獲取文件數量, .type屬性獲取文件類型。

          3、讀取圖片數據并添加預覽圖。

          4、發送圖片數據:使用FormData模擬表單數據AJAX提交文件流。

          實現炫酷的的拖行拖拽

          1.需求分析:設計一個元素,可以跟隨鼠標的移動,元素也進行移動,并且能夠在鼠標按上與按下元素的時候,元素可以進行改變樣式顏色。

          2. 設計思路:先是需要獲取元素,給元素綁定鼠標按下的事件,在綁定的事件中,兼容event事件,獲取鼠標的坐標和元素的坐標,通過鼠標的坐標減去元素的坐標就可以得到鼠標在元素中的坐標。在綁定事件中,寫上一個元素的移動事件,獲取元素的移動坐標。最后,在鼠標按上的事件函數中,可以調用元素的移動事件就可以了。

          <!DOCTYPE html>
          <html lang="en">
          <head>
           <meta charset="UTF-8">
           <title>圖層拖拽</title>
           <style>
           .box {
           width: 200px;
           height: 200px;
           background-color: skyblue;
           border: 2px solid #ccc;
           cursor: pointer;
           position: absolute;
           top: 20px;
           left: 100px;
           }
           </style>
          </head>
          <body>
          <div class="box" id="box"></div>
          </body>
          <script>
           var box = document.getElementById("box");
           box.onmousedown = function(env){
           // 兼容event事件
           var env = env || window.event;
           // 獲取鼠標的坐標
           var x = env.clientX;
           var y = env.clientY;
           // 獲取元素的坐標
           var left = box.offsetLeft;
           var top = box.offsetTop;
           // 獲取鼠標在元素中的坐標
           var x_left = x - left;
           var y_top = y -top;
           // 鼠標點擊后改變顏色
           box.style.background = "red";
           // 元素的移動事件函數
           box.onmousemove = function(env){
           // 兼容event事件
           var env = env || window.event;
           // 獲取元素移動時的鼠標的坐標
           var x = env.clientX;
           var y = env.clientY;
           // 元素的移動坐標
           box.style.left = (x - x_left)+"px";
           box.style.top = (y - y_top)+"px";
           }
           };
           // 鼠標彈出的事件函數
           box.onmouseup = function(){
           box.style.background = "skyblue";
           // 在鼠標彈出后再次調用元素的鼠標移動事件
           box.onmousemove = function(){};
           };
          </script>
          </html>
          

          學習從來不是一個人的事情,要有個相互監督的伙伴,想要學習或交流前端問題的小伙伴可以私信回復小明“學習” 獲取資料,一起學習!

          什么是拖拽?

          本質上來說就是一個對象和一個對象直接傳遞。

          其實學習拖拽,就是學習拖拽事件。

          ⒉在HTML5中很多元素是不能進行拖拽的,比如說圖片和超鏈接:

          在試圖拖拽時你會發現一個禁止的符號,如果想拖拽元素,就必須為元素添加draggable="true"。

          ⒊相關的事件

          應用于被拖拽元素的事件

          ondrag 應用于拖拽元素,整個拖拽過程都會調用--持續

          ondragstart 應用于拖拽元素,當拖拽開始時調用

          ondragleave 應用于拖拽元素,當鼠標離開拖拽元素時調用

          ondragend 應用于拖拽元素,當拖拽結束時調用

          應用于目標元素的事件

          ondragenter 應用于目標元素,當拖拽元素進入時調用

          ondragover 應用于目標元素,當停留在目標元素上時調用

          ondrop 應用于目標元素,當在目標元素上松開鼠標時調用

          ondragleave 應用于目標元素,當鼠標離開目標元素時調用

          案例:





          注意:如果想觸發ondrop事件,那么就必須在ondragover事件中阻止瀏覽器的默認行為。

          來源網絡,侵權聯系刪除

          私信我或關注微信號:猿來如此呀,回復:學習,獲取免費學習資源包。


          主站蜘蛛池模板: 黑巨人与欧美精品一区| 亚洲国产综合无码一区二区二三区| 亚洲欧洲日韩国产一区二区三区| 91午夜精品亚洲一区二区三区| 成人免费视频一区| AV怡红院一区二区三区| 亚洲国产系列一区二区三区| 亚洲国产成人一区二区精品区 | 国产亚洲综合一区二区三区| 无码aⅴ精品一区二区三区浪潮 | 国产一区二区不卡在线播放| 国产精品盗摄一区二区在线| 亚洲一区二区三区无码国产| 成人精品视频一区二区三区不卡 | chinese国产一区二区| 国产精品香蕉一区二区三区| 亚洲高清一区二区三区| 麻豆高清免费国产一区| 日韩精品无码免费一区二区三区 | 精品一区二区三区影院在线午夜| 日本片免费观看一区二区| 无码国产伦一区二区三区视频 | 免费看一区二区三区四区| 欲色影视天天一区二区三区色香欲| 多人伦精品一区二区三区视频| 无码aⅴ精品一区二区三区| 冲田杏梨AV一区二区三区| 无码人妻精品一区二区三区9厂| 日韩一区二区三区不卡视频| 日韩精品久久一区二区三区| 麻豆精品一区二区综合av| 国产精品免费大片一区二区| 国产精品毛片a∨一区二区三区 | 亚洲一区二区三区四区在线观看| 日本中文字幕一区二区有码在线| 无码视频一区二区三区在线观看 | 国产精品美女一区二区| 亚洲福利精品一区二区三区| 亚洲乱码日产一区三区| 久久精品亚洲一区二区三区浴池| 99精品国产高清一区二区麻豆|