Message
所有的微信消息会被封装成一个Message 类
Message
Kind: global class
instance
.from() ⇒
Contact
|null
.to() ⇒
Contact
|null
.room() ⇒
Room
|null
~~[.content()](message.md#message-content)~~.text() ⇒
string
.say(textOrContactOrFile, [mention]) ⇒
Promise.
.type() ⇒
MessageType
.self() ⇒
boolean
.mention() ⇒
Promise.>
.mentionSelf() ⇒
Promise.
.forward(to) ⇒
Promise.
.age() ⇒
number
~~[.file()](message.md#message-file)~~.toFileBox() ⇒
Promise.
.toContact() ⇒
Promise.
static
message.from() ⇒ Contact
Contact
获取发送消息的联系人
Kind: instance method of Message
Example
message.to() ⇒ Contact
| null
Contact
| null
获取消息发送的联系人。在微信群中,Message.to() 会返回null,使用Message.room()获取微信群信息。
Kind: instance method of Message
Example
message.room() ⇒ Room
| null
Room
| null
获取消息所在的微信群,如果这条消息不在微信群中,会返回null
Kind: instance method of Message
Example
message.content()
Deprecated
请使用 message.text()
Kind: instance method of Message
message.text() ⇒ string
string
获取消息的文本内容。
Kind: instance method of Message
Example
message.toRecalled() ⇒ Promise
Promise
获取撤回消息的文本内容。
Kind: instance method of Message
Example
message.say(textOrContactOrFileOrUrl, [mention]) ⇒ Promise.
Promise.
回复多媒体、微信名片、文本或者链接给这条消息的发送者。
这个功能是否能实现取决于你使用的是哪一个Puppet, 详情参考:puppet兼容性列表
Kind: instance method of Message
See: Examples/ding-dong-bot
// 1. send Image
if (/^ding$/i.test(m.text())) { const fileBox = FileBox.fromUrl('https://chatie.io/wechaty/images/bot-qr-code.png') await msg.say(fileBox) }
// 2. send Text
if (/^dong$/i.test(m.text())) { await msg.say('dingdingding') }
// 3. send Contact
if (/^lijiarui$/i.test(m.text())) { const contactCard = await bot.Contact.find({name: 'lijiarui'}) if (!contactCard) { console.log('not found') return } await msg.say(contactCard) }
})
// 4. send UrlLink
if (/^link$/i.test(m.text())) { const linkPayload = new UrlLnik({ description : 'Netty', thumbnailUrl: 'http://mmbiz.qpic.cn/mmbiz_jpg/48MFTQpxichmmxEoXZ1w7eno72H2MQdx1WC6JiaVdYRmwAp4MCcQbctE2IE7jWqkWOlgMPqMBXVAdR1N46xEibvoQ/640?wx_fmt=jpeg&wxtype=jpeg&wxfrom=0', title : 'Netty', url : 'http://mp.weixin.qq.com/s?__biz=MzU2MDU3MzE1Mg==&mid=2247484375&idx=1&sn=5ee91b0a8607a1766b5212a23d3c9179&chksm=fc04bc58cb73354e798403bcc03e293149bb115a0755940e334c0fbe33d7c3b0b0797120a213&scene=0&xtrack=1#rd', }) await msg.say(linkPayload) } .start()
message.self() ⇒ boolean
boolean
查看这条消息是否为机器人发送的。
Kind: instance method of Message
Returns: boolean
- - Return true
for send from self, false
for send from others.
Example
message.mention() ⇒ Promise.
Promise.
获取在群中@的用户列表。
Kind: instance method of Message
Returns: Promise.>
- - Return message mentioned contactList
Example
message.mentionSelf() ⇒ Promise.
Promise.
获取机器人是否在群里被@ 了
Kind: instance method of Message
Returns: Promise.
- - Return true
for mention me.
Example
message.forward(to) ⇒ Promise.
Promise.
转发收到的消息
Kind: instance method of Message
message.date()
消息发送的时间
Kind: instance method of Message
message.age() ⇒ number
number
消息的时差
例如: 消息在8:43:01
发送的,当我们在wechaty 上收到消息的时候,时间是8:43:15
,那么 age() 为 8:43:15 - 8:43:01 = 14 (seconds)
Kind: instance method of Message
message.file()
Deprecated
使用 toFileBox
Kind: instance method of Message
message.toFileBox() ⇒ Promise.
Promise.
从消息中提取多媒体文件并把它 存入到FileBox 里面。
这个方法是否能实现,取决于用的是什么Puppet,具体请看:Puppet 兼容性列表
Kind: instance method of Message
message.toContact() ⇒ Promise.
Promise.
提取转发的微信好友名片内容,并封装成Contact 类型。
这个方法是否能实现,取决于用的是什么Puppet,具体请看:Puppet 兼容性列表
Kind: instance method of Message
Message.find()
在缓存中找消息。
Kind: static method of Message
Message.findAll()
在缓存中找消息
Kind: static method of Message
Last updated