亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        HTML5+CSS3實現(xiàn)拖放(Drag and Drop)示例

        字號:


            本文簡單介紹一下HTML5的拖放實現(xiàn)。
            拖放(Drag 和 drop)是 HTML5 標準的組成部分。
            瀏覽器支持:Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。
            被拖元素,dragElement :
            (1)添加事件:ondragstart
            (2)添加屬性:dragable
            放置元素,dropElement:
            1、添加事件:ondargenter , ondragover , ondragleave , ondragend ,ondrop
            和mouser劃入劃出一類的事件很類似,字面也很好理解,不贅述了,下面會用例子來說明。
            2、頁面上元素間的拖放
            下面用個小例子,div間的拖放來展示,各個事件如何被觸發(fā):
            復制代碼代碼如下:<html>
            <title></title>
            <meta charset="utf-8">
            <style type="text/css">
            #dropEle
            div
            {
            float: left;
            }
            </style>
            <script src="./js/jquery-1.8.3.js" type="text/javascript" charset="utf-8"></script>
            <script type="text/javascript">
            /**
            * 拖放(Drag 和 drop)是 HTML5 標準的組成部分。
            * 瀏覽器支持
            *Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。
            */
            $(function ()
            {
            $("#dragEle")[0].ondragstart = function (event)
            {
            console.log("dragStart");
            event.dataTransfer.setData("Text", event.target.id);
            };
            /**
            * 當放置被拖數(shù)據時,會發(fā)生 drop 事件。
            * 調用 preventDefault() 來避免瀏覽器對數(shù)據的默認處理(drop 事件的默認行為是以鏈接形式打開)
            * @param event
            */
            $("#dropEle")[0].ondrop = function (event)
            {
            /* for (var p in event.dataTransfer)
            {
            console.log(p + " = " + event.dataTransfer[p] + " @@");
            }
            */
            console.log("onDrop");
            var id = event.dataTransfer.getData("Text");
            $(this).append($("#" + id).clone().text($(this).find("div").length));
            event.preventDefault();
            };
            /**
            * ondragover 事件規(guī)定在何處放置被拖動的數(shù)據。
            *默認地,無法將數(shù)據/元素放置到其他元素中。如果需要設置允許放置,我們必須阻止對元素的默認處理方式。
            */
            $("#dropEle")[0].ondragover = function (event)
            {
            console.log("onDrop over");
            event.preventDefault();
            }
            $("#dropEle")[0].ondragenter = function (event)
            {
            console.log("onDrop enter");
            }
            $("#dropEle")[0].ondragleave = function (event)
            {
            console.log("onDrop leave");
            }
            $("#dropEle")[0].ondragend = function (event)
            {
            console.log("onDrop end");
            }
            });
            </script>
            <div draggable="true" id="dragEle">
            </div>
            <div id="dropEle"></div>
            系統(tǒng)中選擇的一個或多個文件拖入該div中,files中會存儲拖入文件的信息,然后我們通過file可以得到文件的類型,長度,內容然后實現(xiàn)上傳。
            3、setDragImage(image, x, y)用于設置鼠標移動過程中隨鼠標一起移動的效果圖。必須在dragstart中設置。
            4、types,effectAllowed和dropEffect分別是拖入元素的類型,拖拽過程中鼠標顯示的樣式,不過通??梢院雎赃@幾個屬性,一般用不到。