码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • file Input文件选择框,选择图片后展示在占位区


    隐藏input,使用div可以自定义点击按钮的样式,在div的click事件中出发文件选择input的click事件选择文件,然后在input的change事件中拿到e.target.files[0],是File对象,其中file.name就是文件名,然后使用FileReader.readAsDataURL(File|Blob),在其onload事件中通过reader.result获取到dataUrl

    <input type="file" name="" accpet="image/*" id="file" class="hide" />
    <div class="add-btn" id="add-btn">+div>
    <img id="img" src="" alt="" class="img-placeholrder" />
    <script>
          const btnDom = document.getElementById("btn");
          const fileDom = document.getElementById("file");
          const addBtnDom = document.getElementById("add-btn");
          const filenameDom = document.querySelector("#filename");
          const imgDom = document.querySelector("#img");
          let file = null;
    
    	// 文件选择后
          fileDom.addEventListener("change", onFileChange);
    
          addBtnDom.addEventListener("click", () => {
            fileDom.click();
          });
          btnDom.addEventListener("click", () => {
            download(file);
          });
    
          async function onFileChange(e) {
            console.log(e.target.files);
            filenameDom.innerHTML = e.target.files[0].name;
            // 获取到文件对象file
            file = e.target.files[0];
    
            const url = await fileToDataUrl(file);
            imgDom.src = url;
          }
    
    	  // 将file对象转成DataURL,DataURL可以作为img.src的值
          function fileToDataUrl(file) {
            return new Promise(resolve => {
              const reader = new FileReader();
    
              reader.readAsDataURL(file);
              reader.onload = function () {
                resolve(reader.result);
              };
            });
          }
    
    	// 通过file对象(Blob对象)所选择的文件
          function download(file) {
          	// 创建objectURL
            const url = URL.createObjectURL(file);
    
    		// 创建a标签,设置download(文件名),设置a.href=objectURl,调用a.click()
            const a = document.createElement("a");
    
            a.download = file.name;
            a.href = url;
    
            a.click();
    
            URL.revokeObjectURL(url);
          }
        script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
  • 相关阅读:
    R语言ggplot2可视化:基于aes函数中的group参数绘制分组折线图并添加数据点(散点)、geom_point函数中配置数据点形状、大小、颜色、填充色等
    Qt(day2)
    高新技术企业研发费用占比要求?
    django框架ModelForm组件用法详解
    2023年第一批次申请考核制博士网上报名相关通知
    Vue3语法糖setup(二)
    Day 49 | 121. 买卖股票的最佳时机 & 122. 买卖股票的最佳时机 II
    react中在js文件里定义的变量,如何在less文件里去使用该变量
    七、PL/SQL 集合
    Redis(四) 主从、哨兵、集群环境搭建
  • 原文地址:https://blog.csdn.net/qq_42372534/article/details/127437409
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号