Help us understand the problem. What is going on with this article?

【djangoとJavaScript】django内でJavaScriptを使って画像を変化させたい

現在3ステップでしっかり学ぶ JavaScript入門という本を使ってJavaScriptを勉強しています。
というのもDjangoアプリケーションでいいねボタンを作っているのですがそれをAjaxを使って非遷移でカウンターを増やしたいのです・・・が全くうまくいかず。
これは付け焼刃の知識では仕方がないのでJavaScriptを学び、かつDjango上でJavaScriptを実際に動かす工程を踏まなきゃだめだな・・・と思ったわけです。

というわけでまず上記の教科書にこんなコードが掲載されていました。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Script-Type" content="text/javascript">
<meta http-equiv="Content-type" content="text/html; charset=UTF-8">
<title>イメージの操作</title>
<style type="text/css">
body {
    text-align: center;
}
</style>
<script type="text/javascript">
var imgs;
function init() {
    imgs = new Array(3);
    for (var i = 0; i <= (imgs.length - 1); i++) {
        imgs[i] = new Image(250, 207);
        imgs[i].src =  "images/pic" + i + ".jpg"
    }
}
window.onload = init;

var num = 0;
function changeImg() {
    document.myImg.src = imgs[num].src
    num++;
    if (num == 3) num = 0;
}
</script>
</head>
<body bgcolor="#FFFFFF">
<img src="images/off.jpg" name="myImg"
    width="250" height="207"
    onclick="changeImg()"
    onmouseout="this.src='images/off.jpg';"
>
</body>
</html>

まずDjangoの画像の配置ですが2つの方法があります。
以下のようにプロジェクト直下にmediaディレクトリを作成し、そこに画像を配置します。
画像へのパス↓

\mysite\media\off.jpg

つまりDjango使用する際には

imgs[i].src =  "images/pic" + i + ".jpg"

imgs[i].src =  "media/pic" + i + ".jpg"

に変更し

onmouseout="this.src='images/off.jpg';"

onmouseout="this.src= 'media/off.jpg';"

に変更すれば良いのです。



ただ、普通は共通部分mediaではなくアプリケーションごとにcssとimagesを設けてそこの画像を操作しますよね。
僕もチャレンジしたのですがやったら意外とめんどくさかったです。
とはいえ一応やり方を。

まずはアプリケーション内にstaticディレクトリを作成しその中に画像を配置します。
パスは以下のようになります。

\mysite(プロジェクト名)\javascript(アプリケーション名)\static\javascript(staticディレクトリの中には必ずアプリケーション名を書いたディレクトリを入れること)\images\off.jpg

ここで今度は

imgs[i].src =  "images/pic" + i + ".jpg"

imgs[i].src =  "javascript/static/javascript/images/" + i + ".jpg"

のように変更すれば良いような気がしますが実はこれはうまくいきません。
まずstaticディレクトリを呼び出すには{% load static %}と一文をテンプレート内に表記する必要があります。
さらにstaticルートを呼び出すためには"{%static ~ %}"という構文を使うため

imgs[i].src =  "{% static "javascript/images/pic" + i + ".jpg" %}"

とすれば良いと思ったのですが変数iの部分が動作しませんでした。
ここでいろいろ聞いた結果JavaScriptの変数はdjangoのレンダリング時には渡せないということでやるならすべてdjangoで書き換える必要があるようでした。
・・・。
それはいずれはやりたいですが今は勉強したばかりのJavaScriptをDjango上で動作させるということが主目的。
一旦それは保留です。


結局画像部分はループ構造を使わず

 <script type="text/javascript">
    var imgs;
    function init() {
          imgs = new Array(3);
        imgs[0] = new Image(250, 207);
        imgs[0].src =  "{% static "javascript/images/pic0.jpg" %}"
        imgs[1] = new Image(250, 207);
        imgs[1].src =  "{% static "javascript/images/pic1.jpg" %}"
        imgs[2] = new Image(250, 207);
        imgs[2].src =  "{% static "javascript/images/pic2.jpg" %}"
    }

としました。

最終的にこんなコードに。もう少し研究の余地がある気がしますね、これ。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
<html lang="ja">
{% load static %}
<link rel="stylesheet" type="text/css" href="{% static 'javascript/style.css' %}">
  <head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">

    <title>JavaScriptの実験</title>
  </head>
  <body>
    <h1>JavaScriptの実験</h1>


    <meta http-equiv="Content-Script-Type" content="text/javascript">
    <meta http-equiv="Content-type" content="text/html; charset=UTF-8">
    <style type="text/css">
    body {
        text-align: center;
    }
    </style>
    <script type="text/javascript">
    var imgs;
    function init() {
          imgs = new Array(3);
        imgs[0] = new Image(250, 207);
        imgs[0].src =  "{% static "javascript/images/pic0.jpg" %}"
        imgs[1] = new Image(250, 207);
        imgs[1].src =  "{% static "javascript/images/pic1.jpg" %}"
        imgs[2] = new Image(250, 207);
        imgs[2].src =  "{% static "javascript/images/pic2.jpg" %}"
    }
    window.onload = init;

    var num = 0;
    function changeImg() {
      document.myImg.src = imgs[num].src
      num++;
      if (num == 3) num = 0;

    }
    </script>
    </head>
    <body bgcolor="#FFFFFF">
    <img src= "{% static "javascript/images/off.jpg" %}" name="myImg"
        width="250" height="207"
        onclick="changeImg()"
        onmouseout="this.src='{% static "javascript/images/off.jpg" %}';"
    >



    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
  </body>
</html>




sr2460
pythonはじめたいです
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
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  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
ユーザーは見つかりませんでした