疯狂的技术宅

以前出于工作目的,编写和翻译了大量的技术文章,以前端为主,删掉了过时的、毫无营养的内容,留下的都是精华。


  • 首页

  • 分类

  • 标签

  • 归档

  • 关于本站

  • 回到主站

  • 搜索

在 React.js 中自动复制文本到剪贴板

时间: 2020-05-13 分类: 前端实战   字数: 433 字 阅读: 1分钟
标签: #实战项目# #React#
  • 本文译自:https://dzone.com/articles/how-to-copy-text-to-clipboard-using-reactjs
  • 译者:疯狂的技术宅

介绍

在本文中,我们将学习怎样在 ReactJS 中把文本复制到剪贴板。

依赖的知识与环境

  • React 基本知识。
  • Visual Studio Code IDE。
  • Bootstrap 和 HTML 的基本知识。

创建一个 React 项目

首先,用以下命令创建一个 React App。

npx create-react-app platform  

然后在 Visual Studio Code 中打开新创建的项目,并使用以下命令安装 Bootstrap:

npm install --save bootstrap  

打开 index.js 文件并导入Bootstrap。

import 'bootstrap/dist/css/bootstrap.min.css';

以下命令安装 copy-to-clipboard 库:

npm install save copy-to-clipboard  

进入到 src 文件夹,创建一个名为 CopyBoard.js 的新组件,并在此组件中添加以下代码。

import React, { Component } from 'react'  
import copy from "copy-to-clipboard";  
import './CopyBoard.css';  
export class CopyBoard extends Component {  
	constructor() {  
		super();  
		this.state = {  
			textToCopy: "Copy to Clipboard Demo!",
			};  
			this.handleInputChange = this.handleInputChange.bind(this);  
			this.Copytext = this.Copytext.bind(this);  
	}

	handleInputChange(e) {
		this.setState({
			textToCopy: e.target.value,
		});
	}
	Copytext() {  
		copy(this.state.textToCopy);  
	}  

	render() {  
		const { textToCopy, btnText } = this.state;  
		return (  
			<div className="container">  
				<div class="row" className="hdr">  
					<div class="col-sm-12 btn btn-info">  
						Copy to Clipboard Demo  
					</div>  
				</div>  
				<div className="txt">  
				<textarea className="form-control" placeholder="Enter Text" onChange={this.handleInputChange} />  
				<br />  
				<br />  
                    <button className="btn btn-info" onClick={this.Copytext}>  
                        Copy to Clipboard  
                    </button>  
				</div>  
			</div>  
		);  
	}
}
export default CopyBoard  

接下来创建一个新的CSS文件,并在该文件中添加以下CSS。

.txt
{  
	margin-bottom: 20px;  
	margin-top: 20px;  
}  
.hdr  
{  
	margin-top: 20px;  
}  

现在,打开 App.js 文件并添加以下代码:

import React from 'react';  
import logo from './logo.svg';  
import './App.css';  
import CopyExample from './CopyBoard';  
function App() {  
	return (  
		<div className="App">  
			<CopyExample/>  
		</div>  
	);
}

然后我们可以运行项目并检查结果。

在文本框中输入一些文本,然后单击按钮

这时候将会复制文本。我们可以把文本粘贴到记事本中。

Pasting text in Notepad

标签: #实战项目# #React#

标题:在 React.js 中自动复制文本到剪贴板

链接:https://fe-tech.viewnode.com/post/202005/13/

作者:疯狂的技术宅

声明: 本博客文章除特别声明外,均采用 CC BY-NC-ND 4.0 国际许可协议( 知识共享署名-非商业性使用-禁止演绎 4.0),转载请注明出处!

为什么 CommonJS 会使你的程序包变大
为什么需要“跨域隔离”才能获得强大的功能
  • 文章目录
  • 站点概览
疯狂的技术宅

疯狂的技术宅

退休程序员,硬件发烧友,人工智能爱好者。写写代码喝喝茶,晒晒太阳带带娃。

457 日志
8 分类
583 标签
GitHub
友情链接
  • viewnode
  • mofish
标签云
  • Javascript 172
  • Node.Js 62
  • Vue 36
  • Typescript 28
  • 实战项目 28
  • 面试 21
  • React 20
  • Css 17
  • 面试题 16
  • 教程 13
  • Promise 12
  • Chrome 9
  • Debug 9
  • 调试 9
  • 资源 9
  • Deno 8
  • Dom 8
  • 杂谈 8
  • 正则表达式 8
  • 测试 8
  • 介绍
    • 依赖的知识与环境
  • 创建一个 React 项目
© 2018 - 2022 疯狂的技术宅 All Rights Reserved
Powered by - Hugo v0.99.0 / Theme by - NexT
Storage by 俺的服务器 / 冀ICP备2022010157号
0%