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内置分页功能。的更多相关文章

  1. django models进行数据库增删查改

    在cmd 上运行 python manage.py shell   引入models的定义 from app.models import  myclass   ##先打这一行    ------这些是 ...

  2. ASP.NET使用EasyUI-DataGrid + ashx + JQuery Ajax:实现数据的增删查改,查询和分页!

    转自:http://www.cnblogs.com/lt-style/p/3457399.html 数据表: 学生表:学生编号.姓名.性别.班级编号.年龄 班级表:班级编号.班级名称 开发过程: 1. ...

  3. JAVAWEB实现增删查改(图书信息管理)之修改功能实现

    首先通过点击index.jsp页面的修改按钮,获取该行的id:↓ 其次,跳转到updateBooks.jsp页面进行修改信息,页面代码如下:↓ <%@ page import="Boo ...

  4. JAVAWEB实现增删查改(图书信息管理)之添加功能实现

    addBooks.jsp页面代码:↓ <%-- Created by IntelliJ IDEA. User: NFS Date: 2019-7-12 Time: 14:30 To change ...

  5. JavaWeb实现增删查改(图书信息管理)之删除功能实现

    —————————————————————————————————————————————————————————— 删除按钮对应的servlet -->DeleteBooks.java  ↓ ...

  6. JDBC课程4--使用PreparedStatement进行增删查改--封装进JDBCTools的功能中;模拟SQL注入 ; sql的date()传入参数值格式!

    主要内容: /*SQL 的date()需要传入参数值: preparedStatement().setDate(new java.util.Date().getTime()); 熟悉了使用Prepar ...

  7. Java实现单链表的增删查改及逆置打印

    //所提供的接口 LinkList.java package Struct; public interface LinkList {//判断链表为空public boolean linkListIsE ...

  8. django内置分页功能扩展

    实现自定制页码数类型class myPaginator(Paginator): def __init__(self,curr_page,per_page_num,*args,**kwargs): se ...

  9. Django笔记&教程 5-1 基础增删查改

    Django 自学笔记兼学习教程第5章第1节--基础增删查改 点击查看教程总目录 第四章介绍了模型类models.Model和创建模型,相当于介绍了数据库表和如何创建数据库表. 这一章将介绍如何使用模 ...

随机推荐

  1. [转载] 解决gns3 for mac模拟器三层交换机无法成功创建vlan的问题

    1.删除之前导入的ios: 2.选择GNS3--Edit--Preferences--IOS routers--New--导入ios-- 勾选This is an EtherSwitch router ...

  2. 基于openresty配置https访问

    安装方法:http://openresty.org/cn/linux-packages.html 1. openssl的版本信息 [root@localhost conf]# openssl vers ...

  3. Spring Boot入门教程(1)

    Spring Boot入门教程(1) 本文将使用Spring Boot一步步搭建一个简单的Web项目来帮助你快速上手. 将要用到的工具 JDK 8 IntelliJ IDEA(Ultimate Edi ...

  4. JavaScript设计模式-2高级类.

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  5. linux mint 19 与windows时间不同步

    首先确定时间无误 sudo apt-get install ntpdate sudo ntpdate time.windows.com 2 sudo hwclock --localtime --sys ...

  6. minStack实现

    设计包含 min 函数的栈(栈)定义栈的数据结构,要求添加一个 min 函数,能够得到栈的最小元素.要求函数 min.push 以及 pop 的时间复杂度都是 O(1). #include <a ...

  7. mongo小记

    进mongo mongo 先添加admin表的账号密码 . use admin . db.createUser( { user: "admin", pwd: "admin ...

  8. docker上安装nginx服务

    环境     1.开启一个容器,安装nginx,略过   2.假如第一步新启动没映射端口的话,重新把容器保存为镜像然后再重新运行一个新容器,不建议在一个正在运行的容器上做端口映射 docker run ...

  9. [转]MAC:删除终端默认前缀的计算机名

    MAC:删除终端默认前缀的计算机名 1.打开终端 输入 sudo vi /etc/bashrc,提示输入密码就是计算机的密码. 2.点击i将编辑模式改成insert修改文档,使用#注释PS1=’\h: ...

  10. [Mysql 查询语句]——对查询结果进一步的操作

    distinct 不显示重复的查询结果 (1) 对于表中一些没有唯一性约束的字段,可能存在重复的值,这时可以使用distinct来消除那些查询结果中的重复值 select cust_id  from ...