溫馨提示×

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

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

HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能

發(fā)布時(shí)間:2021-06-18 15:08:13 來(lái)源:億速云 閱讀:160 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要為大家展示了“HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能”這篇文章吧。

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

1、form提交

2、flash

3、HTML5

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

效果圖1:

HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能

效果圖2:

HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能

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

由于代碼比較多:

這一片主要講一下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>

還是很簡(jiǎn)潔的:

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

b、li img 圖片

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

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

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;  
}

都是比較簡(jiǎn)單的,基本就是定位的簡(jiǎn)單使用~大家自己看下~

最后效果圖:

HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能

以上是“HTML5+CSS3如何實(shí)現(xiàn)無(wú)插件拖拽上傳圖片功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

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

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

AI