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

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

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

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

1454閲覧

Djangoでcloudinaryでのレスポンシブ対応をしたい

Junichi_A

総合スコア11

Django

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2019/04/04 15:26

前提・実現したいこと

DjangoでWEBサービスを開発しています。画像の表示をレスポンシブにしたく、cloudinaryを導入いたしました。
テンプレートで、pxでのサイズ指定はできるのですが、それ以外のcropなどの指定ができず、困っています。

>参考
https://cloudinary.com/documentation/django_image_manipulation

発生している問題・エラーメッセージ

画像ファイルの表示をcloudinaryで行なっているが、サイズ調整以外のパラメータ設定ができない。

該当のソースコード

python

1#views.py 2import cloudinary 3import cloudinary.uploader 4import cloudinary.api 5 6class IndexView(generic.ListView): 7 model = Ex # 使用するモデル 8 template_name = 'ex/index.html' 9~~~ 10 def get_context_data(self, **kwargs): 11 """ICON_EFFECTSを渡したい""" 12 context = super().get_context_data(**kwargs) 13 context['ICON_EFFECTS'] = dict( 14 format = "png", 15 transformation = [ 16 dict(height=95, width=95, crop="thumb", gravity="face", radius=20), 17 dict(angle=10), 18 ] 19 ) 20 return context 21

python

1#index.html 2{% load cloudinary %} 3{% load staticfiles %} 4 5 <div class=""> 6 {% if post.image %} 7 {% cloudinary post.image.url ICON_EFFECTS %} 8 {% endif %} 9 </div> 10 11 12ソースコード

試したこと

{% cloudinary post.image.url height=200 %}
と直接記載すると、height,width のみ反映されます。
レスポンシブにしたく、dictを渡したいのですが、反映されません。
(ICON_EFFECTS自体が反映されていない)

補足情報(FW/ツールのバージョンなど)

Django Version: 2.1.4
Python Version: 3.7.2

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

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

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

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

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

guest

回答1

0

自己解決

公式のサポートにご返答いただきました。
親要素をつけて、max-width設定したところ、できました。

<head> /// <style type="text/css"> .blog-bg img { max-width: 100%; height: auto; width /***/:auto; } </style> /// </head> <body> /// <a class="blog-bg" href="{% url 'excercises:detail' post.pk %}"> {% if post.image %} {% cloudinary post.image width='auto' crop='lfill' responsive='true' height=300 fetch_format="auto" %} {% endif %} </a> /// <script type="text/javascript"> var cl = cloudinary.Cloudinary.new({cloud_name: "hmtmgjlio"}); cl.responsive(); </script> </body>

投稿2019/05/05 08:39

Junichi_A

総合スコア11

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問