演示
使用方法
- 安装
npm install chat-react 复制代码
- 引入
import Chat from 'chat-react'; 复制代码
- 使用
export default class MyChat extends Component {
state = {
inputValue: '',
messages: [],
timestamp: new Date().getTime()
}
setInputfoucs = () => {
this.chat.refs.input.inputFocus(); //set input foucus
}
setScrollTop = () => {
this.chat.refs.message.setScrollTop(1200); //set scrollTop position
}
sendMessage = (v) => {
const {value} = v;
if (!value) return;
const {messages = []} = this.state;
messages.push(v);
this.setState({messages, timestamp: new Date().getTime(), inputValue: ''});
}
render() {
const {inputValue, messages, timestamp} = this.state;
const userInfo = {
avatar: "http://img.binlive.cn/6.png",
userId: "59e454ea53107d66ceb0a598",
name: 'ricky'
};
return (
<Chat
ref={el => this.chat = el}
className="my-chat-box"
dataSource={messages}
userInfo={userInfo}
value={inputValue}
sendMessage={this.sendMessage}
timestamp={timestamp}
placeholder="请输入"
messageListStyle={{width: '100%', height: window.outerHeight}}
/>
);
}
}
复制代码
API
| 属性 & 方法 | 类型 | 描述 |
|---|---|---|
| userInfo | object | 当前用户信息 |
| value | string | 输入框的内容 |
| placeholder | string | 输入框的占位符 |
| emoji | any | 定义emoji内容 |
| customEmoticon | array | 自定义表情包 |
| textareaChange | (value) => {} | 回调函数,输入框的内容变化时触发,函数的第一个参数是当前输入值 |
| selectEmoje | (emojeInfo) => {} | 选择一个emoji后的回调函数,函数的第一个参数是选择的emoje内容信息 |
| inputFocus | func | 子组件input的内置方法,用于设置input焦点 this.chat.refs.input.inputFocus() |
| dataSource | array | 消息列表的数据内容 |
| messageListStyle | object | 消息列表的样式,需要为列表设置一个固定的高度 |
| timestamp | number | 数据源发生变化时候设置的时间戳 |
| timeBetween | number | 在指定时间间隔内显示时间提示(单位:分钟,默认值:5) |
| timeagoMax | number | 在指定时间范围内显示多长时间之前(单位:小时,默认值:24) |
| timeFormat | string | 自定义时间格式 (yyyy-MM-dd hh:mm) |
| loading | bool | 数据源是否在加载中 |
| loader | node | 自定义加载器 |
| noData | bool | 是否没有更多的数据了 |
| noDataEle | node | 当没有更多的数据时显示自定义的元素节点 |
| scrollOptions | object | 该参数使用了iscroll.js的 scrollbars 参数, 查看 iscroll.js 文档 |
| scrolltoUpper | func | 滚动条滚动到顶部时触发的回调函数 |
| onScroll | func | 当滚动条滚动时触发的回调函数 |
| avatarClick | (value) => {} | 用户点击头像触发的回调函数, 参数value为被点击用户信息 |
| unreadCountChange | func | 未读消息变化时的回调函数 |
| setScrollTop | setScrollTop(value) | 子组件message的内置方法,用于设置滚动条位置 this.chat.refs.message.setScrollTop(1200) |
组件参数描述
-
userInfo你必须为这个参数定义 userId 和 avatar 属性,也可以添加一些你需要属性。
userInfo = {
avatar: 'http://example/avatar.jpg', //user avatar, required parameters
userId: '5bf7cf25a069a537ffe7c324', //user id, required parameters
name: 'rigcky',
other: 'otherInfo'
}
复制代码
-
emoji如果设置emoji参数为 false ,则不显示emoji。如果你想添加更多的emoji,您可以设置这个参数为数组,内容为你所添加的emoji。
// add more emoji
emoji = [
{text: 'panda', content: ':panda_face:'},
{text: 'tiger', content: ':tiger:'},
{text: 'pig', content: ':pig:'}
]
复制代码
-
customEmoticon自定义的表情包,参数为数组类型
customEmoticon = [
{text: 'smile', url: 'http://example/emoticon.png'},
{text: 'angry', url: 'http://example/emoticon2.png'},
{text: 'weep', url: '...'}
]
复制代码
-
dataSource消息列表的数据源,数据格式如下:
const customEmoticon = [{
timestamp: 1545925494422,
userInfo: {
avatar: "http://example/2.png",
name: "游客1544365758856",
userId: "1544365758856"
},
value: "hello~"
}, {
timestamp: 1545925534218,
userInfo: {
avatar: "http://example/2.png",
name: "游客1544365758856",
userId: "1544365758856"
},
value: ":grinning:",
error: true //设置消息状态为失败,显示错误状态图标
}]
复制代码
-
messageListStyle消息列表的容器样式,你必须为其设置一个固定的高度,保证其不会被内容撑开,例如{width: '100%', height: 500} -
timestamp当前 dataSource 的数据发生变化时候必须重新设置该参数为当前的时间戳 -
timeFormat格式化时间参数,例如显示2019-2-1 20: 20设置为yyyy-MM-dd hh:mm
以上所述就是小编给大家介绍的《Chat-React基于react的聊天会话组件》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- java – Spring会话数据Redis – 从Redis Store获取有效会话,当前用户
- google-app-engine – GAE webapp2会话:创建和检查会话的正确过程
- 图解 Session(会话)
- 内网会话劫持
- Tomcat集群之会话保持
- Tomcat集群之会话保持
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
激荡十年,水大鱼大
吴晓波 / 中信出版社 / 2017-11-1 / CNY 58.00
【编辑推荐】 知名财经作者吴晓波新作,畅销十年、销量超过两百万册的《激荡三十年》续篇,至此完成改革开放四十年企业史完整记录。 作为时代记录者,吴晓波有意识地从1978年中国改革开放伊始,记录中国翻天覆地的变化和对我们影响至深的人物与事件,串成一部我们每个人的时代激荡史。而最新的这十年,无疑更壮观,也更扑朔迷离。 很多事情,在当时并未有很深很透的感受,回过头来再看,可能命运的轨迹就......一起来看看 《激荡十年,水大鱼大》 这本书的介绍吧!