2018-08-22 23:34:36 +08:00
---
2018-09-02 15:46:49 +08:00
order: 4
2018-08-22 23:34:36 +08:00
title:
zh-CN: 列表
en-US: List
---
## zh-CN
在列表组件中使用加载占位符。
## en-US
Use skeleton in list component.
````jsx
import { Skeleton, Switch, List, Avatar, Icon } from 'antd';
const listData = [];
for (let i = 0; i < 3 ; i + + ) {
listData.push({
href: 'http://ant.design',
title: `ant design part ${i}` ,
avatar: 'https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png',
description: 'Ant Design, a design language for background applications, is refined by Ant UED Team.',
content: 'We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure), to help people create their product prototypes beautifully and efficiently.',
});
}
const IconText = ({ type, text }) => (
< span >
< Icon type = {type} style = {{ marginRight: 8 } } / >
{text}
< / span >
);
class App extends React.Component {
state = {
loading: true,
}
onChange = (checked) => {
this.setState({ loading: !checked });
}
render() {
const { loading } = this.state;
return (
< div >
< Switch checked = {!loading} onChange = {this.onChange} / >
< List
itemLayout="vertical"
size="large"
dataSource={listData}
renderItem={item => (
< List.Item
key={item.title}
actions={!loading & & [< IconText type = "star-o" text = "156" / > , < IconText type = "like-o" text = "156" / > , < IconText type = "message" text = "2" / > ]}
extra={!loading & & < img width = {272} alt = "logo" src = "https://gw.alipayobjects.com/zos/rmsportal/mqaQswcyDLcXyDKnZfES.png" / > }
>
2018-09-02 15:46:49 +08:00
< Skeleton loading = {loading} active avatar >
2018-08-22 23:34:36 +08:00
< List.Item.Meta
avatar={< Avatar src = {item.avatar} / > }
title={< a href = {item.href} > {item.title}< / a > }
description={item.description}
/>
{item.content}
< / Skeleton >
< / List.Item >
)}
/>
< / div >
);
}
}
ReactDOM.render(< App / > , mountNode);
````
< style >
.skeleton-demo {
border: 1px solid #f4f4f4 ;
}
< / style >