溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能

發(fā)布時間:2022-04-27 15:55:37 來源:億速云 閱讀:113 作者:iii 欄目:大數(shù)據(jù)

這篇“HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能”文章的知識點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能”文章吧。

上傳基本是項目中經(jīng)常出現(xiàn)的,一般采用:

1、form提交

2、flash

3、HTML5

form提交會刷新頁面,很難做到異步上傳;flash可能是用得比較多了,因為可以兼顧到幾乎所有的瀏覽器,我之前一直會用jQuery的uploadify作為項目中的上傳工具,uploadify也有基于Html5好像是收費(fèi)的,大家可以去官網(wǎng)看看;當(dāng)然了,現(xiàn)在html5提供了API以及File,F(xiàn)ileReader,XMLHttpRequest等強(qiáng)大的API,為我們拖放實現(xiàn)上傳提供了可能。

效果圖1:

HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能

效果圖2:

HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能

由于本地上傳實在太快,錄了個80M的gif,終于可以看到上傳的細(xì)節(jié)效果了,是不是還是很不錯的。

由于代碼比較多:

這一片主要講一下HTML和CSS:

HTML代碼:

<!DOCTYPE html>  
<html>  
<head>  
    <title></title>  
    <meta charset="utf-8"/>  
    <link href="reset.css" type="text/css" rel="stylesheet"/>  
    <link href="01.css" type="text/css" rel="stylesheet"/>  
  
</head>  
<body>  
  
  
<div id="uploadBox">  
    <ul>  
        <li>  
            <img src="images/pic1.jpg"/>  
            <span class="progress"></span>  
            <span class="percentage"></span>  
        </li>  
  
  
        <li>  
            <img src="images/pic2.jpg"/>  
            <span class="progress"></span>  
            <span class="percentage">12%</span>  
        </li>  
  
  
        <li class="done">  
            <img src="images/pic2.jpg"/>  
            <span class="progress"></span>  
            <span class="percentage"></span>  
        </li>  
  
        <div class="clearfix"></div>  
    </ul>  
  
</div>  
  
</body>  
</html>

還是很簡潔的:

a、一個div#uploadBox,里面ul li 代表每個上傳圖片單元

b、li img 圖片

c、li span.progress用于顯示進(jìn)度,有種水上漲的效果,從height:0% -100%;

d、li span.percentage 用于在圖片中央顯示 1% 到100%數(shù)字,當(dāng)?shù)竭_(dá)100%時,顯示一個正確的圖片

CSS:

body  
{  
    background: #eee;  
}  
  
#uploadBox  
{  
    width: 622px;  
    height: 362px;  
    background-color: #fff;  
    border: 1px solid #777;  
    margin: 120px auto;  
}  
  
#uploadBox ul li  
{  
    float: left;  
    position: relative;  
    margin-left: 5px;  
    margin-top: 5px;  
}  
  
#uploadBox  li img  
{  
    border: 1px solid #D1D1D1;  
    width: 198px;  
    height: 112px;  
    vertical-align: middle;  
}  
  
#uploadBox  li  .percentage  
{  
    width: 69px;  
    height: 69px;  
    position: absolute;  
    left: 50%;  
    top: 50%;  
    margin-left: -34.5px;  
    margin-top: -34.5px;  
    text-align: center;  
    font-size: 18px;  
    line-height: 69px;  
    color: #fff;  
    border-radius: 34.5px;  
    background: rgba(0, 0, 0, .8);  
}  
  
#uploadBox  li.done .percentage  
{  
    background: url("images/done.png") no-repeat 0 0;  
    text-indent: -1000em;  
}  
  
#uploadBox li .progress  
{  
    position: absolute;  
    height: 22.4px;  
    bottom: 0px;  
    width: 200px;  
    background: #000;  
    opacity: .5;  
}  
  
.clearfix  
{  
    clear: both;  
}

最后效果圖:

HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能

以上就是關(guān)于“HTML5+CSS3怎么實現(xiàn)無插件拖拽上傳圖片功能”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI