corethink功能模块探索开发(十六)后台搜索功能

2024-08-24 02:38

本文主要是介绍corethink功能模块探索开发(十六)后台搜索功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果图:

代码很简单,就是添加搜索框,搜索字段,在初始化页面查询的时候添加查询条件。

1.添加搜索框

添加到删除按钮后边.

->setSearch('请输入设备名称/MAC/宿舍号', U('index'))
2.添加搜索字段

// 搜索$keyword = I('keyword', '', 'string');$condition = array('like','%'.$keyword.'%');$map['ap_name|ap_mac|dormitory_num'] = array($condition, $condition, $condition,'_multi'=>true);

添加在index方法开头,map的索引是可供搜索的字段,对应condition

3.添加查询条件

->where($map)

OK.PS:搜索的时候不能用回车键,使用按钮吧。

Application/Equip/Admin/ApAdmin.class.php

<?php
/*** Created by PhpStorm.* User: pangPython* Date: 16-3-30* Time: 下午10:22*/namespace Equip\Admin;use Admin\Controller\AdminController;
use Common\Util\Think\Page;
class ApAdmin extends AdminController{public function index(){// 搜索$keyword = I('keyword', '', 'string');$condition = array('like','%'.$keyword.'%');$map['ap_name|ap_mac|dormitory_num'] = array($condition, $condition, $condition,'_multi'=>true);// 获取所有链接$p = !empty($_GET["p"]) ? $_GET["p"] : 1;$device_repire_object = D('equip_ap');//实例化数据对象$data_list = $device_repire_object->page($p, C('ADMIN_PAGE_ROWS'))->where($map)->select();//分页查询数据列表$page = new Page($device_repire_object->count(),C('ADMIN_PAGE_ROWS'));// 转换成树状列表$tree = new \Common\Util\Tree();$data_list = $tree->toFormatTree($data_list);//使用Builder快速建立列表页面$builder = new \Common\Builder\ListBuilder();$builder->setMetaTitle('无线AP') //设置页面标题->addTopButton('addnew')->addTopButton('delete',array('model'=>'equip_ap'))  // 添加删除按钮->setSearch('请输入设备名称/MAC/宿舍号', U('index'))->addTableColumn('id', 'ID')->addTableColumn('ap_name', '设备名称')->addTableColumn('ap_mac', 'MAC')->addTableColumn('dormitory_num','宿舍号')->addTableColumn('ap_status', '状态', 'status')->addTableColumn('right_button', '操作', 'btn')->setTableDataList($data_list)  // 数据列表->setTableDataPage($page->show())  // 数据列表分页->addRightButton('edit')           // 添加编辑按钮->display();}public function add(){if(IS_POST){$ap_object = D('equip_ap');$data = $ap_object->create();if($data){$id = $ap_object->add($data);if ($id) {$this->success('新增成功', U('index'));} else {$this->error('新增失败');}}else{$this->error($ap_object->getError());}}else{// 使用FormBuilder快速建立表单页面。$builder = new \Common\Builder\FormBuilder();$builder->setMetaTitle('新增AP')  // 设置页面标题->setPostUrl(U('add'))     // 设置表单提交地址->addFormItem('ap_name', 'text', 'AP名称')->addFormItem('ap_mac', 'text', 'mac', 'AP mac地址')->addFormItem('dormitory_num', 'text', '宿舍号', 'AP对应的宿舍号')->addFormItem('status', 'radio', '状态', 'AP状态',array('0'=>'在线','1'=>'离线'))->display();}}public function edit($id){if(IS_POST){//用于保存编辑后的数据$Equip_Repaire_object = D('equip_ap');$data = $Equip_Repaire_object->create();if ($data) {if ($Equip_Repaire_object->save($data)) {$this->success('更新成功', U('index'));} else {$this->error('更新失败');}} else {$this->error($Equip_Repaire_object->getError());}}else{//用于填充并显示点击编辑按钮后生成的列表$info = D('equip_ap')->find($id);// 使用FormBuilder快速建立表单页面。$builder = new \Common\Builder\FormBuilder();$builder->setMetaTitle('更改AP信息')  // 设置页面标题->setPostUrl(U('edit'))    // 设置表单提交地址->addFormItem('id', 'hidden', 'ID', 'ID')//设置文本类型的表单项目并用对应的数据库字段填充->addFormItem('ap_name', 'text', 'AP', 'AP 名称')->addFormItem('ap_mac', 'text', 'MAC', 'AP MAC 地址')->addFormItem('ap_status', 'radio', '状态', 'AP状态',array('0'=>'离线','1'=>'在线'))->addFormItem('dormitory_num', 'text', '宿舍号', 'AP对应的宿舍号')//设置数据关联->setFormData($info)->display();}}
}




这篇关于corethink功能模块探索开发(十六)后台搜索功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Java实现预览与打印功能详解

《Java实现预览与打印功能详解》在Java中,打印功能主要依赖java.awt.print包,该包提供了与打印相关的一些关键类,比如PrinterJob和PageFormat,它们构成... 目录Java 打印系统概述打印预览与设置使用 PageFormat 和 PrinterJob 类设置页面格式与纸张

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加