ant-design/components/comment/demo/basic.md

101 lines
2.1 KiB
Markdown
Raw Normal View History

2018-10-22 21:20:28 +08:00
---
order: 0
title:
zh-CN: 基本评论
en-US: Basic comment
---
## zh-CN
2018-10-28 22:09:38 +08:00
一个基本的评论组件,带有作者、头像、时间和操作。
2018-10-22 21:20:28 +08:00
## en-US
A basic comment with author, avatar, time and actions.
````jsx
2018-12-01 00:24:16 +08:00
import {
Comment, Icon, Tooltip, Avatar,
} from 'antd';
2018-10-22 21:20:28 +08:00
import moment from 'moment';
class App extends React.Component {
state = {
likes: 0,
dislikes: 0,
action: null,
}
like = () => {
this.setState({
likes: 1,
dislikes: 0,
action: 'liked',
});
}
dislike = () => {
this.setState({
likes: 0,
dislikes: 1,
action: 'disliked',
2018-10-31 20:10:42 +08:00
});
2018-10-22 21:20:28 +08:00
}
render() {
const { likes, dislikes, action } = this.state;
const actions = [
<span>
<Tooltip title="Like">
<Icon
type="like"
theme={action === 'liked' ? 'filled' : 'outlined'}
2018-10-22 21:20:28 +08:00
onClick={this.like}
/>
</Tooltip>
<span style={{ paddingLeft: 8, cursor: 'auto' }}>
{likes}
</span>
</span>,
<span>
<Tooltip title="Dislike">
<Icon
type="dislike"
theme={action === 'disliked' ? 'filled' : 'outlined'}
2018-10-22 21:20:28 +08:00
onClick={this.dislike}
/>
</Tooltip>
<span style={{ paddingLeft: 8, cursor: 'auto' }}>
{dislikes}
</span>
</span>,
<span>Reply to</span>,
];
return (
<Comment
actions={actions}
2018-10-22 21:20:28 +08:00
author={<a>Han Solo</a>}
2018-10-31 20:10:42 +08:00
avatar={(
2018-10-22 21:20:28 +08:00
<Avatar
src="https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png"
alt="Han Solo"
/>
2018-10-31 20:10:42 +08:00
)}
content={(
2018-10-30 19:25:54 +08:00
<p>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.</p>
2018-10-31 20:10:42 +08:00
)}
datetime={(
<Tooltip title={moment().format('YYYY-MM-DD HH:mm:ss')}>
<span>{moment().fromNow()}</span>
</Tooltip>
2018-10-31 20:10:42 +08:00
)}
/>
2018-10-22 21:20:28 +08:00
);
}
}
ReactDOM.render(<App />, mountNode);
````