- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 [Available Team] 数组作为按钮填充在(Available Team Members)下。我希望当单击一个按钮时,它会在(Alpha Team Members)下生成一个与父按钮同名的子按钮。当再次点击同一个 parent 时,我希望将 child 从(Alpha Team Members)中删除。 (Omega 团队成员)是随机生成的。
我的问题是点击处理程序一次完成所有按钮的此功能,而不仅仅是点击的按钮,点击时它会随机生成它不应该做的随机生成的(Omega Team Members)...帮助将不胜感激.提前谢谢你。
import React, { Component } from 'react';
import './App.css';
import ToggleDisplay from 'react-toggle-display';
class App extends Component {
constructor() {
super();
this.state = { show: false };
}
handleClick() {
this.setState({
show: !this.state.show
});
}
render() {
const AvailableTeam = ['Benzo Walli', 'Rasha Loa', 'Tayshaun Dasmoto', 'Colmar Cumberbatch', 'Femi Billon', 'Ziya Erika', 'Siyabonga Nesta', 'Sylvain Natalie', 'Dipak Iunia', 'Danel Mio'];
const AlphaTeam = [];
const OmegaTeam = [];
for (let i = 0; i < 3; i++) {
const playerIndex = Math.floor(Math.random() * AvailableTeam.length);
OmegaTeam.push(AvailableTeam[playerIndex]);
AvailableTeam.splice(playerIndex, 1);
}
return (
<div className="App">
<div>
<h3>Available Team Members</h3>
{AvailableTeam.map((player, key) => <div key={key}><button onClick={ () => this.handleClick() }>{player}</button></div>)}
<button onClick={ () => this.handleClick() }>Benzo Walli</button>
</div>
<div>
<h3>Alpha Team Members</h3>
<ToggleDisplay show={this.state.show}>
<div><button></button></div>
</ToggleDisplay>
</div>
<div>
<h3>Omega Team Members</h3>
{OmegaTeam.map((player, key) => <div key={key}><button>{player}</button></div>)}
</div>
</div>
);
}
}
export default App;
我尝试了一种使用 handle 的解决方案,但当使用多个按钮时它们会触发所有按钮。我可以使用 key 修复此问题吗?如果可以,如何修复?
import React, { Component } from 'react';
import './App.css';
import ToggleDisplay from 'react-toggle-display';
class App extends Component {
constructor(props) {
super(props);
this.state = { show: false };
}
handleClick() {
this.setState({
show: !this.state.show
});
}
render() {
const AvailableTeam = ['Benzo Walli', 'Rasha Loa', 'Tayshaun Dasmoto', 'Colmar Cumberbatch', 'Femi Billon', 'Ziya Erika', 'Siyabonga Nesta', 'Sylvain Natalie', 'Dipak Iunia', 'Danel Mio'];
const AlphaTeam = [];
const OmegaTeam = [];
for (let i = 0; i < 3; i++) {
const playerIndex = Math.floor(Math.random() * AvailableTeam.length);
OmegaTeam.push(AvailableTeam[playerIndex]);
AvailableTeam.splice(playerIndex, 1);
}
return (
<div className="App">
<div>
<h3>Available Team Members</h3>
<button onClick={ () => this.handleClick() }>Benzo Walli</button>
<button onClick={ () => this.handleClick() }>Ruan</button>
</div>
<div>
<h3>Alpha Team Members</h3>
<ToggleDisplay show={this.state.show}>
<div><button>Benzo Walli</button></div>
</ToggleDisplay>
<ToggleDisplay show={this.state.show}>
<div><button>Ruan</button></div>
</ToggleDisplay>
</div>
<div>
<h3>Omega Team Members</h3>
{OmegaTeam.map((player, key) => <div key={key}><button>{player}</button></div>)}
</div>
</div>
);
}
}
export default App;
最佳答案
希望我理解正确,所以这是我的解决方案:
您缺少动态显示播放器按钮的逻辑,您只需打开和关闭按钮即可。您的 handleClick 函数不会因您单击的播放器按钮而有所不同。
因此您必须向 handleClick 传递一个参数,我建议播放器。然后,您需要将要显示的每个玩家推送到您的 alphaTeam 数组中。该数组也必须在循环中显示(大概如果你想在那里显示多个玩家)。
对于 shuffle 部分,您的 handleClick 函数会设置您的 App 组件的状态,这会导致 React 重新呈现该 App,从而再次对您的 OmegaTeam 进行 shuffle。您应该考虑在构造函数/状态中移动随机播放以及 AvailableTeam 的初始化。
这是我的建议,虽然我没有测试过:
import React, { Component } from 'react';
import './App.css';
import ToggleDisplay from 'react-toggle-display';
class App extends Component {
constructor() {
super();
let availableTeam = ['Benzo Walli', 'Rasha Loa', 'Tayshaun Dasmoto', 'Colmar Cumberbatch', 'Femi Billon', 'Ziya Erika', 'Siyabonga Nesta', 'Sylvain Natalie', 'Dipak Iunia', 'Danel Mio'];
let omegaTeam = [];
for (let i = 0; i < 3; i++) {
const playerIndex = Math.floor(Math.random() * availableTeam.length);
omegaTeam.push(availableTeam[playerIndex]);
availableTeam.splice(playerIndex, 1);
}
this.state = {
availableTeam : availableTeam,
alphaTeam : [],
omegaTeam : omegaTeam,
};
}
handleClick(player) {
let newAlphaTeam = this.state.alphaTeam;
// if player is not in array , add him
if(newAlphaTeam.indexOf(player)<0){
newAlphaTeam.push(player);
}
// if player is in the array , remove him
else{
newAlphaTeam.splice(newAlphaTeam.indexOf(player), 1);
}
//setState to rerender the App component
this.setState({
alphaTeam : newAlphaTeam,
});
}
render() {
return (
<div className="App">
<div>
<h3>Available Team Members</h3>
{this.state.availableTeam.map((player, key) => <div key={key}><button onClick={ () => this.handleClick(player) }>{player}</button></div>)}
</div>
<div>
<h3>Alpha Team Members</h3>
{this.state.alphaTeam.map((player, key) => <div key={key}><button>{player}</button></div>)}
</div>
<div>
<h3>Omega Team Members</h3>
{this.state.omegaTeam.map((player, key) => <div key={key}><button>{player}</button></div>)}
</div>
</div>
);
}
}
export default App;
关于javascript - react .js : Toggle Buttons with children and parents,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48421522/
如果我需要选择第 10 个父级,是否有更简洁的方法,然后重复 .parent() 10 次? $('#element_id').parent().parent().parent().parent().
从 angularJS 指南中的“如何创建通信指令”开始,https://docs.angularjs.org/guide/directive , 我正在尝试使用该布局来制作可导航的表单。 问题在于指
我有一个 jQuery 函数,需要获取元素父元素的位置。 它看起来像: function show(e) { //debugger; var nextTab
我正在尝试修复这个难看的代码。 RadGrid gv = (RadGrid) (((Control) e.CommandSource).Parent.Parent.Parent.Parent.Pare
我有一个 A 标签,可以触发它的曾曾曾祖 parent 的动画。以下所有方法都可以,但哪一个最有效,为什么? $(this).parent().parent().parent().parent().p
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在尝试定位绝对定位的 div 时遇到了一些问题。我猜它的工作方式应该是这样,但是我希望它与父对象的父对象而不是父对象一起使用,因为我有一个下拉列表,当我希望它像第一个一样保持在顶部时,它会跟随父对象
我正在做一些非常基本的 jQuery 东西,真正开始,我经常通过做类似的事情来向上导航 dom $(this).parent().parent().addClass('hello'); 我只是想知道是
此 HTML 结构有一个 div#page,其中当前页面内容将通过 Ajax 加载。内容始终由 section 标记组成,这些标记可以具有动态高度(相对于浏览器的百分比)或静态高度(以像素为单位)。
在 javascript 中是否有一种简单的方法来定位父对象的父对象? 我使用 this.parentNode 作为函数的元素来选择父节点,我尝试了 this.parent.parentNode 和
当遍历 pager.Pages 对象的 foreach 循环时,$data 是 self(正如预期的那样)。但是,$parent 应该是寻呼机对象,但它返回的是 WaterQualityResultV
在架构中,我想根据父级的 sibling 调整架构。 例如:如果 toggleMonday 为真,那么 weekdays -> monday 应该有一个特定的验证模式。 现在下面的例子有效。但是,它非
我想要完成的是,当用户将焦点放在文本框上时,其中的字段集将添加一个类“active_fieldset”,以便提供用户在表单中的位置的良好视觉提示。使用以下 javascript,它确实会影响父字段集,
我创建了这个函数来保存我的taches sauverTache(tache:Tache){ this.editionEnCours = true; tache.estReelle =
所以..这是我的问题..我有以下代码(示例): var GameObject = function (posX, posY, width, height) { this.posX = posX;
所以,我是 jQuery 的新手,我正在尝试更改关于函数触发器的 2 个级别的 div: 这是我的第一次尝试:我尝试找到最接近的“.node”,它是所有其他 div 的父级并编辑子 div。 fun
我想了解为什么使用 ng-repeat在repeat 的item 上有某个controller,那个item 的parent 和那个item 的祖父是同一个controller。我期待祖父成为父 Co
我想从我的组件 Controller 之一将 jsonModel 设置为我的 SAPUI5 组件。在组件内,我使用应用程序或 splitapp。 我想避免通过 ID 获取元素。从组件内的某个位置获取层
我不确定如何在标题上准确地表达出来,因为问题在我的场景中太具体了,但无论如何基本上我有两个类似于下面的外部类: class Config { public level: number = 1;
在我正在编写的这个脚本中,我发现自己连续使用 .parent() 最多七次来获取元素。虽然这有效,但似乎可以/应该有一种更简单的方法来完成我不知道的这个/功能。除了更多元素上更具体的类/ID 之外,还
我是一名优秀的程序员,十分优秀!