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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

Q&A

解決済

1回答

876閲覧

ローカル機能するとあるjsの機能がHeroku上で機能しない

donut4

総合スコア148

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

0グッド

0クリップ

投稿2019/06/19 08:48

いつもお世話になっております。

Djangoでjavascriptを使ってサジェスト機能を実装しました。

ローカルでは正しく機能するのですが
Heroku上では上手く機能していません。

おそらくJavascripの書き方に問題があると思うのですが
見当がつきません。

どこが原因か見当のつく方がいらっしゃいましたら
可能性でもよいのでご教授いただければと思います。

よろしくお願いいたします。

{% load static %} <!doctype html> <html lang=ja> <head> <mata charset=UTF-8> <meta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0"> <script type="text/javascript" src="/static/jquery/jquery-3.2.1.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/sweetalert2@8"></script> <link type="text/css" rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/cupertino/jquery-ui.min.css" /> <script type="text/javascript" src="http://code.jquery.com/jquery-1.10.2.min.js"></script> <script type="text/javascript" src="http://code.jquery.com/ui/1.10.3/jquery-ui.min.js"></script> <link rel="stylesheet" type="text/css" href="{% static 'css/bootstrap.css' %}" /> <link rel="shortcut icon" href="{% static 'img/favicon.ico' %}"> <link rel="stylesheet" href="{% static 'css/limmys.css' %}" type="text/css"> <title>top</title> </head> <body> <div class="sentence1">test。</div> <div class="sentence2">test</div> <div class="sentence2sp">test/div> <form action="{% url 'findurl' %}" onsubmit="return search()" name="myForm" method="post"> {% csrf_token %} <div class="top_pull_style container"> <div class="btn-select1"> <input id="place" onfocus="clearstr(this.id);" value="どこで" name="place" size="20" maxlengh="50" class="label1" /> </div> <div class="btn-select2"> <input id="purpose" onfocus="clearstr(this.id);" value="なにを" name="purpose" size="20" maxlengh="50" class="label2" /> </div> <button onclick="submitt(); search();" type="button" class="btn-square-pop">検索</button > <div class="mainbox container"> <div class="container" id="loading" ><img id="gifobj" src="" /></div> <p class="container" id="saikounokekka" class="" style=""></p> </div> </form> <div id="fadeLayer"></div> </body> ★★★★★★<!--サジェスト機能-->★★★★★★ <script type="text/javascript"> var placeData = [ ['しんじゅく', '新宿'], //実際は下記3行を使ってDBからデータを持ってきている // {% for item in data %} // ['{{item.suggestkana}}', '{{item.suggest}}'], // {% endfor %} ]; $(function() { // 2オートコンプリート機能を適用 $('#place').autocomplete({ source: function(request, response) { var re = new RegExp('^(' + request.term + ')'), list = []; $.each(placeData, function(i, values) { if(values[0].match(re) || values[1].match(re)) { list.push(values[1]); } }); response(list);}, autoFocus: true, delay: 500, minLength: 2 }); }); </script> <!--フォームチェック--> <script> function search() { if (document.getElementById('place').value == "" || document.getElementById('place').value == "どこで" ) { Swal.fire({ type:"warning", title: "場所はどちらですか?", text: "", }); } else if(document.getElementById('purpose').value == "" || document.getElementById('purpose').value == "なにを" ) { Swal.fire({ type:"warning", title: "何をされますか?", text: "", }); } } function submitt() { if ( document.getElementById('place').value !== "どこで") { if(document.getElementById('place').value !== "" ){ if(document.getElementById('purpose').value !== "なにを"){ if(document.getElementById('purpose').value !== ""){ var target = document.getElementById("fadeLayer"); target.style.visibility = "visible"; outputgif(); setTimeout(loadstart, 5000); } } } } } function loadstart(){ document.myForm.submit(); } </script> <!--フォーカス時テキストエリアクリア処理--> <script> function clearstr(elm) { var elm = document.getElementById(elm); elm.value = ''; }; </script> <!-- 二つなにかをセットされたらロード中gif画像を表示させるスクリプト --> <script> function outputgif(){ document.getElementById("gifobj").src = "/static/img/gif-load.gif";; var elm = document.getElementById("saikounokekka"); elm.classList.add("saikounokekka"); elm.textContent = 'ロード中'; } </script> </html>

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ところどころ、http://でCDNを参照している箇所が見受けられます。HerokuはHTTPSですので、HTTPによるJavaScriptへの参照はブラウザがブロックしてしまいます。

https://での参照に書き直しましょう(ローカルなどでHTTP環境から見ても、https://に書き換えたことによる害はありません)。

投稿2019/06/19 08:52

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

donut4

2019/06/19 09:12

ご返信ありがとうございます。 まさにご指摘の箇所が原因でした。 修正してデプロイしたらちゃんと機能するようになりました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問