整合營銷服務商

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

          免費咨詢熱線:

          HTML5之實現本地拖放



          html代碼:
          <!DOCTYPE html>
          <html lang="en">
          <head>
          <meta charset="UTF-8">
          <title>本地拖放</title>
          <style>
          #imgContainer{
          background-color: #cccccc;
          width: 500px;
          height: 500px;
          }
          </style>
          </head>
          <body>
          <div id="imgContainer"></div>
          <script src="js/app1.js"></script>
          </body>
          </html> 


          pp1.js 源碼:

          簡介】

          拖放是一種常見的特性, 屬于html5標準的一部分, 即抓取對象以后拖動到另一個位置, 在html5中, 任何元素都可被設置拖放。首先, 我們要給需要拖動的HTML元素啟用拖動功能, 設置屬性draggable="true",

          <div draggable="true"></div>

          提示:a標簽和img標簽默認是啟用該屬性的, 可不需要設置draggable屬性。

          draggable有三個值, 如下所示:

          draggable = true(元素可以被拖動)

          draggable = false(元素不能被拖動)

          draggable = auto(瀏覽器可以自主決定某個元素是否可以被拖動)

          【用法】

          當我們用鼠標拖拽目標元素過程中會觸發的事件:

          ondragstart:用戶按下鼠標開始拖動時觸發

          ondrag:用戶正在拖動時反復觸發

          ondragend:用戶結束拖動后觸發

          <img id="imgs" ondragstart="startFun()" ondrag="ondragFun()" ondragend="ondragendFun()" src="../img/a.png"/>

          當拖動元素進入目標容器內觸發的事件:

          ondragenter:鼠標拖動對象進入釋放區時觸發

          ondragover:被拖動物體進入目標容器內移動時反復觸發

          ondragleave:拖動對象在釋放區沒有釋放就離開容器時觸發

          ondrop:被拖動物體在目標容器內釋放時觸發

          <div id="container" ondragenter="ondragenterFun(event)" ondragover="ondragoverFun(event)" ondragleave="ondragleaveFun()" ondrop="drop()"></div>

          ondragenter和ondragover事件的默認行為是拒絕接受任何被拖放的項目, 所以我們必須要做的最重要的事情就是防止這種默認行為的發生。

          因此, 我們只需要在這兩個事件調用的函數中傳入event對象, 使用event.preventDefault()就可取消這種默認行為;舉個例子, 在drop事件時, Firefox瀏覽器會關閉網頁, 轉而顯示被拖動圖片img元素src所引用的地址。

          取消元素默認行為:

          function ondragenterFun(e){

          e.preventDefault();

          }

          function ondragoverFun(e){

          e.preventDefault();

          }

          在event對象中, 我們會使用dataTransfer屬性來獲取DataTransfer對象, 在DataTransfer對象中有我們操作數據的屬性和方法, 具體如下:

          datatransfer:轉移釋放元素的數據到釋放區, 返回Datatransfer對象

          event.dataTransfer //返回DataTransfer對象

          DataTransfer對象的屬性:

          files:處理從操作系統拖動并釋放到釋放區的文件;

          types:返回一個字符串數組, 該對象包含了dataTransfer對象中數據的所有類型;

          items:返回DataTransferItems對象, 該對象代表了拖動數據;

          dropEffect:設置拖放目標允許發生的拖放行為, 如果此處設置的拖放行為不在effectAllowed屬性設置的可拖放行為內, 拖放操作將會失敗。該屬性值只允許為"null"、"copy"、"link"或"move";

          effectAllowed:設置拖動元素允許發生的拖動行為, 該屬性值可為"none"、"copy"、"copyLink"、"copyMove"、"link"、"linkMove"、"move"、"all"或"uninitialized";

          DataTransfer對象的方法:

          setData( format , data ):將指定格式的數據賦值給dataTransfer對象,參數format定義數據的格式也就是數據的類型,data為待賦值的數據。

          getData( format ):從dataTransfer對象中獲取指定格式的數據,format代表數據格式,data為數據。

          clearData( [format] ):從dataTransfer對象中刪除指定格式的數據,參數可選,若不給參數,將刪除對象中所有的數據。

          setDragImage(el, x, y):設置拖放操作的圖標,其中el代表自定義圖標,x代表圖標與鼠標在水平方向上的距離,y代表圖標與鼠標在垂直方向上的距離。

          了解了H5拖動使用的api以后我們接下來看一個綜合的案例, 功能如下:

          1)、實現圖片拖動功能;

          2)、實現圖片復制功能;

          3)、過濾不能拖動的元素;

          4)、實現拖動本地圖片到瀏覽器指定位置;

          公共css部分:

          <style>

          #dropIn{

          border:1px solid #AAAAAA;

          height:100px;

          margin-bottom: 10px;

          padding: 10px;

          }

          #dropIn>img{

          margin-right: 10px;

          border:2px solid deepskyblue;

          }

          img{

          width:100px;

          border-radius: 10px;

          border:2px solid red;

          }

          </style>

          html部分:

          <body>

          <div id="dropIn"></div> <!--釋放區-->

          <img id="drop1" src="img/a.png" alt="" />

          <!--拖動的圖片元素-->

          </body>

          js部分:

          <script type="text/javascript">
          var darggID;
          function getId(el){
          return document.getElementById(el)
          }
          var dropId1 = getId("drop1");
          var dropInId = getId("dropIn");
          //取消事件默認行為
          dropInId.ondragenter = cancelDefault;
          dropInId.ondragover = cancelDefault; //綁定拖動元素釋放時觸發的事件
          dropInId.ondrop = drop; //綁定
          dropId1.ondragstart = startFun;
          function cancelDefault(ev){ //取消默認行為
          ev.preventDefault();
          }
          function startFun(ev){
          darggID = ev.target.id;
          //獲取被拖動元素的id
          //從源對象上的事件處理中保存數據,數據類型為"Text"
          ev.dataTransfer.setData("Text",darggID);
          }
          function drop(ev){
          ev.preventDefault();
          // 從目標對象上的事件處理中讀取"Text"類型數據
          var data=ev.dataTransfer.getData("Text");
          // 插入到目標對象中
          ev.target.appendChild(document.getElementById(data));
          }
          </script>

          接下來我們添加兩張圖, "drop2"是實現復制的圖片, "drop3"是既不能復制也不能拖動的圖片;

          <img id="drop2" src="img/b.png" alt="" /><img id="drop3" src="img/c.png" alt="" />

          添加js代碼:

          //獲取頁面元素

          var dropId2 = getId("drop2");

          var dropId3 = getId("drop3");

          //綁定事件

          dropId2.ondragstart = startFun;dropId3.ondragstart = startFun;

          //修改drop函數為

          function drop(ev){

          ev.preventDefault();

          // 從目標對象上的事件處理中讀取"Text"類型數據

          var data=ev.dataTransfer.getData("Text");

          if(data=='drop1'){

          //移動

          ev.target.appendChild(document.getElementById(data));

          }

          if(data=='drop2'){//復制

          var nreEl=document.getElementById(darggID).cloneNode(false);

          getId("dropIn").appendChild(nreEl);

          }

          if(data=='drop3'){//過濾drop3,drop3不做任何操作

          alert('過濾drop3')

          }

          }

          接下來我們實現拖動本地圖片到瀏覽器, 我們就將圖片拖動到id為"dropIn"的這個div中;添加js:

          /*document 監聽drop 并阻止瀏覽器打開客戶端的圖片*/

          document.ondragover = function (e) {

          //只有在ondragover中阻止默認行為

          e.preventDefault();

          };

          document.ondrop = function (e) {

          //阻止 document.ondrop的默認行為

          e.preventDefault();

          };

          //dropIn是div的id

          dropIn.ondrop = function (e) {

          var list = e.dataTransfer.files;

          for (var i = 0; i < list.length; i++) {

          var f = list[i];

          reader(f);

          }

          };

          function reader(f) {

          var reader = new FileReader();

          //讀取數據

          reader.readAsDataURL(f);

          reader.onload = function () {

          var img = new Image();

          img.src = reader.result;

          dropIn.appendChild(img);

          }

          }

          【瀏覽器支持】

          目前只有Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari5支持拖放,在 Safari5.1.2 中不支持拖放。

          最后再和大家分享一個技巧, 這種拖動行為還能跨瀏覽器工作, 這里說的跨瀏覽器不是瀏覽器之間的跨窗口, 而是可以從Chrome瀏覽器拖動到Firefox瀏覽器, 因為拖放功能的支持是集成在操作系統里面的, 有著相同的特性。

          文由ScriptEcho平臺提供技術支持

          項目地址:傳送門

          Vue 中使用 InMap 創建動態軌跡地圖

          應用場景介紹

          動態軌跡地圖廣泛應用于物流追蹤、車輛管理、人員定位等場景,可直觀展示移動對象的歷史軌跡和實時位置。本代碼示例展示了如何使用 Vue 框架和 InMap 庫創建一個動態軌跡地圖,實現軌跡展示、實時更新和交互功能。

          代碼基本功能介紹

          該代碼的主要功能包括:

          • 加載 InMap 庫并創建地圖實例
          • 從外部數據源加載軌跡數據
          • 創建軌跡線覆蓋物并添加到地圖
          • 設置軌跡線樣式和交互事件
          • 實時更新軌跡數據,反映移動對象的最新位置

          功能實現步驟及關鍵代碼分析

          1. 加載 InMap 庫和創建地圖實例

          onMounted(async () => {
            let jsUrls = [
              'https://api.map.baidu.com/getscript?v=2.0&ak=cxtWZ9zGiLlLdQwBSuGGwpanwqfaLvEc&services=&t=20240108120844',
              'https://registry.npmmirror.com/inmap/2.3.3/files/dist/inmap.min.js',
            ]
            await Promise.all(jsUrls.map((js) => loadJavascript(js)))
          
          

          var map = new inMap.Map({
          id: 'allmap',
          skin: 'Blueness',
          center: [-22.053354, 27.353393],
          zoom: {
          value: 3,
          show: true,
          max: 22,
          min: 3,
          },
          })
          })

          此代碼塊負責加載 InMap 庫和創建地圖實例。首先,異步加載必要的 JavaScript 文件。然后,使用 inMap.Map 構造函數創建地圖實例,并指定地圖容器 ID、皮膚、中心點和縮放級別等參數。

          2. 加載軌跡數據

          var overlay = new inMap.LineStringOverlay({
            data: data.map(function (item, index) {
              item.name = '軌跡' + index
              item.count = index
              return item
            }),
          })
          

          此代碼塊加載外部軌跡數據并將其添加到地圖中。它使用 inMap.LineStringOverlay 構造函數創建一個軌跡線覆蓋物,并傳入軌跡數據。軌跡數據以數組形式提供,每個元素包含軌跡點的經度、緯度和時間戳等信息。

          3. 設置軌跡線樣式和交互事件

          overlay.setStyle({
            normal: {
              borderColor: 'rgba(255, 250, 50, 0.3)',
              borderWidth: 0.7,
              shadowColor: 'rgba(255, 250, 50, 1)',
              shadowBlur: 20,
            },
          })
          

          此代碼塊設置軌跡線的樣式,包括邊框顏色、寬度、陰影顏色和模糊度。

          overlay.setEvent({
            onState(state) {
              console.log(state)
            },
          })
          

          此代碼塊設置軌跡線的交互事件。當用戶懸停、單擊或拖動軌跡線時,會觸發 onState 事件,并將當前狀態輸出到控制臺。

          4. 實時更新軌跡數據

          // 假設您有實時更新軌跡數據的邏輯
          // 在此示例中,我們模擬通過 WebSocket 接收數據
          let socket = new WebSocket('ws://localhost:8080')
          socket.onmessage = (event) => {
            let newData = JSON.parse(event.data)
            overlay.setData(newData)
          }
          

          此代碼塊演示了如何實時更新軌跡數據。它模擬了一個 WebSocket 連接,用于接收更新后的軌跡數據。當收到新數據時,它會使用 setData 方法更新軌跡線覆蓋物的軌跡數據。

          總結與展望

          開發這段代碼的過程讓我深入了解了 Vue 中使用 InMap 創建動態軌跡地圖的技術。通過分析關鍵代碼,我掌握了加載 InMap 庫、創建地圖實例、加載軌跡數據、設置軌跡線樣式和交互事件以及實時更新軌跡數據的步驟。

          未來,該卡片功能可以進一步拓展和優化,例如:

          • 集成更多數據源,支持從多種來源加載軌跡數據
          • 優化數據處理和更新算法,提高實時性的同時降低內存消耗
          • 添加更多交互功能,例如軌跡回放、軌跡分析和導出
          • 更多組件:

          獲取更多Echos

          本文由ScriptEcho平臺提供技術支持

          項目地址:傳送門

          微信搜索ScriptEcho了解更多


          主站蜘蛛池模板: 少妇精品无码一区二区三区| 日韩美一区二区三区| 亚洲国产激情在线一区| 国产精品制服丝袜一区| 精品一区二区三区在线播放 | 久久久久无码国产精品一区 | 久久国产一区二区| 天堂一区二区三区精品| 精品无码综合一区| 日本一区二区三区日本免费| 久久久综合亚洲色一区二区三区| 无码AⅤ精品一区二区三区| 玩弄放荡人妻一区二区三区| 国产精品一区二区av| 一区二区免费在线观看| 国产精品一区二区久久精品涩爱| 日本一区二区三区高清| 一级毛片完整版免费播放一区| 在线成人一区二区| 精品一区二区三区免费毛片爱 | 国产亚洲日韩一区二区三区 | 精品国产毛片一区二区无码| 成人免费视频一区二区三区 | 亚洲国产成人久久综合一区77| 欧美日韩国产免费一区二区三区| 无码人妻精品一区二区三区夜夜嗨| 国产精品 视频一区 二区三区| 日韩精品一区二区午夜成人版| 午夜AV内射一区二区三区红桃视| 亚洲视频一区二区在线观看| 久久精品国产一区二区三区肥胖| 91麻豆精品国产自产在线观看一区 | 亚洲色无码一区二区三区| 一区二区三区在线免费 | 精品久久久中文字幕一区| 在线播放偷拍一区精品| 无码少妇丰满熟妇一区二区| 日韩中文字幕精品免费一区| 中文字幕一区日韩精品| 久久久久久人妻一区二区三区| 中文激情在线一区二区|