首页 > 解决方案 > 将 django-cms 集成到现有项目中 - 错误:TemplateDoesNotExist at /news/cms_wizard/create/

问题描述

我正在尝试将新闻功能添加到现有的 django 项目中。我决定使用 django-cms 来提供功能。就将 django-cms 集成到现有项目中而言,缺少文档,几乎没有什么用处。

我已经看过这个问题这个问题,但提供的答案只带我到目前为止。

我想要做的是能够拥有包含静态数据的页面,并使用 django-cms 允许具有正确权限的用户创建新页面和/或更新现有页面。

目前,当我运行python manage.py runserver并导航到 时http://127.0.0.1:8000/news/1/,我收到以下错误消息:

NoReverseMatch at /news/1/ Reverse for 'pages-root' 未找到。“pages-root”不是有效的视图函数或模式名称。

以下是我的软件组件的相关版本信息:

Django                3.2.2  
django-classy-tags    2.0.0  
django-cms            3.8.0  
django-formtools      2.3    
django-sekizai        2.0.0  
django-treebeard      4.5.1  
djangocms-admin-style 2.0.2 

settings.py(相关部分)

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',

    'django.contrib.sites',
    'cms',
    'menus',
    'treebeard',

    'sekizai',

    'news',
]

SITE_ID = 1

SITE_ID = 1
X_FRAME_OPTIONS = "ALLOWALL"
XS_SHARING_ALLOWED_METHODS = ["POST", "GET", "OPTIONS", "PUT", "DELETE"]

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',

    'django.middleware.locale.LocaleMiddleware',
    'cms.middleware.user.CurrentUserMiddleware',
    'cms.middleware.page.CurrentPageMiddleware',
    'cms.middleware.toolbar.ToolbarMiddleware',
    'cms.middleware.language.LanguageCookieMiddleware',

]

LANGUAGES = [
    ('en', 'English'),
]

CMS_TEMPLATES = (
    ('template_1.html', 'Template One'),
    ('template_2.html', 'Template Two'),
)    

ROOT_URLCONF = 'blogproject.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',

                'sekizai.context_processors.sekizai',
                'cms.context_processors.cms_settings',
            ],
        },
    },
]

WSGI_APPLICATION = 'blogproject.wsgi.application'


# Database
# https://docs.djangoproject.com/en/3.2/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}


# Password validation
# https://docs.djangoproject.com/en/3.2/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/3.2/topics/i18n/

LANGUAGE_CODE = 'en'

# ...

myproj/myproj/urls.py

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('news/', include('news.urls')),
    path('admin/', admin.site.urls),
]

新闻/urls.py

from django.urls import include, path
from . import views

#app_name = 'news'


urlpatterns = [
    path('<int:id>/', views.detail, name='detail'),
    path('', include('cms.urls')),
]

新闻/model.py

from django.db import models
from cms.models.fields import PlaceholderField

# Create your models here.

class NewsItem(models.Model):
    # your fields
    title = models.TextField()
    content = PlaceholderField('placeholder_name')

新闻/views.py

from django.shortcuts import get_object_or_404, render

from .models import NewsItem


# Create your views here.
def detail(request, id):
    object = get_object_or_404(NewsItem, id=id)

    return render(request, 'news/detail.html', { 'object': object })

新闻/模板/新闻/detail.html

{% load cms_tags %}
{{ object.title }}
{% render_placeholder object.content language 'en' %}

新闻/模板的输出

news/templates/
└── news
    ├── cms_wizard
    │   └── create
    │       └── template_1.html
    ├── detail.html
    └── template_1.html

我有两个问题需要帮助解决:

  1. 我去时显示的页面http://127.0.0.1/news/没有使用我的网站模板 - 而是使用来自 django-cms 的模板。如何更改它以使用我自己的模板?

  2. 当我http://127.0.0.1/news/1只显示我的页面标题时 - 可编辑小部件没有移位,并且我无法按预期输入文本。我该如何解决?

标签: pythondjangodjango-cms

解决方案


  1. 要解决找模板的问题,你需要熟悉找模板的方法。从文档中:

从文件系统上的 Django 应用程序加载模板。对于 INSTALLED_APPS 中的每个应用程序,加载程序都会查找模板子目录。如果该目录存在,Django 会在其中查找模板。

例如,对于此设置:

INSTALLED_APPS = ['myproject.polls', 'myproject.music']

… 然后 get_template ('foo.html') 将在这些目录中查找 foo.html,顺序如下:

 / path / to / myproject / polls / templates /
 / path / to / myproject / music / templates /

...并将使用它首先找到的那个。

由此我们可以得出结论,有必要在 INSTALLED_APPS 中将 'news' 放在 'cms' 之前:

INSTALLED_APPS = [
     ...
    'news',
     ...
     'cms',
     ...
] 
  1. 通常文本本身显示在详细信息页面上,无法更改它。他们在管理页面上更改它:

     from django.contrib import admin
     from .news.model import NewsItem
    
     class NewsItemAdmin(admin.ModelAdmin):
          pass
    
     admin.site.register(NewsItem, NewsItemAdmin)
    

如果您需要在您的网站上显示一个页面进行编辑,那么您可以使用表单


推荐阅读