{"id":1313,"date":"2021-07-10T00:18:59","date_gmt":"2021-07-09T15:18:59","guid":{"rendered":"http:\/\/www.agile-software.site\/?p=1313"},"modified":"2021-07-11T21:55:02","modified_gmt":"2021-07-11T12:55:02","slug":"django-summernote","status":"publish","type":"post","link":"https:\/\/agile-software.net\/?p=1313","title":{"rendered":"django-summernote"},"content":{"rendered":"\n<p>Summernote\u3092Django\u3067\u7c21\u5358\u306b\u5b9f\u88c5\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u305f\u30c4\u30fc\u30eb\u304cdjango-summernote\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u5b9f\u88c5\u74b0\u5883<\/h2>\n\n\n\n<p>\u4e0b\u8a18\u30d6\u30ed\u30b0\u3067\u4f5c\u6210\u3057\u305fDjango\u30d6\u30ed\u30b0\u306bsummernote\u3092\u5b9f\u88c5\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\nhttp:\/\/www.agile-software.site\/2021\/04\/11\/django%e8%a8%ad%e5%ae%9a\/\n\n\n\n<h2 class=\"wp-block-heading\">django-summernote\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h2>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>pip3 install django-summernote<\/code><\/pre><\/div>\n\n\n\n<div class=\"wp-block-jin-gb-block-box-with-headline kaisetsu-box1\"><div class=\"kaisetsu-box1-title\">pip\u306e\u30a2\u30c3\u30d7\u30b0\u30ec\u30fc\u30c9<\/div>\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>pip install --upgrade pip<\/code><\/pre><\/div>\n<\/div>\n\n\n\n<div class=\"wp-block-jin-gb-block-box-with-headline kaisetsu-box1\"><div class=\"kaisetsu-box1-title\">Django\u306e\u30a2\u30c3\u30d7\u30b0\u30ec\u30fc\u30c9<\/div>\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>pip install --upgrade django<\/code><\/pre><\/div>\n<\/div>\n\n\n\n<h2 class=\"wp-block-heading\">settings.py\u306b\u8ffd\u8a18<\/h2>\n\n\n\n<p>INSTALLED_APPS\u306b&#8217;django_summernote&#8217;\u3092\u8ffd\u52a0\u3057\u3066\u3001X_FRAME_OPTIONS = &#8220;SAMEORIGIN&#8221;\u3082<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>INSTALLED_APPS = [\n    &#39;blog.apps.BlogConfig&#39;,   # \u30a2\u30d7\u30ea\n    &#39;django.contrib.admin&#39;,\n    &#39;django.contrib.auth&#39;,\n    &#39;django.contrib.contenttypes&#39;,\n    &#39;django.contrib.sessions&#39;,\n    &#39;django.contrib.messages&#39;,\n    &#39;django.contrib.staticfiles&#39;,\n    &#39;django_summernote&#39;,    # \u8ffd\u8a18\n]\n\nX_FRAME_OPTIONS = &quot;SAMEORIGIN&quot;   # \u8ffd\u8a18<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">urls.py\u306b\u8ffd\u8a18<\/h2>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"mysite\/urls.py\"><code>urlpatterns = [\n    path(&#39;admin\/&#39;, admin.site.urls),\n    path(&#39;summernote\/&#39;, include(&#39;django_summernote.urls&#39;)),   # \u8ffd\u8a18\n]<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">admin.py\u306b\u8ffd\u8a18<\/h2>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/admin.py\"><code>from django.contrib import admin\nfrom .models import Post, Category\nfrom django_summernote.admin import SummernoteModelAdmin\n\nclass PostAdmin(SummernoteModelAdmin):\n    summernote_fields = &#39;__all__&#39;\n\n\nadmin.site.register(Post,PostAdmin)\nadmin.site.register(Category)<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3<\/h2>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>python3 manage.py migrate<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3092\u6587\u7ae0\u5316\u3059\u308b<\/h2>\n\n\n\n<p>\u3053\u306e\u307e\u307e\u3060\u3068\u6587\u7ae0\u3092\u4f5c\u6210\u3057\u305f\u6642\u306bHTML\u306e\u30b3\u30fc\u30c9\u3067\u8868\u793a\u3055\u308c\u3066\u3057\u307e\u3044\u307e\u3059\u3002<br>\u305d\u308c\u3092\u9632\u3050\u305f\u3081\u306bpost_data.content\u3092safe\u306b\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>&lt;p&gt;{{ post_data.content|safe }}&lt;\/p&gt;<\/code><\/pre><\/div>\n","protected":false},"excerpt":{"rendered":"<p>Summernote\u3092Django\u3067\u7c21\u5358\u306b\u5b9f\u88c5\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u305f\u30c4\u30fc\u30eb\u304cdjango-summernote\u3067\u3059\u3002 \u5b9f\u88c5\u74b0\u5883 \u4e0b\u8a18\u30d6\u30ed\u30b0\u3067\u4f5c\u6210\u3057\u305fDjango\u30d6\u30ed\u30b0\u306bsummernote\u3092\u5b9f\u88c5\u3057\u3066\u3044\u304d\u307e\u3059\u3002 django-s<\/p>\n","protected":false},"author":1,"featured_media":1436,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jin_ogp_image_url":"","_jin_last_featured_id":0,"footnotes":""},"categories":[8],"tags":[],"class_list":["post-1313","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-django"],"_links":{"self":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts\/1313","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1313"}],"version-history":[{"count":2,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts\/1313\/revisions"}],"predecessor-version":[{"id":1437,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts\/1313\/revisions\/1437"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/media\/1436"}],"wp:attachment":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1313"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1313"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1313"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}