Django专栏
文章平均质量分 81
Django实战,Django与Ruby on Rails (RoR)的对比,深入Django框架。
ThinkInside
这个作者很懒,什么都没留下…
展开
-
Django+jquery 什锦(1):集成Django和jquery
在《Django实战》系列中,简单的提到了Django + jquery 实现ajax,但总感觉“意犹未尽”,很多事情都没有说清楚。所以打算专门讨论一下这个话题。ajax可以用在web应用的方方面面,所以用“什锦小菜”的方式,用几个单独的例子来说明常见的使用情况。如果你一定要问为什么是jquery而不是别的什么ajax框架,请参考这里。根据Django官方的说法,Django没有提供内置的aj原创 2012-02-18 00:28:46 · 10302 阅读 · 1 评论 -
深入Django(2):自定义ORM
Django的Model使用ORM来操作数据库,通常我们只需关注Model类本身,Django自己会处理到数据库的映射。但凡事总有例外,有时需要改变默认的映射行为。Django对此也提供了丰富的支持。1. 自定义字段名默认的字段名与属性名相同,可以通过字段的db_column属性自定义,如 where = models.CharField(max_length=400原创 2012-02-14 01:00:01 · 4313 阅读 · 2 评论 -
Django技巧:改变Admin中显示的应用(app)名称
Django的Admin提供了强大的功能,很多人可能会基于Admin开发自己的应用。在Admin默认的管理界面中,Model类的显示名称可以通过国际化的方法来改变,其实app的名称也可以自己指定,你甚至可将同一个应用下的Model类分配到不同的app中去分组,如下图:以《Django实战》中的Model类为例,可以这样指定Order类显示的应用名称:class Order(mode原创 2012-02-13 18:18:29 · 6366 阅读 · 3 评论 -
深入Django(1): 通用视图 (generic views)
如果对Django的基础部分尚不熟悉,请参考《Django实战》系列。欢迎访问Django专栏:http://blog.csdn.net/column/details/django.html内容提要1. 回顾Django的视图函数(view function)2. 在视图函数中使用模板3. 简化视图函数的两个工具4. 使用通用视图函数5. Django提供的通用原创 2012-02-12 00:57:05 · 6094 阅读 · 2 评论 -
Django实战(24):总结
这个实战系列暂时就告一段落了,时间和能力的关系,有些地方写的不够清楚明白,代码也没有整理出来。未尽事宜将在以后逐步补全。希望通过这个系列,你能够掌握使用Django开发一个web应用的基本过程。现在简单整理一下《Django实战系列》的内容:0. 如果你以前没有接触过Django,你可能需要这些准备知识: URLconf+MTV:Django眼中的MVC Dja原创 2012-02-10 16:58:38 · 10190 阅读 · 17 评论 -
Django实战(23):权限控制
我们已经实现了登录和注销功能,但是它还没有起作用。因为匿名用户还是可以通过直接输入url:http://localhost:8000/depotapp/product/list/ 访问到产品管理界面。这就好像你在门上加了把锁,却没有把窗户关上一样。所以我们还需要进行访问控制。我们这里实现最简单的控制,非登录用户禁止访问产品管理界面。在Django里面,只需要在相应的视图函数前面增加@login原创 2012-02-10 15:50:24 · 5981 阅读 · 4 评论 -
Django实战(22):处理登录和注销
广告时段:转载请保留源地址:http://blog.csdn.net/thinkinside/article/details/7247171,并欢迎访问我的Django专栏:http://blog.csdn.net/column/details/django.html前一节我们实现了用户管理,本节对用户登录和登出进行处理。由于我们已经引入了django.contrib.auth应用,用户的登录原创 2012-02-10 10:29:42 · 9840 阅读 · 2 评论 -
Django实战(21):使用内置的Amin管理用户
到目前为止,我们开发的所有功能都是匿名访问的,这显然不够安全。通常我们会要求注册的用户通过用户名和密码登录,只有登录后的用户才可以管理产品。套用专业的说法就是:第一步是认证,验证用户是否是他所宣称的那个人;第二步是授权,验证用户是否拥有执行某种操作的权限。Django已经提供了一个django.contrib.auth应用来处理登录、登出和权限验证,同时还提供了django.contrib.a原创 2012-02-09 23:44:05 · 5567 阅读 · 0 评论 -
Django实战(20):分页(Pagination)
在上一节我们实现了针对某个产品的订单订阅功能。但是我们可能需要直接在站点上查询所有的订单。显然,随着时间的增长订单会越来越多,所以分页(Pagination)是个好办法:每次只显示一部分订单。分页是Web应用常用的手法,Django提供了一个分页器类Paginator(django.core.paginator.Paginator),可以很容易的实现分页的功能。该类有两个构造参数,一个是数据的原创 2012-02-09 20:33:58 · 4246 阅读 · 2 评论 -
Django实战(19):自定义many-to-many关系,实现Atom订阅
记得有人跟我说过,rails的has_many :through是一个”亮点“,在Django看来,该功能简直不值一提。rails中的many-to-many关联中,还需要你手工创建关联表(写migration的方式),而has_many :through的”语法“只不过是为了自定义关联关系:通过一个中间的、到两端都是many-to-one的模型类实现多对多关联。在Django中,many-t原创 2012-02-09 15:30:45 · 3299 阅读 · 1 评论 -
Django实战(18):提交订单
原文地址:http://blog.csdn.net/thinkinside/article/details/7240914,转载请保留。另外欢迎访问Django专栏。前面的内容已经基本上涵盖了Django开发的主要方面,我们从需求和界面设计出发,创建模型和修改模型,并通过scaffold作为开发的起点;在scaffold的基础上重新定制模板,并且通过Model类和Form类对用户输入的数据原创 2012-02-08 11:51:47 · 5109 阅读 · 4 评论 -
Django实战(17):ajax !
继续上一节未完成的任务,现在让我们来通过ajax请求后台服务。当然首选要实现后台服务。关于“加入购物车”,我们需要的服务是这样定义的:url: http://localhost:8000/depotapp/API/cart/items/postpost数据: product = product_id处理过程: 根据product_id,将product加入购物车返回:购物车中的原创 2012-02-07 15:02:17 · 5924 阅读 · 5 评论 -
Django实战(16):Django+jquery
已经开通了Django专栏,本系列的文章会持续加入。现在我们有了一个使用json格式的RESTful API,可以实现这样的功能了:为了避免在产品列表和购物车之间来回切换,需要在产品列表界面显示购物车,并且通过ajax的方式不刷新界面就更新购物车的显示内容。ajax框架的选择关于ajax框架的选择,看图不说话:我不管你选的是什么,反正我是选了jquery。原创 2012-02-07 00:50:42 · 9511 阅读 · 4 评论 -
Django实战(15):Django实现RESTful web service
原文地址:http://blog.csdn.net/thinkinside/article/details/7236807,欢迎转载,请保留链接!曾几何时,Ajax已经统治了Web开发中的客户端,而REST成为web世界中最流行的架构风格(architecture style)。所以我们的选择变得很简单:前端ajax访问后端的RESTful web service对资源进行操作。Djang原创 2012-02-06 14:48:19 · 17145 阅读 · 13 评论 -
Django实战(14):让页面联动起来
原文地址:http://blog.csdn.net/thinkinside/article/details/7235082,欢迎转载,请保留链接!上一节我们实现了一个”能看不能用“的购物车,现在我们来使用这个购物车。首先是产品目录界面中的”加入购物车“链接,我们希望点击这个按钮后,在购物车中添加该产品(添加的规则是如果购物车中已经有该产品就增加数量,如果没有就增加条目),然后显示购物车原创 2012-02-05 21:50:40 · 5711 阅读 · 3 评论 -
Django实战(13):在session中保存购物车
现在,我们有了一个产品目录界面,用户如果看到满意的产品,就可以将其放入购物车。下面就让我们来实现购物车的功能。首先要做一下简单的分析和设计。购物车应该显示一系列产品的清单,其中列出了买方选中的产品。但是这个清单没有必要马上保存到数据库,因为直到付款之前,用户随时都有可能改变主意。我们只需要在用户的session中记录这些产品就可以了。购物车中的条目购物车中的条目与产品(Prod原创 2012-02-05 16:43:45 · 10706 阅读 · 11 评论 -
Django实战(12):增加目录页,设定统一布局
针对上一节的新需求,界面设计师还为我们设计了一个新的界面,不仅仅是目录页,还包含了站点的整体风格,如下图:感谢界面设计师为我们提供的“又黑又硬”的工具条,这个看起来真的很酷。下面,让我们来享用她的工作成果吧。我们前面的scaffold已经生成了有继承关系模板,显然对于一些公用的内容应该放到base.html之中。但是我们先把这件事情放到一边,先来实现目录页。首选为目录页原创 2012-02-03 17:19:12 · 6057 阅读 · 7 评论 -
Django实战(11):修改Model类
我们已经实现了卖方的产品维护界面,根据最初的需求,还要为买方实现一个目录页:买方通过这个界面浏览产品并可以加入购物车。通过进一步需求调研,了解到产品有一个“上架时间”,在这个时间之后的产品才能被买方看到。并且买方应该先看到最新的产品。我们注意到,这个“新需求”需要对Product进行调整,增加一个日期属性date_available来保存“上架时间”。如同开发新功能一样,在修改的时候也应该原创 2012-02-03 13:10:50 · 7139 阅读 · 9 评论 -
Django实战(10):单元测试
尽早进行单元测试(UnitTest)是比较好的做法,极端的情况甚至强调“测试先行”。现在我们已经有了第一个model类和Form类,是时候开始写测试代码了。 Django支持python的单元测试(unit test)和文本测试(doc test),我们这里主要讨论单元测试的方式。这里不对单元测试的理论做过多的阐述,假设你已经熟悉了下列概念:test suite, test cas原创 2012-02-02 14:06:00 · 6379 阅读 · 2 评论 -
Django实战(9):实现Product的输入校验
让我们完成上一节中的任务:1.验证price>0:需要在Form中验证;2. 验证title唯一:在Model中验证;3. 验证image_url的扩展名:在Form中验证,还可以顺便在Model中将其改为URLField类型。之前生成的scaffold中已经实现了属性不能为空的验证:但是对于url格式,rul的后缀,title的唯一性都没有验证。首先在model中增加UR原创 2012-02-01 15:42:18 · 5695 阅读 · 7 评论 -
Django第一步
对于一个web框架,掌握了三部分的内容,就可以说是迈出了第一步。1. 准备开发环境2. 创建一个工程,并运行3. 开发hello world应用1. 准备环境 首先应该是安装python和django。这点官方网站有很详细的说明,网上也有很多教程,这里就不再重复了,只是表达一个对操作系统的观点: Mac OS:对程序员和用户都很友好原创 2012-01-29 18:31:32 · 7080 阅读 · 6 评论 -
URLconf+MTV:Django眼中的MVC
MVC是众所周知的模式,即:将应用程序分解成三个组成部分:model(模型),view(视图),和 controller(控制 器)。其中: M 管理应用程序的状态(通常存储到数据库中),并约束改变状态的行为(或者叫做“业务规则”)。 C 接受外部用户的操作,根据操作访问模型获取数据,并调用“视图”显示这些数据。控制器是将“模型”和“视图”隔原创 2012-01-29 15:29:27 · 6535 阅读 · 4 评论 -
Django的第一印象
Django (/ˈdʒæŋgoː/) 是用python语言写的开源web开发框架(open source web framework),鼓励快速开发,并遵循MTV设计模式。其主要目的是简便、快速的开发数据库驱动的网站。 Django遵守 BSD版权,目前最新的稳定版(stable)是2011年9月发布的v1.3.1。 Django 的名称来源于比利时的爵士音乐原创 2012-01-29 14:39:49 · 4405 阅读 · 4 评论 -
Django实战(8):对比RoR与Django的输入校验机制
rails有一个”简洁、完美的验证机制,无比强大的表达式和验证框架“。在《Agile Web Development with Rails 4th》一书的7.1节向我们展示了如何验证Product:class Product < ActiveRecord::Base validates :title, :description, :image_url, :presence => t原创 2012-02-01 00:40:35 · 5107 阅读 · 7 评论 -
Django实战(7):改造ProductList界面
有了上一节关于Django模板的基础,改造界面就很容易理解了。将界面设计师设计的页面中的内容根据复用程度分别放到基础模板base.html和专用模板productlist.html中。depot/templates/base.html {% block title %} 标题 {% endblock %} {%原创 2012-01-31 19:02:48 · 6570 阅读 · 3 评论 -
Django实战(6):对比RoR和Django的模板系统
scaffold的生成物虽然用处不大,但是给我们带来一些最佳实践。其中就有模板的继承和分区。如果你深入使用过rails的模板体系,那么恭喜你:你有超强的忍耐力!而且更重要的是,你只需要3分钟就可以理解Django的模板体系。让我们先回顾一下rails的模板系统:1. 你创建了一个xxxview,展现出一些数据。2. 你意识到,各个view都有一些共同的内容。因为rails也强调DR原创 2012-01-31 18:07:22 · 7093 阅读 · 5 评论 -
Django实战(5):引入bootstrap,设置静态资源
之前生成了Product类的scaffold,但是如同rails的开发者David所讲的那样,scaffold几乎没什么用。所以按照《Agile Web Development with Rails 4th》中的迭代计划,下一步的修改是美化list页面:但是这个界面还是太丑陋了。其实,有了bootstrap后,很多站点都变成了“又黑又硬”的工具条+“小清新”风格。我们即不能免俗,又懒得原创 2012-01-31 11:58:21 · 14054 阅读 · 5 评论 -
Django实战(4):scaffold生成物分析
在上一节用一个插件生成了类似rails的scaffold,其实无非就是URLconf+MTV。让我们看看具体都生成了哪些东西。首先是“入口”的定义即URLconf,打开urls.py:from django.conf.urls.defaults import patterns, include, urlfrom depot.views import hellourlpatterns原创 2012-01-30 23:25:41 · 6538 阅读 · 2 评论 -
Django实战(3):Django也可以有scaffold
rails有一个无用的”神奇“功能,叫做scaffold。能够在model基础上,自动生成CRUD的界面。说它无用,是因为rails的开发者David说,scaffold”不是应用程序开发的目的。它只是在我们构建应用程序时提供支持。当你设计出产品的列表该如何工作时,你依赖于“支架”“生成器”产生创建,更新,和删除的行为。然后在保留这个“动作”时你要替换由“生成器”生成的行为。有时候当你需要一个原创 2012-01-30 14:34:19 · 8303 阅读 · 17 评论 -
Django实战(2):创建第一个模型类
从模型开始开发似乎是个好主意。一方面模型是整个应用的核心,实现了应用的业务数据和对业务数据进行操作的约束,而视图和模板只是向用户提供操作和展现这些数据的界面;另一方面模型相对于系统的其他部分更加稳定,将模型先确定下来有助于系统其他部分的实现。DDD(领域驱动设计)更进一步将模型中的核心对象抽取出来作为“领域模型”。从Depot应用来看,产品(Product) 应该是模型中的核心对象之一。就原创 2012-01-30 11:27:38 · 9497 阅读 · 2 评论 -
Django实战(1):需求分析和设计
Depot是《Agile Web Development with Rails》中的一个购物车应用。该书中用多次迭代的方法,逐步实现购物车应用,使很多人走上了rails开发的道路。遗憾的是Django世界中好像没有类似的指引,也许是因为pythoner 不需要具体的例子。但是如果通过这样一个例子能够让更多的人加入pythoner的队伍,也是一大幸事。本文首先回顾一下depo原创 2012-01-29 19:56:52 · 8134 阅读 · 2 评论