Debug-023-Document.createElement()的使用

2024-08-24 14:52

本文主要是介绍Debug-023-Document.createElement()的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 Document.createElement()

 document.createElement()是在对象中创建一个对象,要与appendChild() 或 insertBefore()方法联合使用。

appendChild() 方法在节点的子节点列表末添加新的子节点。

insertBefore() 方法在节点的子节点列表任意位置插入新的节点。

用途举例:用这个来实现手动唤起文件上传入口

// 手动调取图片本地上传入口
function onUploadImgLocal(row:any) {console.log('importBillExcel', row)const input = document.createElement('input')input.type = 'file'input.accept = '.jpeg, .png,  .jpg' // 限制选择的文件类型为 .jpg, .png,  .jpginput.style.display = 'none'document.body.appendChild(input)input.click()input.onchange = (e:any) => {const file = e.target.files[0] // 获取文件对象console.log('eeeeee', e, file)// handleExceed([file])}
}
  1. 创建隐藏的文件输入元素:代码首先通过document.createElement创建一个input元素,并设置其类型为file,接受的文件类型为.jpeg, .png, .jpg,然后将其隐藏并添加到document.body中。

  2. 模拟点击文件输入:通过input.click()方法,模拟用户点击文件输入元素,从而唤起文件选择界面。

  3. 处理文件选择变化:通过input.onchange事件监听器,当用户选择文件后,执行箭头函数。该函数从事件目标的files属性中获取第一个文件(e.target.files[0]),并将其传递给handleExceed函数进行进一步处理,同时在控制台打印相关信息。
     

    // 创建一个文件输入元素
    const fileInput = document.createElement('input');
    fileInput.type = 'file';
    fileInput.accept = '.jpeg, .png, .jpg'; // 限制选择的文件类型// 添加到DOM中
    document.body.appendChild(fileInput);// 添加点击事件,例如触发文件选择对话框
    fileInput.addEventListener('click', () => {// 可以在这里添加一些额外的逻辑,比如显示提示信息
    });// 监听文件选择变化
    fileInput.addEventListener('change', (event) => {const files = event.target.files; // 获取选中的文件列表if (files && files.length > 0) {// 处理选中的文件console.log('文件已选择:', files[0]);// 这里可以添加更多处理文件的逻辑}
    });

document对象的一些常用方法,并且补充了一些说明和示例。以下是10个常用的方法:

//创建一个新的元素节点。
const newElement = document.createElement('div');//将一个节点添加到指定父节点的子节点列表的末尾。
document.body.appendChild(newElement);//通过ID获取文档中的一个元素。
const elementById = document.getElementById('myId');//通过类名获取文档中的元素集合。
const elementsByClass = document.getElementsByClassName('myClass');//通过标签名获取文档中的元素集合。
const elementsByTag = document.getElementsByTagName('p');//返回文档中匹配指定CSS选择器的第一个元素。
const firstMatch = document.querySelector('.myClass');//返回文档中匹配指定CSS选择器的所有元素的NodeList对象。
const allMatches = document.querySelectorAll('.myClass');//创建一个文本节点
const textNode = document.createTextNode('Hello, world!');//从DOM树中删除一个子节点。
document.body.removeChild(newElement);//向元素添加事件监听器。
input.addEventListener('change', (e) => {const file = e.target.files[0];console.log('Selected file:', file);
});

这篇关于Debug-023-Document.createElement()的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102797

相关文章

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示