这篇文章主要介绍“React的多选Checkbox组件怎么使用”,在日常操作中,相信很多人在React的多选Checkbox组件怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”React的多选Checkbox组件怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
代码如下:
import React, { PureComponent } from "react";
import { List, NavBar, Checkbox } from "antd-mobile";
import { Icon } from "antd";
import TouchFeedback from "rmc-feedback";
import NavContentContainer from "./NavContentContainer";
import PanelContentContainer from "./PanelContentContainer";
export default class Checkbox_ extends PureComponent {
constructor(props) {
super(props);
this.state = { select: [] };
}
componentWillReceiveProps(props) {
const { show, init } = props;
if (show) {
this.setState({ select: init || [] });
}
}
getDefaultChecked = value => {
const { init } = this.props;
const result = (init || []).filter(i => i === value);
return result.length !== 0;
};
render() {
const { show, data, title, hide, save } = this.props;
const { select } = this.state;
return (
<div
style={{
display: show ? "block" : "none",
zIndex: 1,
position: "absolute",
backgroundColor: "#fff",
overflowY: "auto",
top: 0,
bottom: 0,
left: 0,
right: 0
}}
>
<NavBar
className="global-navbar"
mode="dark"
icon={
<TouchFeedback activeClassName="primary-feedback-active">
<Icon type="left" />
</TouchFeedback>
}
onLeftClick={() => hide()}
rightContent={[
<Icon
type="check"
style={{ marginRight: "16px" }}
onClick={() => save(select)}
/>
]}
>
{title}
</NavBar>
<NavContentContainer>
<PanelContentContainer>
<List>
{data.map(i => (
<Checkbox.CheckboxItem
wrap
key={i.value}
defaultChecked={this.getDefaultChecked(i.value)}
onChange={() => {
if (select.indexOf(i.value) === -1) {
select.push(i.value);
} else {
const odd = select;
odd.splice(odd.indexOf(i.value), 1);
this.setState({
select: odd
});
}
}}
>
{i.key}
</Checkbox.CheckboxItem>
))}
</List>
</PanelContentContainer>
</NavContentContainer>
</div>
);
}
}
<Checkbox
show={showCheckbox}
data={checkboxData}
title={checkboxTitle}
id={checkboxId}
init={checkboxNum[checkboxId]}
hide={() => this.setState({ showCheckbox: false })}
save={v => {
this.setState({
showCheckbox: false,
checkboxNum: { ...checkboxNum, [checkboxId]: v }
});
}}
/>
效果图:
到此,关于“React的多选Checkbox组件怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://blog.51cto.com/u_15812097/5723183