• 酱狗的杂七杂八(壹)


    路由层

    """
    url的第一个参数是正则表达式
    	精确匹配表达式	url(r"^index/$", ... )
    url的第二个参数是视图函数
    	url(r"^login", views.login)
    """
    # 无名分组 (在正则匹配中分组)
    """
    	1.按位置传参
    	2.分组之后,会把分组出来的数据作为位置参数传到视图函数,所以视图函数需要定义形参来接收传过来的参数
    	3.url(r"^login/([0-9]{4})/([0-9]{2})$", views.login)	# 路由层
    	  def login(request, *args):	# 视图函数
    	  		...
    	  	return ...
    """
    # 有名分组  (在正则匹配中定义有名分组)
    """
    	1.按关键字传参
    	2.分组之后,会把分组后的数据作为关键字参数传到视图函数,所以视图函数需要定义形参,形参的名字要和分组的名字对应,与顺序无关
    	3.url(r"^login/(?P<year>[0,9]{4})")/(?P<month>[0,9]{2})/$", views.login)	# 路由层
    	  def login(request, month, year) ==> def login(request, **kwargs):		# 视图函数
    	  	  ...
    	  	  return ...
    """
    # ps:有名分组和无名分组不要混用
    
    # 反向解析 (路由的重命名,实现动态生成路由)
    """
    基础路由
    	1. url(r"^login", views.login, name="login")		# 路由层 总路由中
    	2. <a href="{% url "login" %}">相对路径</a>			 # 模板层
    	3. return redirect(reverse("login")	# 视图层
    无名分组路由
    	1. url(r"^login/(/d+)/", views.login, name="login")	#路由层
    	2. {% url "login" 10 %} 这是一个路由...可以给表单中的action用
    	3. return redirect(reverse("login", args=(x, y)))	#视图函数返回一个反解析路由地址,并携带参数(可有可无)
    有名分组路由 
    	>>>和无名分组类似...<<<
    		...
    		
    总结:针对有名分组与无名分组的反向解析统一采用一种格式即可
    	后端
    	reverse('list',args=(10,))  # 这里的数字通常都是数据的主键值
    	前端
    	{% url 'list' 10 %}
    反向解析的本质:就是获取到一个能够访问名字所对应的视图函数
    """
    # 路由分发
    """
    # django每一个app下面都可以有自己的urls.py路由层,templates文件夹,static文件夹
    # 项目名下urls.py(总路由)不再做路由与视图函数的匹配关系而是做路由的分发
    
    from django.conf.urls import include
    
    # 总路由中,路由分发,养成命名独特且易读的习惯
    url(r'^app01/',include(app01_urls)),
    url(r'^app02/',include(app02_urls))
    
    # 在应用下新建urls.py文件,在该文件内写路由与视图函数的对应关系即可
    from django.conf.urls import url
    from app01 import views
    urlpatterns = [
    	url(r'^index/',views.index)
    ]
    
    """
    # 伪静态网页
    """
    搜索优化seo
    	url(r'^index.html',views.index,name='app01_index')
    """
    
    # 名称空间
    """
    url(r'^app01/',include(app01_urls,namespace='app01')),
    	url(r'^app02/',include(app02_urls,namespace='app02'))
    app01.urls.py
    	from django.conf.urls import url
    	from app01 import views
    	urlpatterns = [
    		url(r'^index/',views.index,name='index')
    	]
    
    app02.urls.py
    	from django.conf.urls import url
    	from app02 import views
    	urlpatterns = [
    		url(r'^index/',views.index,name='index')
    	]
    
    app01.views.py
    reverse('app01:index')
    
    app02.views.py
    reverse('app02:index')
    """
    

    视图层

    # JsonResponse
    """
    from django.http import JsonResponse
    def index(request):
    	# res = {'name':'Jason大帅比','password':18}
    	# return HttpResponse(json.dumps(res))
    	return JsonResponse({'name':'Jason大帅比','password':'1888888'},json_dumps_params={'ensure_ascii':False})
    """
    
    # FBV 与 CBV
    """
    FBV 基于函数的视图
    CBV 基于类的视图
    
    CBV:
    	url(r'^mycls/',views.MyCls.as_view())
    
    	class MyCls(View):
    		def get(self,request):
    			return render(request,'index.html')
    		def post(self,request):
    			return HttpResponse('post')
    
    无论是FBV还是CBV路由层都是路由对应视图函数内存地址
    urlpatterns = [
    	# url(r'^mycls/',views.view)
    	url(r'^mycls/',views.MyCls.as_view())
    ]
    
    class MyCls(View):
    	def get(self,request):
    		return render(request,'index.html')
    	def post(self,request):
    		return HttpResponse('post')
    """
    
    # 
    

    文件上传

    """
    简单的文件上传
    前端需要注意的点:
    	1.method需要指定成post
    	2.enctype需要改为formdata格式
    
    后端暂时需要注意的是
    	1.配置文件中注释掉csrfmiddleware中间件
    	2.通过request.FILES获取用户上传的post文件数据
    	
    file_obj = request.FILES.get('my_file')
        print(file_obj.name)
        with open(file_obj.name,'wb') as f:
            for line in file_obj.chunks():
                f.write(line)
    """
    

    虚拟环境

    """
    不同的项目配置不同的python解释器
    """
    

    Django1.0Django2.0 的区别

    """
    django1.0与django2.0之间的区别
    	django2.0里面的path第一个参数不支持正则,你写什么就匹配,100%精准匹配
    	
    	django2.0里面的re_path对应着django1.0里面的url
    	
    虽然django2.0里面的path不支持正则表达式,但是它提供五个默认的转换器
    
    	str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
    	int,匹配正整数,包含0。
    	slug,匹配字母、数字以及横杠、下划线组成的字符串。
    	uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
    	path,匹配任何非空字符串,包含了路径分隔符(/)(不能用?)
    
    自定义转换器
    	1.正则表达式
    	2.类
    	3.注册
    
    # 自定义转换器
    class FourDigitYearConverter:
    	regex = '[0-9]{4}'
    	def to_python(self, value):
    		return int(value)
    	def to_url(self, value):
    		return '%04d' % value  # 占四位,不够用0填满,超了则就按超了的位数来!
    register_converter(FourDigitYearConverter, 'yyyy')
    PS:路由匹配到的数据默认都是字符串形式
    """
    
  • 相关阅读:
    20155307 2017-2018-2 《Java程序设计》第2周学习总结
    20155307刘浩——预备作业03: 安装虚拟机
    刘浩(专业打劫三十年)20155307的预备作业02:
    刘浩的预备作业01:我期望的师生关系——————不要问我为什么我叫专业打劫三十年
    List Leaves
    树的同构
    Pop Sequence
    Reversing Linked List
    一元多项式的乘法与加法运算
    Python 基础语法复习
  • 原文地址:https://www.cnblogs.com/Ethan99/p/11001172.html
Copyright © 2020-2023  润新知