这是一个反应性的初学者练习,所以我正在寻找最简单的解决方案。我目前正在学习React,所以任何有用的评论也将不胜感激。预先感谢!
这是练习:
在功能组件中,创建一个div
,其中包含2个输入和一个按钮。
每一个都应是一个单独的子组件,所有子组件均由称为App的父组件呈现。
您应该从输入中收集数据,并使其在父组件中可用(使用函数可以做到这一点)。
输入1应该收集用户的电子邮件。 输入2应该收集用户密码。
单击按钮(也是一个单独的组件)时,您应该对两个输入所收集的数据发出警报。
您应该使用onChange
和onClick
事件
我不太确定该与Button组件做什么。到目前为止,这是我要进行的练习,但是我认为这是错误的?……
APP.JS
import React from 'react'
import Email from './components/Email'
import Password from './components/Password'
const App = () => {
getData = data => '${data}'
return ( <div>
<Email getData = {getData} />
<Password getData = {getData} />
</div>
)
}
export default App
EMAIL.JS
import React from 'react'
const App = () => {
let email = '';
return (
<button onClick ={()=>props.getData({email})}></button>
);
}
export default Email;
PASSWORD.JS
import React from 'react'
const App = () => {
let password = '';
return (
<button onClick ={()=>props.getData({password})}></button>
);
}
export default Password;
BUTTON.JS
答案 0 :(得分:0)
我已经创建了一个解决方案和一个沙箱。
App.js
import React, { useState } from "react";
import Email from "./components/Email";
import Password from "./components/Password";
import Button from "./components/Button";
const App = () => {
const [email, setEmail] = useState("");
const [password, setpassword] = useState("");
const [submit, setSubmit] = useState(false);
if (submit) {
console.log("email ", email);
console.log("password ", password);
}
return (
<div>
<Email setEmail={setEmail} />
<Password setpassword={setpassword} />
<Button setSubmit={setSubmit} />
</div>
);
};
export default App;
Password.js
import React from "react";
const Password = ({ setpassword, submit }) => {
return (
<>
Get Password
<input type="password" onChange={e => setpassword(e.target.value)} />
</>
);
};
export default Password;
Email.js
import React from "react";
const Email = ({ setEmail }) => {
return (
<>
Get Email
<input type="text" onChange={e => setEmail(e.target.value)} />
</>
);
};
export default Email;
Button.js
import React from "react";
const Button = ({ setSubmit }) => {
return (
<button
onClick={() => {
setSubmit(true);
}}
>
Submit
</button>
);
};
export default Button;
我强烈建议您在开始任何课程之前先访问reactjs.org并仔细阅读文档。请不要复制粘贴。希望对您有所帮助。