Django,ajax实现表格增删查改,Django内置分页功能。
1.工程目录
2.urls.py
"""Django_ajax URL Configuration The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/2.1/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from app01 import views urlpatterns = [
path('admin/', admin.site.urls), path('students/', views.students),
path('add_student/', views.add_student),
path('del_student/', views.del_student),
path('edit_student/', views.edit_student),
path('edit_student/', views.edit_student), ]
3.views.py
from django.shortcuts import render, HttpResponse, redirect
from app01 import models
import json
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger # Create your views here. class CustomPaginator(Paginator):
def __init__(self, current_page, show_page_num, *args, **kwargs):
self.current_page = current_page
self.show_page_num = show_page_num
super(CustomPaginator, self).__init__(*args, **kwargs)
print('current_page:', current_page)
print('show_page_num:', show_page_num) def pager_num_range(self): if self.current_page-self.show_page_num > 0 and self.current_page+self.show_page_num <= self.num_pages:
limit_left = int(self.current_page-self.show_page_num/2)
limit_right = int(self.current_page + self.show_page_num/2+1)
elif self.current_page-self.show_page_num <= 0:
limit_left = 1
limit_right = 1 + self.show_page_num+1
elif self.current_page+self.show_page_num > self.num_pages:
limit_right = self.num_pages+1
limit_left = self.num_pages-self.show_page_num return range(limit_left, limit_right) def students(request): current_page = request.GET.get('p')
num_A_page = request.GET.get('n')
show_page_num = 10 if num_A_page == None:
num_A_page = 10 paginator = CustomPaginator(int(current_page), show_page_num, models.Student.objects.all(), num_A_page)
try:
posts = paginator.page(current_page)
except PageNotAnInteger:
posts = paginator.page(1)
except EmptyPage:
posts = paginator.page(paginator.num_pages) cls_list = models.Classes.objects.all()
return render(request, 'students.html', {'posts': posts, 'cls_list': cls_list}) def add_student(request):
print(request.POST)
response = {'status': True, 'message': None, 'data': None}
try: u = request.POST.get('stu_username')
a = request.POST.get('stu_age')
g = request.POST.get('gender')
c = request.POST.get('cls_id')
print('-------------', u, a, g, c)
obj = models.Student.objects.create(username=u, age=a, gender=g, cs_id=c)
response['data'] = obj.id except Exception as e:
response['status'] = False
response['message'] = '用户输入错误!' result = json.dumps(response, ensure_ascii=False)
return HttpResponse(result) def del_student(request):
response = {'status': True, 'message': None, 'data': None} nid = request.GET.get('nid')
models.Student.objects.filter(id=nid).delete() result = json.dumps(response, ensure_ascii=False) return HttpResponse(result) def edit_student(request):
print(request.POST)
response = {'status': True, 'message': None, 'code': 1000}
try:
nid = request.POST.get('nid')
u = request.POST.get('user')
a = request.POST.get('age')
g = request.POST.get('gender')
c = request.POST.get('edit_cls_id')
print('-------------', u, a, g, c) models.Student.objects.filter(id=nid).update(username=u, age=a, gender=g, cs_id=c) except Exception as e:
response['status'] = False
response['code'] = 1001
response['message'] = '用户输入错误!' import json
result = json.dumps(response, ensure_ascii=False) return HttpResponse(result)
4.models.py
from django.db import models # Create your models here. class Classes(models.Model):
title = models.CharField(max_length=32)
m = models.ManyToManyField('Teachers') class Teachers(models.Model):
name = models.CharField(max_length=32) class Student(models.Model):
username = models.CharField(max_length=32)
age = models.IntegerField()
gender = models.BooleanField()
cs = models.ForeignKey(Classes, on_delete=models.CASCADE)
5.在static文件夹中加入jquery-3.3.1.js、创建plugins文件夹,在该文件夹下加入要使用是前端框架。
链接:https://pan.baidu.com/s/1PrYlNmW3FyOlvkQhb7KYiQ
提取码:1cc9
6.生成数据库中的表
在pycharm中的Terminal中输入:
python manage.py makemigrations python manage.py migrate
7.运行服务器:
在pycharm中的Terminal中输入:
python manage.py runserver 8081
运行成功
8.访问效果:
Django,ajax实现表格增删查改,Django内置分页功能。的更多相关文章
- django models进行数据库增删查改
在cmd 上运行 python manage.py shell 引入models的定义 from app.models import myclass ##先打这一行 ------这些是 ...
- ASP.NET使用EasyUI-DataGrid + ashx + JQuery Ajax:实现数据的增删查改,查询和分页!
转自:http://www.cnblogs.com/lt-style/p/3457399.html 数据表: 学生表:学生编号.姓名.性别.班级编号.年龄 班级表:班级编号.班级名称 开发过程: 1. ...
- JAVAWEB实现增删查改(图书信息管理)之修改功能实现
首先通过点击index.jsp页面的修改按钮,获取该行的id:↓ 其次,跳转到updateBooks.jsp页面进行修改信息,页面代码如下:↓ <%@ page import="Boo ...
- JAVAWEB实现增删查改(图书信息管理)之添加功能实现
addBooks.jsp页面代码:↓ <%-- Created by IntelliJ IDEA. User: NFS Date: 2019-7-12 Time: 14:30 To change ...
- JavaWeb实现增删查改(图书信息管理)之删除功能实现
—————————————————————————————————————————————————————————— 删除按钮对应的servlet -->DeleteBooks.java ↓ ...
- JDBC课程4--使用PreparedStatement进行增删查改--封装进JDBCTools的功能中;模拟SQL注入 ; sql的date()传入参数值格式!
主要内容: /*SQL 的date()需要传入参数值: preparedStatement().setDate(new java.util.Date().getTime()); 熟悉了使用Prepar ...
- Java实现单链表的增删查改及逆置打印
//所提供的接口 LinkList.java package Struct; public interface LinkList {//判断链表为空public boolean linkListIsE ...
- django内置分页功能扩展
实现自定制页码数类型class myPaginator(Paginator): def __init__(self,curr_page,per_page_num,*args,**kwargs): se ...
- Django笔记&教程 5-1 基础增删查改
Django 自学笔记兼学习教程第5章第1节--基础增删查改 点击查看教程总目录 第四章介绍了模型类models.Model和创建模型,相当于介绍了数据库表和如何创建数据库表. 这一章将介绍如何使用模 ...
随机推荐
- 利用python 学习数据分析 (学习四)
内容学习自: Python for Data Analysis, 2nd Edition 就是这本 纯英文学的很累,对不对取决于百度翻译了 前情提要: 各种方法贴: https://w ...
- mysql随机取出若干条记录的实用方法
1.常见的方法 ; 这种方法可以随机取得数据,但是如果表比较大,数据量很多的时候会很耗时. 2.优化后的方式 ) as t ); 分析,首先根据条件筛选出要选的数据,然后随机排序取出要的条数的id , ...
- (原创推荐文章)kerberos服务器端与客户端
#环境 两台装centos7的虚拟机即可. kerberos服务器端与客户端各一台 (本文档推荐使用Typora软件观看) # 1.kerberos服务器端配置 ## 1.1安装配置Kerberos ...
- JQ 文件上传
var formData = new FormData(); var name = $("input").val(); formData.append("file&quo ...
- 常用的re正则
常用的正则表达式: 用户名:/^[a-z0-9_-]{3,16}$/ 密码:/^[a-z0-9_-]{6,18}$/ 十六进制值:/^#?([a-f0-9]{6}|[a-f0-9]{3})$/ 电子邮 ...
- 遇见Navicat 2003-can't connect to MYSQL server on 'localhost'(10061)
学习过程中难免遇到问题,今天就遇到了Navicat 2003-can't connect to MYSQL server on 'localhost'(10061),navicat报错,我就纳闷以前都 ...
- Servlet+JSP+JDBC设计实现图书系统——管理功能实现
写在前面,之前由于种种原因博客好久没有更新.最近打算重拾JavaWeb,所以从头开始,先用servlet+jdbc+bootstrap最基础的代码实现一个图书系统.考虑有管理员端+用户端,项目完成后会 ...
- 1.CentOS6.5下的基础DNS配置
常规DNS的安全和配置1.安装DNSyum -y install bind bind-utils安装后生成的文件,我们主要配置下面几个/etc/named.conf/var/named/xx这个xx是 ...
- WCF系列教程之WCF实例化
本文参考自http://www.cnblogs.com/wangweimutou/p/4517951.html,纯属读书笔记,加深记忆 一.理解WCF实例化机制 1.WCF实例化,是指对用户定义的服务 ...
- 【文档】五、Mysql Binlog事件结构
这个部分描述了事件被写入binlog或者delay log中的属性.所有的事件有相同的整体结构,也就是包含事件头和事件数据: +===================+ | event header ...