导航:VS2019开发Django系列

第一篇介绍了安装Django,那么,今天的主题内容是使用VS编写第一个Django应用。

1)新建Django Web项目

选择新建Django Web项目,在弹出来的窗口中,修改名称,修改路径,创建即可。创建成功之后,VS会自动打开一个readme.html的文件,文件内容是指引你创建超级用户用来管理你的Django应用。从图中我们也可以看出来,与Python相关的操作,都在一个独立的菜单中,以后肯定会经常用到的。

 2)看看VS为我们创建了什么

项目创建完成之后,我们可以看到VS为我们创建了如下图所以的目录文件结构,一个app文件夹,一个DjangoLazyOrders文件夹,以及db.sqlite3,manager.py等文件,具体每个文件是用来干嘛的我就不细说了,官方文档有详细的说明,我只谈一下我自己的理解。

app:类似于Asp.Net MVC项目中的Area,可以这么来理解,实际就是用来区分功能模块的。

db.sqlite3:说明Django默认是使用sqlite数据库

urls.py:类似于Asp.Net MVC中的RoutConfig.cs,用来配置路由用的

requirements.txt:Django对版本的配置要求,打开这个文件,VS会提示创建虚拟环境,直接选择创建即可,创建虚拟环境的目的是为了给当前这个项目一个独立的运行环境,不受其他环境的影响,因为你的电脑上可能不止一个Python项目

因为VS已经集成了Django的开发环境,所以一些配置的工作,IDE已经给我们配置好了,我们可以直接运行,项目可以正常打开网页,没有任何的问题。我们跟踪代码,分别来看看app文件夹下边的这些文件是用来干嘛的:

migrations:这个与Orm相关,用来迁移数据库用的

static:里边保存的是一些静态文件,比如:js,css,fonts文件等,VS内置了bootstrap前端框架的脚本文件

templates:里边存放的是一些html文件,但是不是静态的html文件,里边的数据绑定是有语法规则的,类似于Asp.Net MVC中的cshtml文件中使用的razor语法,python解释器会按照语法规则来绑定渲染模板文件,然后返回数据给浏览器。

forms.py:与表单相关的内容,以及表单数据校验等

models.py:orm中的entity,与Asp.Net MVC中model的区别是,Asp.Net MVC中的model实质是viewmodel,并不是entity,而这里直接就是entity

tests.py:用来写测试代码用的

views.py:类似于Asp.Net MVC中的controller,里边的函数,就是action方法

 3)新建hello app

在项目文件上右键,添加,Django应用,命名为hello,确定,VS会自动创建上述所有的文件,省去了一个一个创建文件的麻烦,这也是IDE强大的地方之一。我们要实现一个在浏览器中输入http://localhost:8090/hello得到我们写的hello world!界面,我们要怎么做?

服务启动的端口号可以在项目属性调试中修改

第一步:在setting.py文件中注册(引用)我们新增加hello,批注:此时还不是必须,因为我们还没有用到models

# Application references
# https://docs.djangoproject.com/en/2.1/ref/settings/#std:setting-INSTALLED_APPS
INSTALLED_APPS = [
'hello',
'app',
# Add your apps here to enable them
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]

第二步,修改hello app中的view.py文件,添加如下内容:

from django.http import HttpResponse

# Create your views here.
def hello(request):
return HttpResponse("hello world!"); def test(request):
return HttpResponse("test")

第三步,在hello app中新增加文件urls.py,文件内容为:

from django.urls import path
from hello import views urlpatterns = [path('hello/',views.hello,name='hello'),
path('test/',views.test,name='test')]

第四步,修改DjangoLazyOrders文件夹下的urls.py的内容如下:

"""
Definition of urls for DjangoLazyOrders.
""" from datetime import datetime
from django.urls import path,include
from django.contrib import admin
from django.contrib.auth.views import LoginView, LogoutView
from app import forms, views urlpatterns = [path('', views.home, name='home'),
path('contact/', views.contact, name='contact'),
path('about/', views.about, name='about'),
path('login/',
LoginView.as_view(template_name='app/login.html',
authentication_form=forms.BootstrapAuthenticationForm,
extra_context=
{
'title': 'Log in',
'year' : datetime.now().year,
}),
name='login'),
path('logout/', LogoutView.as_view(next_page='/'), name='logout'),
path('admin/', admin.site.urls),
path('', include('hello.urls')),]

第五步,访问,启动调试,在地址后面追加hello回车,得到了我们要展示的内容hello world!

 4)总结

  • 该篇主要介绍了,Django项目的目录结构,介绍每个文件是干嘛用的
  • 完成经典入门app的hello world

最新文章

  1. React学习笔记-2-什么是jsx?如何使用jsx?
  2. NPIO 导出记录
  3. window.location.href url含中文服务器收到乱码问题解决
  4. 将Log4net的配置配置到的独立文件中
  5. php判断是否为手机客户端
  6. 【Google Protocol Buffer】Google Protocol Buffer
  7. 扩展ExtJs 4.2.1 htmleditor 添加图片功能
  8. 【BZOJ1036】【树链剖分】树的统计Count
  9. Android wear 初体验
  10. apt-get 总结
  11. CSS滤镜效果
  12. PHP中MD5函数漏洞
  13. 【NLP】Conditional Language Modeling with Attention
  14. Spark提高篇——RDD/DataSet/DataFrame(二)
  15. jQuery实现回车绑定Tab事件
  16. MySql基本查询、连接查询、子查询、正则表达查询解说
  17. 基本数据类型list,tuple
  18. Bzoj3122:多项式BSGS
  19. kafka存储数据量过大,导致磁盘爆满
  20. centos7下git的使用和配置

热门文章

  1. kube-nginx 和 keepalived 部署安装
  2. 处理器CPU天梯图,显卡天梯图(性能排名图)
  3. xshell使用xftp传输文件、使用pure-ftpd搭建ftp服务
  4. 洛谷上的C语言三连击。
  5. 《Windows内核安全与驱动开发》 5.1&5.2 内核与应用方面的编程
  6. 【网络流相关】最大流的Dinic算法实现
  7. oracle创建jobs定时任务报错:ora-01008:not all variables bound
  8. 这可能是最容易入门的socket教程了
  9. kubernetes学习笔记(一)——minikube安装记录
  10. Spring源码学习笔记之基于ClassPathXmlApplicationContext进行bean标签解析