效果图:

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

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();
}
}
}

  

最新文章

  1. JAVA文件下载功能问题解决日志
  2. 第 17 章 CSS 边框与背景[下]
  3. java 计算地球上两点间距离
  4. 高可用与负载均衡(7)之聊聊Lvs-DR+Keepalived的解决方案
  5. jquery幻灯片
  6. Python的平凡之路(5)
  7. 基于Maven构建整合SpringMVC+Mybtis+Druid
  8. 使用BeanUtils操作Bean属性
  9. Comparing cards
  10. 如何使用ERStudio 生成comment
  11. synchronized 关键字
  12. Python文件处理(1)
  13. simplePagination API
  14. C# - 学习总目录
  15. Api文件
  16. mongoDB的配置以及运行
  17. python进程同步,condition例子
  18. Selenium2+python自动化37-爬页面源码(page_source)
  19. Mybatis+MySql 一个标签中执行多条sql语句 这个坑 ,我心中有一句MMP
  20. SQL 十分位

热门文章

  1. Codeforces Round #429 (Div. 2) E. On the Bench
  2. CDH 安装配置指南(Tarball方式)
  3. OSX 10.8+下开启Web共享的方法 /转
  4. 用e2fsck修复受损的linux文件系统
  5. 用TortoiseSVN忽略文件或文件夹(ignore)(网络摘抄记录)
  6. php yaf框架扩展实践五——数据层
  7. Oracle启动中,spfile.ora、init&lt;SID&gt;.ora、spfile&lt;SID&gt;.ora 这三个文件正确的先后顺序是什么?
  8. 【vijos】1892 树上的最大匹配(树形dp+计数)
  9. Java WEB 之页面间传递特殊字符
  10. ytu 2231: 交集问题(线性表)(数据结构,链表练习)