質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.84%

  • JavaScript

    14245questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • HTML

    7783questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • Python

    5906questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

動的HTMLを他のHTMLへ埋め込む方法

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 77

limitman80

score 11

現在Pythonを使ってチャットボットの開発をしています。
よくある右下にボタンがあり、押すとニョロっとチャット画面が出てくる感じにしたいと思ってます。

BotUIを使ってチャットボット機能を実装する予定で、それっぽい画面を表示することは出来ました。
ただ、ただ次の画面に遷移した時にや前の画面に遷移した時に今までのやり取りが消えて全て最初からやり直しになってしまいます。
BotUIで生成されたHTMLをそのまま次画面に持ち込む方法は可能でしょうか?

チャットボットのHTMLになります。

    <div id="slide">
        <div id="slide-in">
            <div id="open-btn"><img src="img/open-btn.gif" width="20" height="20" /></div>
            <h7>開くかも</h7>
            <div id="slide-contents">
                <div class="botui-app-container" id="self-intro">
                    <bot-ui></bot-ui>
                </div>
            </div>
        </div>
    </div>
    <link rel="stylesheet" type="text/css" href="{{url_for('static', filename='css/botui-theme-default.css')}}">
    <script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
    <script src="https://cdn.jsdelivr.net/vue/latest/vue.min.js"></script>
    <script src="{{url_for('static', filename='js/botui.min.js')}}"></script>
    <script src="{{url_for('static', filename='js/chat.js')}}"></script>


これをtemplate extendsを使って表示したいHTMLに埋め込んでます。
この方法で何とか次画面にもチャットエリアの表示をすることは出来たのですが、この場合だと<bot-ui>タグ内が毎回新規作成されてしまうので仕様を満たさないです。

(function() {
  var botui = new BotUI('self-intro');

  //初期メッセージ.
  botui.message.add({
    content: 'こんにちは!'
  }).then(Questions);

  function Questions() {
    botui.message.add({
      cssClass:'custom-class',
      delay:1500,
      content: '何について,お話ししましょうか?'
    }).then(function() {
      return botui.action.button({
        autoHide: false,
        delay: 1500,
        action: [
          {icon: 'user-o', text: '来歴', value: 'carrier'},
          {icon: 'rocket', text: '趣味', value: 'hobby'},
          {icon: 'pencil', text: 'サイト', value: 'memotaro'}]
      });
    }).then(function(res) {
      botui.action.hide();
      switch (res.value) {
        case 'carrier': showCarrier(); break;
        case 'hobby': showHobby(); break;
        case 'memotaro': showMemotaro(); break;
        default: end();
      }
    });
  }
});


上記の内容がchat.jsになります。
入力待ちの状態をキープしたまま次画面に遷移できるのかがわかりません。

わかる方、宜しくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

+1

入力待ちの状態をキープしたまま次画面に遷移できるのかがわかりません。

ブラウザの遷移に頼っては実現できません(ページ全体が再読込されます)。ということで、

  • 普通のWebページをベースにするのであれば、Turbolinksなどを使って、ページ遷移をJavaScriptで再現させる
  • サイト全体をSPAで組む

などの手段が必要となります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.84%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • JavaScript

    14245questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • HTML

    7783questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • Python

    5906questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。