热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

利用jqgrid+加mysql的text类型实现简单自定义数据模型

下面来看一个关于利用jqgrid+加mysql的text类型实现简单自定义数据模型例子,希望对各位有帮助.有的时候,我们做东西可能速度和安全在前期并不是我们考虑的重点,数据的灵活性可能对于一个不...
下面来看一个关于利用jqgrid+加mysql的text类型实现简单自定义数据模型例子,希望对各位有帮助.

有的时候,我们做东西可能速度和安全在前期并不是我们考虑的重点,数据的灵活性可能对于一个不成熟的系统更加重要,这里我使用thinkphp+mysql+jqgrid做了一个简单的自定义数据模型,简单总结一下.

以前我也写过一个自定义模型:php一种不增加字段的自定义表单实现,但是当时因为没有jqgrid这样比较好用的工具,所以当时那个还是比较麻烦,这次当然也是不增加字段的,利用数据的text类型加json数据,实现虚拟的“表”,听到这里,有的同学应该知道,如果我们使用mongodb其实做起来就更加的灵活和简便,但是,因为这个东西比较小,就先这样用着了.

首先功能特点,通过配置文件,动态配置字段的key,类型,排序,显示,是否必填等等,比如图片类型,定义为image即可,看一下配置文件,代码如下:

return array( 
    //包名前缀 
    'pack_pre' => 'Pack_', 
    //商品管理字段配置 
    /** 
     * key为字段索引、存储字段 
     * name为字段显示名称 
     * required是否必填1是0不是 
     * hidden:列表是否显示,1隐藏,0显示,此选项会影响搜索,但不影响编辑 
     * type类型:三种类型 
     * 字段显示顺序与key的顺序一致 
    */ 
    'goodsfield' => array( 
        //id为系统保留字段 
        //商品名 
        'title' =>array( 
            'name'    =>'商品名', 
            'hidden'  =>0, 
            'required'=>1, 
            'type'    =>'text', 
        ), 
        //spu 
        'spu' =>array( 
            'name'    =>'spu', 
            'hidden'  =>0, 
            'required'=>1, 
            'type'    =>'text', 
        ), 
        //图片地址 
        'image' =>array( 
            'name'    =>'图片地址', 
            'hidden'  =>0, 
            'required'=>1, 
            'type'    =>'img', 
        ), 
        //url 
        'url' =>array( 
            'name'    =>'详情地址', 
            'hidden'  =>0, 
            'required'=>1, 
            'type'    =>'url', 
        ), 
    ), 
    //以下两个映射针对goodsfield而言 
    //goods_info api map,无映射即使用原字段 
    'goodsinfomap'=>array( 
    ),
    //pack post api map,商品包下发amc字段映射无映射即使用原字段 
    'map'=>array( 
    ), 
);

可以通过配置,非常方便修改,并一改全改,增删改.

2,html的jqgrid代码,代码如下:

jQuery("#goodsList").jqGrid({ 
       url:'/index.php?m=Home&a=getList', 
    datatype: "json", 
    mtype: 'POST', 
       colNames:[&#39;ID&#39;,<{$feildname}>,&#39;修改时间&#39;,&#39;操作&#39;], 
       colModel:[ 
           {name:&#39;id&#39;,width:25,index:&#39;id&#39;,setGridHeight:"auto"}, 
        <{$feildmap}> 
        {name:&#39;lastdotime&#39;,sortable:true}, 
        {name:&#39;edit&#39;,search:false,sortable:false}, 
       ], 
       rowNum:10, 
       rowList:[10,20,30], 
    multiselect:true,  //复选框 
       pager: &#39;#goodsPager&#39;, 
       sortname: &#39;lastdotime&#39;, 
    viewrecords: true, 
    sortorder: "desc", 
    editurl:&#39;/index.php?m=Home&a=oper&#39;,//添加修改操作url 
    autowidth:true, 
    height:&#39;100%&#39; 
});


3,三个比较重要的函数,代码如下:

//获取字段名称 
function feild_name($feild){ 
    $fields = C($feild); 
    $feild = &#39;&#39;; 
    foreach($fields as $val){ 
        $feild .="&#39;".$val[&#39;name&#39;]."&#39;,"; 
    } 
    $feild = rtrim($feild,&#39;,&#39;); 
    return $feild; 
} 
//获取字段字典 
function feild_map($feild){ 
    $fields = C($feild); 
    $feildmap =&#39;&#39;; 
    foreach($fields as $key=>$val){ 
        $feildmap .= &#39;{name:\&#39;&#39;.$key.&#39;\&#39;,sortable:false,editable:true&#39;; 
        if(1==$val[&#39;hidden&#39;]){ 
            $feildmap .=&#39;,hidedlg:true,hidden:true,editrules:{edithidden:true,&#39;; 
        }else{ 
            $feildmap .= &#39;,editrules:{&#39;; 
        } 
        if(1==$val[&#39;required&#39;]){ 
            $feildmap .=&#39;required:true}&#39;; 
        }else{ 
            $feildmap .=&#39;required:false}&#39;; 
        } 
        $feildmap .= &#39;},&#39;."\n"; 
    } 
    return $feildmap; 
} 
//获取字段列表 
function feild_list($feild,$array=array(),$row=array()){ 
    $row = json_decode($row[&#39;value&#39;],true); 
    $fields = C($feild); 
    foreach($fields as $key=>$val){ 
        switch($val[&#39;type&#39;]){ 
            case &#39;url&#39;:$array[]=&#39;&#39;.$row[$key].&#39;&#39;;break; 
            case &#39;img&#39;:$array[]=&#39;&#39;;break; 
            default:$array[] = $row[$key]; 
        } 
    } 
    return $array; 
}

代码没有什么,就是通过json对象动态配置.


教程网址:

欢迎收藏∩_∩但请保留本文链接。

推荐阅读
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • Jquery 跨域问题
    为什么80%的码农都做不了架构师?JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念。当然 ... [详细]
  • MongoDB学习:(二)MongoDB简单使用
    MongoDB学习:(二)MongoDB简单使用MongoDB使用:执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面&amp;amp;gt;mongo提示 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
  • step1.为mongodb添加admin管理员root@12.154.29.163:~#mongoMongoDBshellversionv3.4.2connectingto:mo ... [详细]
  • nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • Abp+MongoDb改造默认的审计日志存储位置
    一、背景在实际项目的开发当中,使用AbpZero自带的审计日志功能写入效率比较低。其次审计日志数据量中后期十分庞大,不适合与业务数据存放在一起。所以我们可以重新实现A ... [详细]
author-avatar
学生联盟v
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有