Comment
A comment displays user feedback and discussion to website content.
When To Use#
Comments can be used to enable discussions on an entity such as a page, blog post, issue or other.
Examples

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.
- 0
- 0
- Reply to
import {
Comment, Icon, Tooltip, Avatar,
} from 'antd';
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',
});
}
render() {
const { likes, dislikes, action } = this.state;
const actions = [
<span>
<Tooltip title="Like">
<Icon
type="like"
theme={action === 'liked' ? 'filled' : 'outlined'}
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'}
onClick={this.dislike}
/>
</Tooltip>
<span style={{ paddingLeft: 8, cursor: 'auto' }}>
{dislikes}
</span>
</span>,
<span>Reply to</span>,
];
return (
<Comment
actions={actions}
author={<a>Han Solo</a>}
avatar={(
<Avatar
src="https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png"
alt="Han Solo"
/>
)}
content={(
<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>
)}
datetime={(
<Tooltip title={moment().format('YYYY-MM-DD HH:mm:ss')}>
<span>{moment().fromNow()}</span>
</Tooltip>
)}
/>
);
}
}
ReactDOM.render(<App />, mountNode);
import { Comment, Tooltip, List } from 'antd';
import moment from 'moment';
const data = [
{
actions: [<span>Reply to</span>],
author: 'Han Solo',
avatar: 'https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png',
content: (
<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>
),
datetime: (
<Tooltip title={moment().subtract(1, 'days').format('YYYY-MM-DD HH:mm:ss')}>
<span>{moment().subtract(1, 'days').fromNow()}</span>
</Tooltip>
),
},
{
actions: [<span>Reply to</span>],
author: 'Han Solo',
avatar: 'https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png',
content: (
<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>
),
datetime: (
<Tooltip title={moment().subtract(2, 'days').format('YYYY-MM-DD HH:mm:ss')}>
<span>{moment().subtract(2, 'days').fromNow()}</span>
</Tooltip>
),
},
];
ReactDOM.render(
<List
className="comment-list"
header={`${data.length} replies`}
itemLayout="horizontal"
dataSource={data}
renderItem={item => (
<Comment
actions={item.actions}
author={item.author}
avatar={item.avatar}
content={item.content}
datetime={item.datetime}
/>
)}
/>,
mountNode,
);

We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure).
- Reply to

We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure).
- Reply to

We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure).
- Reply to

We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure).
- Reply to
import { Comment, Avatar } from 'antd';
const ExampleComment = ({ children }) => (
<Comment
actions={[<span>Reply to</span>]}
author={<a>Han Solo</a>}
avatar={(
<Avatar
src="https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png"
alt="Han Solo"
/>
)}
content={<p>We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure).</p>}
>
{children}
</Comment>
);
ReactDOM.render(
<ExampleComment>
<ExampleComment>
<ExampleComment />
<ExampleComment />
</ExampleComment>
</ExampleComment>,
mountNode,
);

import {
Comment, Avatar, Form, Button, List, Input,
} from 'antd';
import moment from 'moment';
const TextArea = Input.TextArea;
const CommentList = ({ comments }) => (
<List
dataSource={comments}
header={`${comments.length} ${comments.length > 1 ? 'replies' : 'reply'}`}
itemLayout="horizontal"
renderItem={props => <Comment {...props} />}
/>
);
const Editor = ({
onChange, onSubmit, submitting, value,
}) => (
<div>
<Form.Item>
<TextArea rows={4} onChange={onChange} value={value} />
</Form.Item>
<Form.Item>
<Button
htmlType="submit"
loading={submitting}
onClick={onSubmit}
type="primary"
>
Add Comment
</Button>
</Form.Item>
</div>
);
class App extends React.Component {
state = {
comments: [],
submitting: false,
value: '',
}
handleSubmit = () => {
if (!this.state.value) {
return;
}
this.setState({
submitting: true,
});
setTimeout(() => {
this.setState({
submitting: false,
value: '',
comments: [
{
author: 'Han Solo',
avatar: 'https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png',
content: <p>{this.state.value}</p>,
datetime: moment().fromNow(),
},
...this.state.comments,
],
});
}, 1000);
}
handleChange = (e) => {
this.setState({
value: e.target.value,
});
}
render() {
const { comments, submitting, value } = this.state;
return (
<div>
{comments.length > 0 && <CommentList comments={comments} />}
<Comment
avatar={(
<Avatar
src="https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png"
alt="Han Solo"
/>
)}
content={(
<Editor
onChange={this.handleChange}
onSubmit={this.handleSubmit}
submitting={submitting}
value={value}
/>
)}
/>
</div>
);
}
}
ReactDOM.render(<App />, mountNode);
API#
Property | Description | Type | Default |
---|---|---|---|
actions | List of action items rendered below the comment content | Array | - |
author | The element to display as the comment author | string|ReactNode | - |
avatar | The element to display as the comment avatar - generally an antd Avatar or src | string|ReactNode | - |
children | Nested comments should be provided as children of the Comment | ReactNode | - |
content | The main content of the comment | string|ReactNode | - |
datetime | A datetime element containing the time to be displayed | string|ReactNode | - |
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.
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.