欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生js實現(xiàn)上傳圖片控件

 更新時間:2021年08月20日 10:20:50   作者:Hizo  
這篇文章主要為大家詳細介紹了原生js實現(xiàn)上傳圖片控件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了js實現(xiàn)上傳圖片控件的具體代碼,供大家參考,具體內(nèi)容如下

一、修改原生 input 樣式

html 結構

<div class="card">
    <input id="upload" type="file" accept=".jpg" />
    <div class="view">
        <!-- 上傳成功后 -->
        <div id="imgContainer" class="img-container">
            <img id="img" />
            <!-- 鼠標移入展示 查看 與 刪除 操作 -->
            <div class="img-mask">
                <span id="showImg">查看</span>
                <span id="delImg">刪除</span>
            </div>
        </div>
        <!-- 上傳成功前 -->
        <span id="icon">+</span>
    </div>
</div>

css 樣式

.card {
    position: relative;
    width: 200px;
    height: 140px;
    padding: 5px;
    margin-right: 20px;
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    margin: 300px auto;
}

.card input {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.card .view {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.card .view #icon {
    display: inline-block;
    font-size: 30px;
}

.card .view .img-container {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: none;
}

.img-container img {
    width: 100%;
    height: 100%;
}

.img-container .img-mask {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    background: rgba(0, 0, 0, .3);
    transition: all .5s ease;
    display: flex;
    justify-content: center;
    align-items: center;
}

.img-container:hover .img-mask {
    opacity: 1;
}

.img-mask span {
    color: #fff;
    margin: 0 10px;
    cursor: pointer;
}

效果展示

二、上傳圖片并展示

監(jiān)聽 input 的 change 事件,圖片上傳成功后創(chuàng)建 URL

<script>
    const upload = document.getElementById('upload');
    const imgContainer = document.getElementById('imgContainer');
    const img = document.getElementById('img');
    const icon = document.getElementById('icon');

    let imgUrl = '';
    // 圖片上傳成功后創(chuàng)建 URL
    upload.onchange = function (value) {
        const fileList = value.target.files;
        if (fileList.length) {
            imgContainer.style.display = 'block';
            icon.style.display = 'none';
            imgUrl = window.URL.createObjectURL(fileList[0]);
            img.src = imgUrl;
        }
    }
<script>

上傳成功后展示

三、實現(xiàn)圖片預覽

寫一個 modal 框

<!-- 預覽圖片的 modal 框 -->
<div id="modal">
    <span id="closeIcon">關閉</span>
    <div class="content">
        <img id="modalImg">
    </div>
</div>

modal 樣式

/* modal 樣式 */
#modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 0;
    height: 0;
    box-shadow: 0 0 10px #d9d9d9;
    background: rgba(0, 0, 0, .3);
    /* transition: all .1s ease-in-out; */
    overflow: hidden;
}

#modal .content {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding: 45px 20px 20px;
    display: flex;
    justify-content: center;
}

#modal #modalImg {
    height: 100%;
}

#modal #closeIcon {
    position: absolute;
    top: 10px;
    right: 10px;
    cursor: pointer;
}

然后獲取元素, 監(jiān)聽點擊事件

/* ...接以上代碼 */
const showImg = document.getElementById('showImg');
const delImg = document.getElementById('delImg');
const modal = document.getElementById('modal');
const modalImg = document.getElementById('modalImg');
const closeIcon = document.getElementById('closeIcon');

// 點擊預覽圖片
showImg.onclick = function () {
    modal.style.width = '100%';
    modal.style.height = '100%';
    modalImg.src = imgUrl;
}

// 關閉 modal 框
closeIcon.onclick = function () {
    modal.style.width = '0';
    modal.style.height = '0';
    modalImg.src = '';
}

// 刪除上傳的圖片
delImg.onclick = function () {
    upload.value = '';
    imgUrl = '';
    icon.style.display = 'block';
    imgContainer.style.display = 'none';
}

預覽效果圖

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • JS實現(xiàn)點擊事件統(tǒng)計的簡單實例

    JS實現(xiàn)點擊事件統(tǒng)計的簡單實例

    下面小編就為大家?guī)硪黄狫S實現(xiàn)點擊事件統(tǒng)計的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • javascript實現(xiàn)非常簡單的小數(shù)取整功能示例

    javascript實現(xiàn)非常簡單的小數(shù)取整功能示例

    這篇文章主要介紹了javascript實現(xiàn)非常簡單的小數(shù)取整功能,結合具體實例形式分析了javascript數(shù)學運算取整相關操作技巧,需要的朋友可以參考下
    2017-06-06
  • js模擬實現(xiàn)百度搜索

    js模擬實現(xiàn)百度搜索

    這篇文章主要為大家詳細介紹了js模擬實現(xiàn)百度搜索,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • JS寫的數(shù)字拼圖小游戲代碼[學習參考]

    JS寫的數(shù)字拼圖小游戲代碼[學習參考]

    昨天沒事做,就用JS寫了個數(shù)字拼圖的小游戲,自娛自樂。 可惜關于逆序數(shù)的問題還沒解決,現(xiàn)在有時是拼不成的,大家見諒了。
    2008-10-10
  • 微信小程序實現(xiàn)長按 識別圖片二維碼(兩種方案)

    微信小程序實現(xiàn)長按 識別圖片二維碼(兩種方案)

    這篇文章主要介紹了微信小程序實現(xiàn)長按 識別圖片二維碼(兩種方案),第一種方案只需要在image里面加一個屬性就可以了,本文結合實例代碼介紹的非常詳細,需要的朋友可以參考下
    2024-01-01
  • js動態(tài)添加onload、onresize、onscroll事件(另類方法)

    js動態(tài)添加onload、onresize、onscroll事件(另類方法)

    window 的 onload、onresize、onscroll 事件,跟其他的事件不一樣,它不能用 attachEvent 或 addEventListener 來添加于是本人想了一些另類的方法,需要了解的朋友可以參考下
    2012-12-12
  • js實現(xiàn)多選項切換導航菜單的方法

    js實現(xiàn)多選項切換導航菜單的方法

    這篇文章主要介紹了js實現(xiàn)多選項切換導航菜單的方法,可實現(xiàn)動態(tài)生成多選項切換導航菜單的功能,是非常實用的技巧,需要的朋友可以參考下
    2015-02-02
  • JS回調(diào)函數(shù)深入理解

    JS回調(diào)函數(shù)深入理解

    這篇文章主要介紹了JS回調(diào)函數(shù),結合實例形式深入分析了js回調(diào)函數(shù)的概念、原理、使用方法及相關操作注意事項,需要的朋友可以參考下
    2019-10-10
  • javascript在IE下trim函數(shù)無法使用的解決方法

    javascript在IE下trim函數(shù)無法使用的解決方法

    這篇文章主要介紹了javascript在IE下trim函數(shù)無法使用的解決方法,分別敘述了javascript以及jQuery下的解決方案,對于WEB前端javascript設計人員進行瀏覽器兼容性調(diào)試有不錯的借鑒價值,需要的朋友可以參考下
    2014-09-09
  • JS獲取CSS樣式(style/getComputedStyle/currentStyle)

    JS獲取CSS樣式(style/getComputedStyle/currentStyle)

    這篇文章主要為大家介紹了JS獲取CSS樣式的方法,介紹了CSS樣式的三種分類情況,對獲取樣式做一個簡單的封裝,感興趣的小伙伴們可以參考一下
    2016-01-01

最新評論