Django

·   Django流程

·   Django url

·   Django view

·   Django form

①:Django流程介绍

MTV模式

  注明的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层;他们之间以一种插件似的,松耦合的方式连接在一起.

  模型负责业务对象与数据库的对象(ORM),视图负责与用户的交互(页面),控制器(C)接受用户的输入调用模型和视图完成用户的请求.

注: 什么是松耦合:简单的说,松耦合是一个 重要的保证互换性的软件开发方法.

Django的MTV模式本质上与MVC模式没有什么差别,也是各组件之间为了保持松耦合关系,只是定义上有些许不同,Django的MTV分别代表:

Model(模型):负责业务对象与数据库的对象(ORM)

Template(模版):负责如何把页面展示给用户

View(视图):负责业务逻辑,并在适当的时候调用Model和Template

此外,Django还有一个url分发器,它的作用是将一个个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template

②:Django URL

URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。URL的家在是从配置文件中开始。

参数说明:

  ·   一个正则表达式字符串

  ·   一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串

  ·   可选的要传递给视图函数的默认参数(字典形式)

  ·   一个可选的name参数

下面是一个示例URLconf:

  1. from django.conf.urls import url
  2.  
  3. from . import views
  4.  
  5. urlpatterns = [
  6. url(r'^articles/2003/$', views.special_case_2003),
  7. url(r'^articles/([0-9]{4})/$', views.year_archive),
  8. url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
  9. url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9]+)/$', views.article_detail),
  10. ]

注释:

  ·  To capture a value from the URL, just put parenthesis around it.

   (从URL中捕获值,只是把它周围的括号。)

  • There’s no need to add a leading slash, because every URL has that. For example, it’s ^articles, not ^/articles.

   (没有必要添加一个领先的削减,因为每个URL。例如,它的^的文章,而不是^ /文章。)

  · The 'r' in front of each regular expression string is optional but recommended. It tells Python that a string is “raw” – that nothing in the string should be escaped. See Dive Into Python’s explanation.

(每个正则表达式字符串前面的'R'是可选的,但建议。它告诉Python字符串是“原始” - 没有什么字符串中应该进行转义。见深入Python的解释。)

Example requests:

  · A request to /articles/2005/03/ would match the third entry in the list. Django would call the functionviews.month_archive(request, '2005', '03').

(请求/文章/ 2005/03 /匹配列表中的第三项,Django的将调用函数views.monthly存档(要求下,'2005','03')。)

  · /articles/2005/3/ would not match any URL patterns, because the third entry in the list requires two digits for the month.

  (/文章/ 2005/3 /不匹配任何URL模式,因为第三个条目列表中需要两个数字的月. .)

  · /articles/2003/ would match the first pattern in the list, not the second one, because the patterns are tested in order, and the first one is the first test to pass. Feel free to exploit the ordering to insert special cases like this. Here, Django would call the function views.special_case_2003(request)

  (/文章/ 2003 /将匹配第一个模式列表中,没有第二个,因为模式是为了进行测试.第一个是第一个测试通过,随时利用顺序插入这样的特殊情况,这里,Django所说的功能的观点。特殊情况2003(请求))

  · /articles/2003 would not match any of these patterns, because each pattern requires that the URL end with a slash.

  (/文章/ 2003不匹配任何这些模式,因为每个模式要求以斜线结尾的URL。)

  · /articles/2003/03/03/ would match the final pattern. Django would call the functionviews.article_detail(request, '2003', '03', '03').

  (/文章/ 2003/03/03 /将最终的模式相匹配,Django将调用函数views.article细节(的要求,'2003','03','03')。)

Named groups

  · The above example used simple, non-named regular-expression groups (via parenthesis) to capture bits of the URL and pass them as positional arguments to a view. In more advanced usage, it’s possible to use named regular-expression groups to capture URL bits and pass them as keyword arguments to a view.

(上面的例子中使用简单,non-named正则表达式组(通过括号)捕捉到的URL,将他们作为一个视图的位置参数。在更高级的用法,可以使用指定的正则表达式组捕获的URL)

  · In Python regular expressions, the syntax for named regular-expression groups is (?P<name>pattern), where name is the name of the group and pattern is some pattern to match.

(在Python正则表达式,命名正则表达式组的语法是(?P <名>的模式),其中name是组的名称和模式是某种模式相匹配。)

  · Here’s the above example URLconf, rewritten to use named groups:

(下面是上面的例子中的URLconf,改写使用命名组:)

  1. import re
  2.  
  3. ret=re.search('(?P<id>\d{3})/(?P<name>\w{3})','weeew34ttt123/ooo')
  4.  
  5. print(ret.group())
  6. print(ret.group('id'))
  7. print(ret.group('name'))

正则知识

  1. from django.conf.urls import url
  2.  
  3. from . import views
  4.  
  5. urlpatterns = [
  6. url(r'^articles/2003/$', views.special_case_2003),
  7. url(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),
  8. url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
  9. url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/$', views.article_detail),
  10. ]

This accomplishes exactly the same thing as the previous example, with one subtle difference: The captured values are passed to view functions as keyword arguments rather than positional arguments. For example:

(这完成了前面的例子一样,有一个微妙的差异:捕获的值传递给视图函数作为关键字参数而不是位置参数。例如:)  

A request to /articles/2005/03/ would call the function views.month_archive(request, year='2005',month='03'), instead of views.month_archive(request, '2005', '03').

(的请求/用品/ 2005/03/会调用函数views.monthly存档(要求,今年='2005',一个月='03'),而不是views.monthly存档(要求下,'2005','03')。)

A request to /articles/2003/03/03/ would call the function views.article_detail(request, year='2003',month='03', day='03').

(请求/文章/ 2003/03/03 /将调用该函数的观点。文章细节(请求,年= ' 2003 ',月=“03”,天=“03”)。)

In practice, this means your URLconfs are slightly more explicit and less prone to argument-order bugs – and you can reorder the arguments in your views’ function definitions. Of course, these benefits come at the cost of brevity; some developers find the named-group syntax ugly and too verbose.

(在实践中,这意味着你的URLconf稍微更明确,不容易参数顺序错误 - 你可以在你的意见'函数定义重新排序的参数。当然,这些优点来在简短的费用;一些开发商找到命名组的语法丑陋,太冗长。)

常见写法实列:

Captured arguments are always strings:

Each captured argument is sent to the view as a plain Python string, regardless of what sort of match the regular expression makes. For example, in this URLconf line:

(每个捕获的参数发送到视图作为普通的Python字符串,无论什么样的匹配正则表达式做。例如,在该URL配置行:)

  1. url(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),

...the year argument passed to views.year_archive() will be a string,

(…参数传递给视图。年存档()将是一个字符串,)

not an integer, even though the [0-9]{4} will only match integer strings.

(不是整数,即使[0-9]{4}将只匹配整数串。)

Including other URLconfs :

At any point, your urlpatterns can “include” other URLconf modules. This essentially “roots” a set of URLs below other ones.

(在任何时候,您的网址模式可以“包含”其他的URLconf模块。这实质上是“根”的一套低于其他的网址。)

For example, here’s an excerpt of the URLconf for the Django website itself. It includes a number of other URLconfs:

(例如,这里的URL配置为Django的网站本身的摘录。它包括许多其他URL配置的:)

  1. from django.conf.urls import include, url
  2.  
  3. urlpatterns = [
  4. # ... snip ...
  5. url(r'^community/', include('django_website.aggregator.urls')),
  6. url(r'^contact/', include('django_website.contact.urls')),
  7. # ... snip ...
  8. ]

 Passing extra options to view functions:

URLconfs have a hook that lets you pass extra arguments to your view functions, as a Python dictionary.

(URLconf中有一个挂钩,可以传递额外的参数给您的视图功能,作为一个Python字典。)

The django.conf.urls.url() function can take an optional third argument which should be a dictionary of extra keyword arguments to pass to the view function.

(该django.conf.urls.url()函数可以接受这应该是额外的参数的字典传递给视图功能可选的第三个参数。)

For example:

  1. from django.conf.urls import url
  2. from . import views
  3.  
  4. urlpatterns = [
  5. url(r'^blog/(?P<year>[0-9]{4})/$', views.year_archive, {'foo': 'bar'}),
  6. ]

  In this example, for a request to /blog/2005/, Django will call views.year_archive(request, year='2005',foo='bar').

(在本例中,请求/博客/ 2005 / Django将调用视图。年存档(请求,年= ' 2005 ',foo = '参数')。)

This technique is used in the syndication framework to pass metadata and options to views.

(这种技术用于聚合框架通过元数据和视图选项。)

Dealing with conflicts

( 应对冲突)

It’s possible to have a URL pattern which captures named keyword arguments, and also passes arguments with the same names in its dictionary of extra arguments. When this happens, the arguments in the dictionary will be used instead of the arguments captured in the URL.

(可以有一个URL模式捕获关键字参数,并通过参数具有相同名字的字典的额外参数。当这种情况发生时,将使用参数在字典里而不是参数捕获)

需要注意的是,当你加上参数时,对应函数views.index必须加上一个参数,参数名也必须命名为a,如下:

  1. if auth():
  2.  
  3. obj=model.user.filter()
  4.  
  5. {'obj':obj}

应用

name param

  1. urlpatterns = [
  2. url(r'^index',views.index,name='bieming'),
  3. url(r'^admin/', admin.site.urls),
  4. # url(r'^articles/2003/$', views.special_case_2003),
  5. url(r'^articles/([0-9]{4})/$', views.year_archive),
  6. # url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
  7. # url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9]+)/$', views.article_detail),
  8.  
  9. ]
  10. ###################
  11.  
  12. def index(req):
  13. if req.method=='POST':
  14. username=req.POST.get('username')
  15. password=req.POST.get('password')
  16. if username=='alex' and password=='':
  17. return HttpResponse("登陆成功")
  18.  
  19. return render(req,'index.html')
  20.  
  21. #####################
  22.  
  23. <!DOCTYPE html>
  24. <html lang="en">
  25. <head>
  26. <meta charset="UTF-8">
  27. <title>Title</title>
  28. </head>
  29. <body>
  30. {# <form action="/index/" method="post">#}
  31. <form action="{% url 'bieming' %}" method="post">
  32. 用户名:<input type="text" name="username">
  33. 密码:<input type="password" name="password">
  34. <input type="submit" value="submit">
  35. </form>
  36. </body>
  37. </html>
  38.  
  39. #######################

name的应用

Django views

http请求中产生两个核心对象

  • http请求:HttpRequest对象

  • http响应:HttpResponse对象
  1. # 获取提交方式
  2. request.method
  3. if request.method == "POST":
  4. times = time.time()
  5. return render(request,'index.html')
  6.  
  7. # 获取前端post提交的数据
  8. request.POST.get('username')
  9.  
  10. # 获取域名后路径
  11. get_full_path()
  12. 例:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()得到的结果就是/index33/?name=123

HttpRequest对象

  1. def test(request):
  2. # 往前端写入字符串
  3. return HttpResponse("xxx")
  4. # 跳转路径
  5. return redirect('/index/')
  6.  
  7. # 渲染HTML文件两种方式
  8. return render(reuqest, "test.html")
  9. return render_to_response('text.html')
  10.  
  11. # 可以直接将函数中所有的变量传给模板
  12. return render(reuqest, "test.html",locals())
  13.  
  14. # 可以根据通过字典的方式往前端传值,取值输入key即可
  15. return render(reuqest, "test.html",{'shijie':'你好'})

HttpResponse对象

  1. # path: 请求页面的全路径,不包括域名
  2. #
  3. # method: 请求中使用的HTTP方法的字符串表示。全大写表示。例如
  4. #
  5. # if req.method=="GET":
  6. #
  7. # do_something()
  8. #
  9. # elseif req.method=="POST":
  10. #
  11. # do_something_else()
  12. #
  13. # GET: 包含所有HTTP GET参数的类字典对象
  14. #
  15. # POST: 包含所有HTTP POST参数的类字典对象
  16. #
  17. # 服务器收到空的POST请求的情况也是可能发生的,也就是说,表单form通过
  18. # HTTP POST方法提交请求,但是表单中可能没有数据,因此不能使用
  19. # if req.POST来判断是否使用了HTTP POST 方法;应该使用 if req.method=="POST"
  20. #
  21. #
  22. #
  23. # COOKIES: 包含所有cookies的标准Python字典对象;keys和values都是字符串。
  24. #
  25. # FILES: 包含所有上传文件的类字典对象;FILES中的每一个Key都是<input type="file" name="" />标签中 name属性的值,FILES中的每一个value同时也是一个标准的python字典对象,包含下面三个Keys:
  26. #
  27. # filename: 上传文件名,用字符串表示
  28. # content_type: 上传文件的Content Type
  29. # content: 上传文件的原始内容
  30. #
  31. #
  32. # user: 是一个django.contrib.auth.models.User对象,代表当前登陆的用户。如果访问用户当前
  33. # 没有登陆,user将被初始化为django.contrib.auth.models.AnonymousUser的实例。你
  34. # 可以通过user的is_authenticated()方法来辨别用户是否登陆:
  35. # if req.user.is_authenticated();只有激活Django中的AuthenticationMiddleware
  36. # 时该属性才可用
  37. #
  38. # session: 唯一可读写的属性,代表当前会话的字典对象;自己有激活Django中的session支持时该属性才可用。

参数

Django Form

一、基础form提交

比如写一个计算 a和 b 之间的简单应用,网页上这么写.

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <p>请输入两个数字</p>
  5.  
  6. <form action="/add/" method="POST"><input type="text" name="a"> <input type="text" name="b">
  7. <input type="submit" value="提交">
  8. </form>
  9. </body>
  10. </html>

HTML

把这些代码保存成一个index.html,放在 templates 文件夹中。

网页的值传到服务器是通过 <input> 或 <textarea>标签中的 name 属性来传递的,在服务器端这么接收:

  1. from django.http import HttpResponse
  2. from django.shortcuts import render
  3.  
  4. def index(request):
  5. return render(request, 'index.html')
  6.  
  7. def add(request):
  8. a = request.POST.GET('a')
  9. b = request.POST.GET('b')
  10. a = int(a)
  11. b = int(b)
  12. return HttpResponse(str(a+b)

服务器端

但是,比如用户输入的不是数字,而是字母,就出错了,还有就是提交后再回来已经输入的数据也会没了。

那么,当然如果我们手动将输入之后的数据在 views 中都获取到再传递到网页,这样是可行的,但是很不方便,所以 Django 提供了更简单易用的 forms 来解决验证等这一系列的问题。

二、Django Forms应用

1、简单案例一

在app01下新建一个文件forms.py

  1. from django import forms
  2.  
  3. class AddForm(forms.Form):
  4. a = forms.IntegerField()
  5. b = forms.IntegerField()

forms.py

(视图函数) views.py 

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. from django.shortcuts import render,HttpResponse
  4. from app01.forms import AddForm
  5.  
  6. def index(request):
  7. if request.method == 'POST':# 当提交表单时
  8. # form 包含提交的数据
  9. form = AddForm(request.POST)
  10. # 如果提交的数据合法
  11. if form.is_valid():
  12. a = form.cleaned_data['a']
  13. b = form.cleaned_data['b']
  14. return HttpResponse(str(int(a) + int(b)))
  15. # 当正常访问时
  16. else:
  17. form = AddForm()
  18. return render(request, 'index.html', {'form': form})

views.py

对应的模板文件 index.html

  1. <form method='post'>
  2. {% csrf_token %}
  3. {{ form }}
  4. <input type="submit" value="提交">
  5. </form>

index.html

这个简单的案例,大家不知道有没有看出其中的蹊跷呢,仔细观察,form类给我做了验证,用户输入错了会弹出报错信息

2丶简单案例二

  1. from django.db import models
  2.  
  3. # Create your models here.
  4.  
  5. class BookType(models.Model):
  6. caption = models.CharField(max_length=64) #最大长度
  7.  
  8. class Book(models.Model):
  9. name = models.CharField(max_length=64) #最大长度
  10. pages = models.IntegerField()
  11. price = models.DecimalField(max_digits=10,decimal_places=2)
  12. pubdate = models.DateField()
  13. book_type = models.ForeignKey('BookType')
  14.  
  15. #当然min_length --最小长度

models.py

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. from django.shortcuts import render
  4. from app01.forms import Form1
  5.  
  6. def form1(request):
  7. if request.method == 'POST':
  8. # 获取请求内容做验证
  9. f = Form1(request.POST)
  10. if f.is_valid():
  11. print(f.cleaned_data)
  12. else:
  13. print(type(f.errors),f.errors)
  14. return render(request,'form1.html',{'error':f.errors,'form':f})
  15. else:
  16. f = Form1()
  17. return render(request,'form1.html',{'form':f})

views.py

在app01下新建一个文件forms.py

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3.  
  4. from django import forms
  5. from app01 import models
  6.  
  7. class Form1(forms.Form):
  8. # 用户名,给该标签添加一个class属性,还有空值的报错信息修改
  9. user = forms.CharField(
  10. widget=forms.TextInput(attrs={'class': 'c1'}),
  11. error_messages={'required': '用户名不能为空'},)
  12.  
  13. # 密码定义最大长度和最小长度
  14. pwd = forms.CharField(max_length=4,min_length=2)
  15. # 邮箱定义错误信息,required为空值错误信息,invalid为邮箱匹配错误信息
  16. email = forms.EmailField(error_messages={'required': '邮箱不能为空', 'invalid': '邮箱格式错误'})
  17. # 生成多行文本编辑框
  18. memo = forms.CharField(widget=forms.Textarea())
  19.  
  20. # 下拉菜单实时更新数据库
  21. user_type_choice = models.BookType.objects.values_list('id','caption')
  22. book_type = forms.CharField(widget=forms.widgets.Select(choices=user_type_choice,attrs={'class': "form-control"}))
  23.  
  24. def __init__(self,*args, **kwargs):
  25. super(Form1, self).__init__(*args, **kwargs)
  26. self.fields['book_type'] = forms.CharField(
  27. widget=forms.widgets.Select(choices=models.BookType.objects.values_list('id','caption'),attrs={'class': "form-control"}))

forms.py

HTML页面(form1.html)

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <style>
  7. .input-group{
  8. position: relative;
  9. padding: 20px;
  10. width: 250px;
  11. }
  12. .input-group input{
  13. width: 200px;
  14. display: inline-block;
  15. }
  16. .input-group span{
  17. display: inline-block;
  18. position: absolute;
  19. height: 12px;
  20. font-size: 8px;
  21. border: 1px solid red;
  22. background-color: darksalmon;
  23. color: white;
  24. top: 41px;
  25. left: 20px;
  26. width: 202px;
  27. }
  28. </style>
  29. </head>
  30. <body>
  31.  
  32. <form action="/form1/" method="post">
  33.  
  34. <div class="input-group">
  35. {{ form.user }}
  36. {% if error.user.0 %}
  37. <span>{{ error.user.0 }}</span>
  38. {% endif %}
  39. </div>
  40. <div class="input-group">
  41. {{ form.pwd }}
  42. {% if error.pwd.0 %}
  43. <span>{{ error.pwd.0 }}</span>
  44. {% endif %}
  45. </div>
  46. <div class="input-group">
  47. {{ form.email }}
  48. {% if error.email.0 %}
  49. <span>{{ error.email.0 }}</span>
  50. {% endif %}
  51. </div>
  52. <div class="input-group">
  53. {{ form.memo }}
  54. {% if error.memo.0 %}
  55. <span>{{ error.memo.0 }}</span>
  56. {% endif %}
  57. </div>
  58. <div class="input-group">
  59. {{ form.book_type }}
  60. {% if error.book_type.0 %}
  61. <span>{{ error.book_type.0 }}</span>
  62. {% endif %}
  63. </div>
  64.  
  65. <div>
  66. <input type="submit" value="提交">
  67. </div>
  68. </form>
  69.  
  70. </body>
  71. </html>

form1.html

Django|第一部的更多相关文章

  1. Django知识(二)

    上一部链接 django入门全套(第一部) 本章内容 Django model Model 基础配置 django默认支持sqlite,mysql, oracle,postgresql数据库. < ...

  2. 实战Django:官方实例Part1

    [写在前面] 撰写这个实战系列的Django文章,是很久之前就有的想法,问题是手头实例太少,一旦开讲,恐有"无米下锅"之忧. 随着对Django学习的深入,渐渐有了些心得,把这些心 ...

  3. 转一篇:文档笔记之Django QuerySet

    这个放着,说不定以后作一些更深入的查询时,用得着的. http://www.rapospectre.com/blog/7/ 今天刚刚答完辩体完检就跑来更新博客了!!! 先补上第一篇: 一般情况下,我们 ...

  4. django 配置URLconf和获取值

    django中正确配置url匹配找到视图: 1 在项目下的settings.py中ROOT_URLCONF = "项目名.urls" 表示 前台发来请求会先去项目下的test3/u ...

  5. python框架之Django(10)-Form组件

    介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来.与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否输入,输入 ...

  6. 【转】django 与 vue 的完美结合 实现前后端的分离开发之后在整合

    https://blog.csdn.net/guan__ye/article/details/80451318   最近接到一个任务,就是用django后端,前段用vue,做一个普通的简单系统,我就是 ...

  7. Django学习笔记之Django QuerySet的方法

    一般情况下,我们在写Django项目需要操作QuerySet时一些常用的方法已经满足我们日常大多数需求,比如get.filter.exclude.delete神马的感觉就已经无所不能了,但随着项目但业 ...

  8. Django Query

    Making Qeries 一旦创建了数据模型,Django就会自动为您提供一个数据库抽象API,允许您创建.检索.更新和删除对象.本文档解释了如何使用这个API. The models 一个clas ...

  9. python框架django中结合vue进行前后端分离

    一:创建django项目 1.django-admin startproject mysite # 创建mysite项目 2.django-admin startapp app01# 创建app01应 ...

随机推荐

  1. 1.3.2. App Icon 和 Launch Image(Core Data 应用程序实践指南)

    App Icon: 选中 Assets.xcassets 选择 AppIcon ,并拖入图片(29.40.60) Launch Image: 创建 Launch Image 拖入图片(2x.R4)

  2. spring3.1........jar包下载

    1.common-dbcp-1.4.jar 下载地址:http://commons.apache.org/dbcp/ 2.common-pool-1.6.jar 下载地址:http://commons ...

  3. 封装bt轮播图淡入淡出效果样式

    <!--BT轮播图-->    <div data-ride="carousel" class="carousel slide carousel_inn ...

  4. iOS 协议

    协议分为三部分:声明.引用.实现. 通常,声明协议和声明协议类型的属性都是在同一个类中.声明协议和声明协议作为属性在头文件中,引用在声明类的实现文件中.而实现协议则在其它类中.

  5. Java线程:同步

    一 同步的概念 线程的同步是为了防止多个线程访问一个数据对象时,对数据造成的破坏. 例如:两个线程ThreadA.ThreadB都操作同一个对象Foo对象,并修改Foo对象上的数据. MyRunnab ...

  6. C++设计模式——抽象工厂模式

    问题描述 之前讲到了C++设计模式——工厂方法模式,我们可能会想到,后期产品会越来越多了,建立的工厂也会越来越多,工厂进行了增长,工厂变的凌乱而难于管理:由于工厂方法模式创建的对象都是继承于Produ ...

  7. 在ASP.NET MVC中使用JQ插件datatable

    1. Models public class Citys { public int Id { get; set; } public string CityName { get; set; } publ ...

  8. redis内存占用说明

    执行info命令后,找到Memory这一栏,就可以看到内存的使用信息了,如下图: # Memory used_memory:13490096 //数据占用了多少内存(字节) used_memory_h ...

  9. RedisRepository分享和纠错

    .mytitle { background: #2B6695; color: white; font-family: "微软雅黑", "宋体", "黑 ...

  10. [转载] HTTP协议状态码详解(HTTP Status Code)

    转载自:http://www.cnblogs.com/shanyou/archive/2012/05/06/2486134.html 使用ASP.NET/PHP/JSP 或者javascript都会用 ...