关于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

相关文章

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

python如何调用java的jar包

《python如何调用java的jar包》这篇文章主要为大家详细介绍了python如何调用java的jar包,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录一、安装包二、使用步骤三、代码演示四、自己写一个jar包五、打包步骤六、方法补充一、安装包pip3 install

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.