jqgrid获取数据库数据

2023-12-26 14:18
文章标签 数据 数据库 获取 jqgrid

本文主要是介绍jqgrid获取数据库数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

jqgrid获取数据库数据

jqgrid获取数据有两种方法,一种是获取本地(即html中写入的固定的数据),另一种是获取后台数据库中的数据。
不过,不论是哪种方法,我这里采用的,都是基于local的数据获取方式,后台数据库的数据,也是通过Django与JavaScript之间的数据传递,将后台数据传给html中的js内的变量,然后以local 的方式显示在网页jqgrid中。

1.写入固定的数据

首先,先放上代码:

<script type="text/javascript">$(".grid").jqGrid({datatype: "local",height: 250,colNames: ['title', 'key_word', 'url_address', 'text_content'],colModel: [{name: 'title', index: 'title', width: 60},{name: 'key_word', index: 'key_word', width: 90},{name: 'url_address', index: 'url_address', width: 100},{name: 'text_content', index: 'text_content', width: 100},],caption: "討厭鬼grid"});var gameDate = [{"title":"2","key_word":"333","url_address":"還可以", "text_content":"sfdsfdsf"},{"title":"3","key_word":"Lineage","url_address":"死外掛", "text_content":"sfdsfdsf"},{"title":"4","key_word":"RO","url_address":"不想玩", "text_content":"sfdsfdsf"}];for(var i=0;i<=gameDate.length;i++){$(".grid").jqGrid('addRowData',i+1,gameDate[i]);}
</script>

这种方法是写入固定的数据,后期无法更改,也不能动态显示。可以作为前期对jqgrid的一种实现,先把表格展现出来再说。我这里引用的jqgrid版本,如下所示:(包括对应的css样式文件)

<link href="/static/css/ui.jqgrid.css" rel="stylesheet" type="text/css"/>
<link href="/static/css/jquery-ui.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="/static/js/jquery-1.11.0.min.js"></script>
<script type="text/javascript" src="/static/js/jquery.jqGrid.min.js"></script>
<script type="text/javascript" src="/static/js/grid.locale-cn.js"></script>

2.获取数据库中的数据

获取数据库中的数据,便涉及到Django与JavaScript的数据传递机制,这里直接搬运一下“Django自强学堂” 关于这一块儿的教学(又是基础知识!应该打牢才是!!
Django自强学堂
更详细的Django知识,可以戳传送门,去Django自强学堂学习了解:Django自强学堂网站。
到这里,我们解决了通过Django传送数据给js的问题,那么还有两个问题:

1. 在Django后台,如何获取数据库的数据,并改为jqgrid要求的格式?
2. 在js前端,如何将数据显示在jqgrid中?

先来看第一个问题,在Django中,获取数据库中的数据,我们可以编写如下的辅助函数:

def read_data_from_database():# 读数据到表格datas= Board.objects.values_list('title', 'key_word', 'url_address', 'text_content')orders = list(datas)data = []datain = []# 对数据进行预处理for tr in orders:for zr in tr:datain.append(zr)data.append(datain)datain = []Dict = []# 将数据变为jqgrid要求的格式,即对应的键值对for i in data:dict_in = {"title": i[0], "key_word": i[1], "url_address": i[2], "text_content": i[3]}Dict.append(dict_in)data = json.dumps(Dict)return data

接着,在views.py中,调用上面的函数,然后渲染到html中,代码如下:

def show_form(request):data = readorderfromdatabase()return render(request, 'form.html', {'Dict':data})

至此,我们就解决了第一个问题,把数据按照要求,顺利地传到了前端,在html中可以获取到数据,那么,接下来如何在js中处理数据,并调用jqgrid相关接口,将数据显示到表格中去呢?
首先,我们先来看代码,如下所示:

<script type="text/javascript">var Dict = {{ Dict|safe }};$(".grid").jqGrid({datatype: "local",height: 250,colNames: ['title', 'key_word', 'url_address', 'text_content'],colModel: [{name: 'title', index: 'title', width: 60},{name: 'key_word', index: 'key_word', width: 90},{name: 'url_address', index: 'url_address', width: 100},{name: 'text_content', index: 'text_content', width: 100},],caption: "这里是表格的总标题"});var gameDate = Dict;for(var i=0;i<=gameDate.length;i++){$(".grid").jqGrid('addRowData',i+1,gameDate[i]);}
</script>

正如前面强调的,这里,要加上safe过滤器,否则无法正常接收数据。数据格式也很重要。其实就相当于第一种方法里的固定数据传送,只不过这里的数据不是写在html中的固定数据,而是来自于后台Django传递来的数据,数据格式和固定数据的格式应该保持一致,否则jqgrid无法显示的。

至此,基本上就解决了后台Django数据传送到js端并通过jqgrid显示的问题。这个问题困扰了我将近两天的时间,百度Google了大量资料,看得我都快自闭了,最后在Django基础知识里找到了答案……这更加说明了基础知识的重要性!另一方面,自己查资料的方向也出错了,之前一直在查jQuery、jqgrid等纯前端方面的知识,所以查到了各种自己不懂得东西,什么ajax、php、jqgrid里的url、json服务器传值等等……最后就查了一次Django,就找到问题所在了。

不过,目前实现的jqgrid虽然可以显示数据库中的值了,但是依然存在一些问题需要处理,比如通过表单提交新的值后,需要重新刷新页面才能更新,这是因为自己写的jQuery代码没有包含刷新的函数,所以只是在页面加载的第一次进行了显示。
还有一些功能没有完善,比如增、删、改、查以及排序、筛选等等,需要后面继续深入了解。
————————更新分割线————————————
已经解决,当页面重载时,数据更新问题。
解决方法,见该链接:https://blog.csdn.net/u012746051/article/details/52949353
其中的核心代码复制粘贴如下:

<script>
$("#jqGrid_ds").jqGrid('clearGridData');  //清空表格
$("#jqGrid_ds").jqGrid('setGridParam',{  // 重新加载数据datatype:'local',data : newdata,   //  newdata 是符合格式要求的需要重新加载的数据 page:1
}).trigger("reloadGrid");
</script>

我的个人博客

欢迎大家访问我搭建的个人博客哦,通过github Page搭建的,基于hexo,用了next主题。有什么问题都可以互相交流。博客地址:我的个人博客:CodeSausage的博客

这篇关于jqgrid获取数据库数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/539732

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2