python - 将 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
我有两个问题需要帮助解决:
我去时显示的页面
http://127.0.0.1/news/
没有使用我的网站模板 - 而是使用来自 django-cms 的模板。如何更改它以使用我自己的模板?当我
http://127.0.0.1/news/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',
...
]
通常文本本身显示在详细信息页面上,无法更改它。他们在管理页面上更改它:
from django.contrib import admin from .news.model import NewsItem class NewsItemAdmin(admin.ModelAdmin): pass admin.site.register(NewsItem, NewsItemAdmin)
如果您需要在您的网站上显示一个页面进行编辑,那么您可以使用表单。
推荐阅读
- r - 根据列中的最大值对列进行排序 - R 数据框排列
- javascript - 无法将数据从父组件传递到子组件
- regex - 处理条件多次捕获正则表达式?
- javascript - 在子进程的数据事件中使用 setTimeout 是否有理由导致任意长时间的延迟?
- ios - 生成的 IPA 太小,我无法在我的 mac 上打开它
- gradle - 如何解决 IntelliJ 中的“无法将 'String' 分配给 'Publication'”Gradle 错误?
- google-apps-script - Google Sheet 在单元格具有特定值时发送电子邮件
- javascript - SyntaxError:不能在模块外使用 import 语句:运行 Jest-expo 测试时
- java - 重新生成相同的布局
- oracle - 如何知道数据库中某处是否使用了 db-link