如何仅使用 CSS 在 React 中实现图像拖放
React 在构建交互式 UI 方面得到了广泛认可。在本教程中,我们将指导您仅使用 CSS 在 React 中创建图像拖放功能。
第 1 步:设置你的 React 项目
首先设置您的 React 项目。您可以使用 create-react-app 进行简单设置。
npx create-react-app drag-and-drop
第2步:更新App.js和App.css
接下来,修改 App.js 文件以创建图像和标题的容器。
import './App.css'; function App() { return ( <div classname="App"> <h2 id="Select-Image">Select Image:</h2> <div classname="image-area"></div> </div> ); } export default App;
在 App.css 中,设置页面样式:
.App { text-align: center; width: 100vw; height: 100vh; } .heading { font-size: 32px; font-weight: 500; }
第三步:创建ImageContainer组件
创建一个新文件 ImageContainer.js 并定义一个基本的拖放容器。
import React from 'react'; const ImageContainer = () => { return ( <div classname="image-container"></div> ); }; export default ImageContainer;
在 ImageContainer.css 中设置此容器的样式:
.image-container { width: 60%; height: 90%; display: flex; align-items: center; justify-content: center; border: 2px dashed rgba(0, 0, 0, .3); }
第四步:添加图片上传功能
通过文件输入和用户文本说明增强 ImageContainer。
import React from 'react'; import './ImageContainer.css'; const ImageContainer = () => { const [url, setUrl] = React.useState(''); const onChange = (e) => { const files = e.target.files; if (files.length > 0) { setUrl(URL.createObjectURL(files[0])); } }; return ( <div classname="image-container"> <div classname="upload-container"> <input type="file" classname="input-file" accept=".png, .jpg, .jpeg" onchange="{onChange}"> <p>Drag & Drop here</p> <p>or</p> <p>Click</p> </div> </div> ); }; export default ImageContainer;
并设置上传容器的样式:
.image-container { width: 60%; height: 90%; display: flex; align-items: center; justify-content: center; border: 2px dashed rgba(0, 0, 0, .3); } .upload-container { position: relative; width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; background-color: white; } .upload-container > p { font-size: 18px; margin: 4px; font-weight: 500; } .input-file { display: block; border: none; position: absolute; top: 0; left: 0; right: 0; bottom: 0; opacity: 0; }
第 5 步:预览图像
修改组件,有条件地渲染上传的图片或拖放区域。
import React from 'react'; import './ImageContainer.css'; const ImageContainer = () => { const [url, setUrl] = React.useState(''); const onChange = (e) => { const files = e.target.files; if (files.length > 0) { setUrl(URL.createObjectURL(files[0])); } }; return ( <div classname="image-container"> {url ? ( <img classname="image-view" alt="如何在 React 中实现图像拖放" > <h3> Step 6: Import and Run the Application </h3> <p>Finally, import ImageContainer into App.js and run the app.<br> </p> <pre class="brush:php;toolbar:false">import './App.css'; import ImageContainer from './ImageContainer'; function App() { return ( <div classname="App"> <h2 id="Select-Image">Select Image:</h2> <div classname="image-area"> <imagecontainer></imagecontainer> </div> </div> ); } export default App;
现在您可以运行应用程序并享受使用 React 和 CSS 编写图像拖放功能的乐趣。
本教程介绍了如何使用 React 设置基本的图像拖放区域、利用文件输入和 CSS 进行样式设置以及处理图像预览。
以上是如何在 React 中实现图像拖放的详细内容。更多信息请关注PHP中文网其他相关文章!

本教程演示了使用智能表单框架创建外观专业的JavaScript表单(注意:不再可用)。 尽管框架本身不可用,但原理和技术仍然与其他形式的建筑商相关。

CSS盒子阴影和轮廓属性获得了主题。让我们查看一些在真实主题中起作用的示例,以及我们必须将这些样式应用于WordPress块和元素的选项。

构建内联文本编辑器并不是微不足道的。 该过程首先要使目标元素可编辑,并在此过程中处理潜在的语法异常。 创建您的编辑器 要构建此编辑器,您需要动态修改内容

这是我们在形式可访问性上进行的小型系列中的第三篇文章。如果您错过了第二篇文章,请查看“以:focus-visible的管理用户焦点”。在

Svelte Transition API提供了一种使组件输入或离开文档(包括自定义Svelte Transitions)时动画组件的方法。

本文探讨了Envato Market上可用的PHP表单构建器脚本,比较了其功能,灵活性和设计。 在研究特定选项之前,让我们了解PHP形式构建器是什么以及为什么要使用一个。 PHP形式

该教程通过使用node.js,express和multer构建文件上传系统来指导您。 我们将介绍单个和多个文件上传,甚至演示在MongoDB数据库中存储图像以进行以后的检索。 首先,设置您的projec


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver Mac版
视觉化网页开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。