关于urls路由在html上的调用困扰

2024-03-02 22:08

本文主要是介绍关于urls路由在html上的调用困扰,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于urls路由在html上的调用困扰

参考文章
1—>http://huacnlee.com/blog/django-url-routes-and-get-absolute-url/

  • django文档

    • https://docs.djangoproject.com/en/dev/ref/models/instances/?from=olddocs#get-absolute-url
    • https://docs.djangoproject.com/en/dev/topics/http/urls/#topics-http-urls
  • 常规的Templates里调用url地址

{% url apps.views.post post.user.slug,post.id %}或者 在url中加一个参数定义url名字调用url.py

  但是Template里面会用到很多,如果当参数有变动的时候,重构将会是很麻烦的事情。所以我需要调用一个固定的地方。Django 的 Model 里面有一个 get_absolute_url()的方法,这个东西是定义Model的对象的查看地址,主要是用在RSS与后台查看页面的,以前看RSS的文档里面的写法是直接组合URL地址,但urls.py我们又定义了url的格式,这样在项目中就出现了两处关于这个页面的url配置,这样的以后做修改的时候就会有可能出现遗漏。所以我们需要想办法当url的配置终一化,urls.py 是被 Django 定义为url定义的,理所当然关于 url 的配置就应当写在这里,哪么 models 里面的 get_absolute_url() 怎么得到 urls.py 里面的定义呢?
  下面是网上找的解决办法

  • urls.py
# -*- coding: utf-8 -*-
from django.conf.urls.defaults import *
from django.contrib import adminadmin.autodiscover()urlpatterns = patterns('',# Home:(r'^$','apps.views.home'),url(r'^post/(?P<slug>[a-zA-Z0-9_\-]+)[/]{0,1}$','apps.views.post',name='post_view'),# Admin:(r'^admin/r/', include('django.conf.urls.shortcut')),(r'^admin/(.*)',admin.site.root),# Other:(r'^static/(.*)','django.views.static.serve', {'document_root': './static/'}),
)
  • models.py
# -*- coding: utf-8 -*-
from django.db import models,connection
from django.contrib import admin
from django.core.urlresolvers import reverseclass Post(models.Model):title = models.CharField('标题',max_length=200)slug = models.CharField('slug',max_length=255,blank=True)summary = models.TextField('摘要',blank=True)body = models.TextField('正文')def get_absolute_url(self):return reverse('post_view',args=[self.slug])
  • views.py
# -*- coding: utf-8 -*-
from django.http import HttpResponse,Http404, HttpResponseRedirect, HttpResponseServerError
from django.template import Context, loader
from django.shortcuts import get_object_or_404def post(request,slug):post = Nonetry:post = Post.objects.get(slug = slug)except:return Http404()data = {'post' : post,}template = loader.get_template('post.html')context = Context(data)output = template.render(context)return HttpResponse(output)
  • templates/post.html
<div class="post"><h1>{{ post.title }}</h1><div class="url">URL:{{ post.get_absolute_url }}</div><div class="summary">{{ post.summary }}</div>
</div>

这篇关于关于urls路由在html上的调用困扰的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767576

相关文章

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

一分钟带你上手Python调用DeepSeek的API

《一分钟带你上手Python调用DeepSeek的API》最近DeepSeek非常火,作为一枚对前言技术非常关注的程序员来说,自然都想对接DeepSeek的API来体验一把,下面小编就来为大家介绍一下... 目录前言免费体验API-Key申请首次调用API基本概念最小单元推理模型智能体自定义界面总结前言最

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

关于Gateway路由匹配规则解读

《关于Gateway路由匹配规则解读》本文详细介绍了SpringCloudGateway的路由匹配规则,包括基本概念、常用属性、实际应用以及注意事项,路由匹配规则决定了请求如何被转发到目标服务,是Ga... 目录Gateway路由匹配规则一、基本概念二、常用属性三、实际应用四、注意事项总结Gateway路由

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo