day18 js 正则,UI框架,Django helloworld 以及完整工作流程
只匹配数字:
所以JS 正则的使用方式:
1 写一个满足需求的js正则匹配式
2 使用test来验证是否符合
那么如果我们想获取里面的数据该怎么办呢?
exec:
默认只拿第一个
使用分组:
全局匹配:
注意:会从开始一直匹配,每次匹配一个,直到匹配完,会返回一个null 然后再匹配的话会从头重新开始
全局使用分组:
每次返回两个值,第一个为匹配的,第二个为去除正则后的数据
复习下正则:
这里再声明一下,使用自定义动作的时候一定要加上return 才能取消自带的动作
对于checkbox 来说,默认事件先执行,然后才执行自定的事件
完整验证过程:
学习框架:
已知的有
1 jQuery UI
2 Bootstrap
BootStrap 可适用于前端展示及后端管理的都可以
响应式布局效果:
在修改别人的插件的时候,要更改东西的时候就使用 important 表名最重要的!!! 这样就不关心前后顺序了
各种轮播图等、 都有插件
所有web框架的本质:
python 3 中三种方式转换为字节:
判断客户端的请求路径
使用字典形式,省去做if 判断:
从文件中返回数据:
分开写:
所谓各种名词 就是下面的框架:
开始 Django
1 安装
2 创建工程
3 运行
访问:
添加一个自定义的url
from django.conf.urls import url
from django.contrib import admin
from django.shortcuts import HttpResponse
def home(request):
return HttpResponse('<h1>Frist</h1>')
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^home/', home),
]
写一个时间更新的页面:
from django.conf.urls import url
from django.contrib import admin
from django.shortcuts import HttpResponse
def time(request):
import time
info = time.ctime()
return HttpResponse(['<h1>时间服务器</h1>',info])
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^time/', time),
]
创建一个网站的多个app用来处理不同的事情:
实践:
然后把逻辑代码放到新的目录里:
修改urls:
访问:
app目录的详细解释:
一行实现读取文件:
文件是通过配置里的目录来配置的,不然找不到文件的
实践:
1 编写登陆逻辑函数
from django.shortcuts import HttpResponse
from django.shortcuts import render
def login(request):
return render(request,'login.html')
def time(request):
import time
info = time.ctime()
return HttpResponse(['<h1>时间服务器</h1>',info])
2 编写登陆页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
label{
width: 80px;
text-align: right;
display: inline-block;
}
</style>
</head>
<body>
<form action="/login" method="post">
<p>
<label for="username">用户名:</label>
<input id="username" type="text" />
</p>
<p>
<label for="password">密码:</label>
<input id="password" type="text" />
<input type="submit" value="提交" />
</p>
</form>
</body>
</html>
3添加路由
4 检查配置
5 启动并测试
静态文件配置:
创建Django app 后首先需要操作:
使用静态文件:
2 修改配置文件,添加静态文件目录
STATIC_URL = '/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static'),
)
3 添加静态文件
4 修改html中的引用
5 测试
注释掉跨站 csrf:
判断用户是GET 还是POST
获取用户提交的信息:
程序里写:
完整的基本的用户名密码认证:
实践:
1 修改html 增加name 在POST 提交的时候才能分辨是什么内容,添加Django 特有的替换字符串的变量
action 的url 要和urls 里配置的一样,要么都有/ 要么都没有,不然会报错。
2 程序添加判断请求方式,获取输入的数据,并判断是否正确
3 实验:
在html 页面中使用for 循环来生成网页信息:
获取数据并添加到当前页面:
HTML页面:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body style="margin: 0">
<div style="height: 48px;background-color: #dddddd"></div>
<div>
<form action="/home" method="post">
<input type="text" name="username" placeholder="用户名" />
<input type="text" name="email" placeholder="邮箱"/>
<input type="text" name="gender" placeholder="性别"/>
<input type="submit" value="添加" />
</form>
</div>
<div>
<table>
{% for row in user_list %}
<tr>
<td>{{ row.username }}</td>
<td>{{ row.gender }}</td>
<td>{{ row.email }}</td>
</tr>
{% endfor %}
</table>
</div>
</body>
</html>
2 添加路由并添加处理的函数
urls
业务逻辑函数
USER_LIST =[
{'username':'alex','email':'abc@12.com','gender':'男'},
{'username':'alex','email':'abc@12.com','gender':'男'}
]
def home(request):
if request.method == 'POST':
#在request中获取用户提交的数据
u = request.POST.get('username')
e = request.POST.get('email')
g = request.POST.get('gender')
temp = {'username':u,'email':e,'gender':g}
USER_LIST.append(temp)
return render(request,'home.html',{'user_list':USER_LIST})
3 启动并测试
重新打开页面也还有数据,但是重启程序就没有了,所以需要把数据写到存储中,例如写入redis 中,就可以持久化了
经过以上一些实践,我们大概了解了Djanago 的工作方式,下面还Django的处理流程及部件组成图:
回顾一下以上的内容,做一个整理:
Django的程序完成开发流程:
模板语言的语法:
if 也可以嵌套,直接在里面写,但是要记得写上结尾符
EOF
day18 js 正则,UI框架,Django helloworld 以及完整工作流程的更多相关文章
- nodejs的Express框架源码分析、工作流程分析
nodejs的Express框架源码分析.工作流程分析 1.Express的编写流程 2.Express关键api的使用及其作用分析 app.use(middleware); connect pack ...
- WEB前端JS与UI框架
前端Js框架汇总 概述: 有些日子没有正襟危坐写博客了,互联网飞速发展的时代,技术更新迭代的速度也在加快.看着Java.Js.Swift在各领域心花路放,也是煞是羡慕.寻了寻.net的消息,也是振奋人 ...
- js客户端UI框架
Best jQuery UI http://b-jui.com/ jQuery EasyUI http://www.jeasyui.com/ bootstrap学习网: http://www.runo ...
- scrapy 基础组件专题(一):scrapy框架中各组件的工作流程
Scrapy 使用了 Twisted 异步非阻塞网络库来处理网络通讯,整体架构大致如下(绿线是数据流向): Scrapy主要包括了以下组件: 引擎(Scrapy)用来处理整个系统的数据流处理, 触发事 ...
- Django的JWT机制工作流程
https://blog.csdn.net/bin_1022/article/details/81278513 django-rest-framework-jwt token 怎么解码得到用户名? d ...
- 移动端常用UI框架
作为一个前端人员来说,总结几款相对来说不错的用于移动端开发的UI框架是非常必要的,以下几种移动端UI框架就能基本满足工作中开发需要,根据项目需求,选用合适的框架搭建项目,更能容易提高开发效率. 一.M ...
- Android酷炫实用的开源框架(UI框架)
Android酷炫实用的开源框架(UI框架) 前言 忙碌的工作终于可以停息一段时间了,最近突然有一个想法,就是自己写一个app,所以找了一些合适开源控件,这样更加省时,再此分享给大家,希望能对大家有帮 ...
- Android酷炫实用的开源框架(UI框架) 转
Android酷炫实用的开源框架(UI框架) 前言 忙碌的工作终于可以停息一段时间了,最近突然有一个想法,就是自己写一个app,所以找了一些合适开源控件,这样更加省时,再此分享给大家,希望能对大家有帮 ...
- 黄聪:Android酷炫实用的开源框架(UI框架)(转)
Android酷炫实用的开源框架(UI框架) 前言 忙碌的工作终于可以停息一段时间了,最近突然有一个想法,就是自己写一个app,所以找了一些合适开源控件,这样更加省时,再此分享给大家,希望能对大家有帮 ...
随机推荐
- Struts2笔记1
一.简介 1.作用于web层:Struts2是一种基于MVC模式的轻量级Web框架; 2.各文件夹简介: apps:该文件夹存用于存放官方提供的Struts2示例程序,这些程序可以作为学习者 ...
- 转:ZedGraph 各属性含义(中文)
简介:ZedGraph 是一个开源的.NET图表类库, 全部代码都是用C#开发的.它可以利用任意的数据集合创建2D的线性和柱形图表. 属性名称 属性值.作用 MasterPane 一个类对象管理多个G ...
- zabbix-3.4-快速入门
1 登陆和配置用户 登陆Zabbix,以及在Zabbix内建立一个系统用户. 用户名:Admin 或者 admin 密码 : zabbix 增加用户 可以在 管理(Administration) → ...
- Android商城开发系列(十四)—— 设置监听RecyclerView的位置
在前面的博客中有讲到过点击一个图片按钮控制RecyclerView的滚动到顶部位置的效果,但是那个图片按钮一直处在一个显示的状态,今天我们来改造一下那个地方,我们要实现的效果是:一开始打开的时候看不到 ...
- mustache.js 数组循环的索引
在使用mustache作为模板引擎时,想要利用数组中的对象的索引排序,却发现mustache中无法获得数组索引,在一番搜索之后,发现在数组的对象中加入索引,就可以了,示例如下 /html {{#dat ...
- linux 查看帐号创建时间
查看用户的home目录的创建时间 查看日志 用stat 命令,可以看到目录的三个时间.不过这个时间只是用来参考的,确定一个范围. 查看日志是最准确的方法 /var/log/auth.log ,前提是你 ...
- python_60_装饰器3
#嵌套函数 def foo(): print('in the foo') def bar(): print('in the bar') bar() #bar()#出错,无法在外边调用,bar函数的作用 ...
- matlplotlib 为折线图填充渐变颜色
概要 本篇记录绘图时填充颜色时的一些常用设置,主要用到了 imshow,fill 函数. 填充图实例 填充的效果图如下: 图 1:渐变色效果图 可根据下方给出的代码进行自定义. #!/us ...
- Java面向对象之继承,方法重写,super关键字,员工类系列继承题
在程序中,如果想声明一个类继承另一个类,需要使用extends关键字. 格式: class 子类 extends 父类 {} 继承的好处 1.继承的出现提高了代码的复用性,提高软件开发效率. 2.继承 ...
- python 读取mat文件
import osimport scipy.io as sio import numpy as np #matlab文件名 matfn='/home/user/devkit/data/meta_det ...