Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
7
Help us understand the problem. What is going on with this article?
@n0bisuke

Node.jsでLINE Botを作るときの複数リプライメモ #linedc

どこが配列になるっけ... がよく忘れるのでメモ

まずは通常

return client.replyMessage(event.replyToken, {
    type: 'text',
    text: responseMsg //実際に返信の言葉を入れる箇所
});

2件リプライ

return client.replyMessage(event.replyToken, [{
    type: 'text',
    text: '1件目'
  },
  {
    type: 'text',
    text: '2件目'
  }
]);

スクリーンショット 2021-06-10 10.36.09.png

一度のリプライは5件まで

現時点だと6件以上はエラーになります。

    return client.replyMessage(event.replyToken, [{
        type: 'text',
        text: '1件目'
      },
      {
        type: 'text',
        text: '2件目'
      },
      {
        type: 'text',
        text: '3件目'
      },
      {
        type: 'text',
        text: '4件目'
      },
      {
        type: 'text',
        text: '5件目'
      }
    ]);
  }

スクリーンショット 2021-06-10 10.38.41.png

テキストと画像を同時にリプライ

画像のメッセージオブジェクト詳細はこちらを参考にしましょう。

return client.replyMessage(event.replyToken, [{
    type: 'text',
    text: '1件目'
  },
  {
    type: 'image',
    originalContentUrl: 'https://i.gyazo.com/ff363c0d05710b9803349c9e5423cce1.png',
    previewImageUrl: 'https://i.gyazo.com/ff363c0d05710b9803349c9e5423cce1.png'
  }
]);

さらにスタンプも同時にリプライ

スタンプのメッセージオブジェクト詳細はこちらを参考にしましょう。

return client.replyMessage(event.replyToken, [{
    type: 'text',
    text: '1件目'
  },
  {
    type: 'image',
    originalContentUrl: 'https://i.gyazo.com/ff363c0d05710b9803349c9e5423cce1.png',
    previewImageUrl: 'https://i.gyazo.com/ff363c0d05710b9803349c9e5423cce1.png'
  },
  {
    type: 'sticker',
    packageId: '446',
    stickerId: '1988'
  }
]);

さらにFlex Messageも同時にリプライ

ここまでくるとJSONがぐちゃぐちゃですが一応できます。

JSON崩れるとバグるのでFLEX MESSAGE SIMULATORの利用はほぼマストかも。

return client.replyMessage(event.replyToken, [{
    type: 'text',
    text: '1件目'
  },
  {
    type: 'image',
    originalContentUrl: 'https://i.gyazo.com/ff363c0d05710b9803349c9e5423cce1.png',
    previewImageUrl: 'https://i.gyazo.com/ff363c0d05710b9803349c9e5423cce1.png'
  },
  {
    type: 'sticker',
    packageId: '446',
    stickerId: '1988'
  },
  {
    "type": "flex",
    "altText": "this is a flex message",
    "contents": {
      "type": "bubble",
      "body": {
        "type": "box",
        "layout": "vertical",
        "contents": [
          {
            "type": "button",
            "action": {
              "type": "postback",
              "label": "ぼたん1",
              "data": "button1",
              "displayText": "ほげほげ"
            },
            "gravity": "top"
          },
          {
            "type": "button",
            "action": {
              "type": "postback",
              "label": "ぼたん2",
              "data": "button2",
              "displayText": "ふがふが"
            }
          }
        ]
      }
    }
  }
]);

まとめ

複数メッセージは5件までなら送れますが、Flex Messageを使った瞬間にJSON地獄になるのでご利用は計画的に

7
Help us understand the problem. What is going on with this article?
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
n0bisuke
プロトタイピング専門スクール「プロトアウトスタジオ」で教えたりしてます。 プロフ -> https://dotstud.io/members/n0bisuke
dotstudio
全ての人がモノづくりを楽しむ世界を目指して活動しています。 ( https://dotstud.io ) プロトタイピングスクールの運営をしています。

Comments

No comments
Sign up for free and join this conversation.
Sign Up
If you already have a Qiita account Login
7
Help us understand the problem. What is going on with this article?