前端到后台ThinkPHP开发整站(4)
今晚继续我的这个项目的开发,今晚也是写的不多,主要写了一个菜单管理功能的CURD方法,前端界面还没有进行编写。
菜单管理Model层的代码:
<?php
namespace Common\Model;
use Think\Model; class MenuModel extends Model{
private $_db=''; public function __construct(){
$this->_db=M("menu");
} /**
* 插入菜单数据
*/
public function insert($data=array()){
if(!data || !is_array($data)){
return 0;
} return $this->_db->add($data);
} /**
* 获取菜单数据
*/
public function getMenus($data,$pageIndex,$pageSize=10){
$data['status']=array('neq',-1);
$offset=($pageIndex-1)*$pageSize;
$list=$this->_db->where($data)->order('listorder desc,menu_id desc')->limit($offset,$pageSize);
return $list;
} /**
* 获取菜单总数
*/
public function getMenusCount($data=array()){
$data['status']=array('neq',-1);
return $this->_db->where($data)->count();
} /**
* 根据ID获取菜单ID
*/
public function find($id){
if(!$id || !is_numeric($id)){
return array();
}
return $this->_db->where("menu_id={}$id")->find();
} /**
* 根据ID更新菜单
*/
public function updateMenuById($id,$data){
if(!$id || !is_numeric($id)){
throw_exception("ID不合法");
} if(!$data || !is_array($data)){
throw_exception('更新的数据不合法');
} return $this->_db->where("menu_id={$id}")->save($data);
} /**
* 更新排队序号
*/
public function updateMenuListOrderById($id,$listorder){
if(!$id || !is_numeric($id)){
throw_exception('ID不合法');
}
$data=array(
'listorder'=>intval($listorder);
); return $this->_db->where("menu_id={$id}")->save($data);
} /**
* 获取后台菜单
*/
public function getAdminMenus(){
$data=array(
'status'=>array('neq',-1),
'type'=>1
); return $this->_db->where($data)->order('listorder desc,menu_id desc')->select();
} /**
* 获取前台菜单
*/
public function getBarMenus(){
$data=array(
'status'=>1,
'type'=>0
);
return $this->_db->where($data)->order('listordre desc,menu_id desc')->select();
}
}
?>
菜单管理控制器类的代码:
<?php
namespace Admin\Controller;
use Think\Controller; class MenuController extends CommonController{ public function index(){
$data=array();
if(isset($_REQUEST['type']) && in_array($_REQUEST, array(0,1))){
$data['type']=intval($_REQUEST['type']);
$this->assign('type',$data['type']);
}else{
$this->assign('type',-100);
}
} public function add(){
if($_POST){
if(!isset($_POST['name']) || !$_POST['name']){
return jsonResult(0, '菜单名不能为空');
}
if(!isset($_POST['m']) || !$_POST['m']){
return jsonResult(0, '模块名不能为空');
}
if(!isset($_POST['c']) || !$_POST['c']){
return jsonResult(0, '控制器不能为空');
}
if(!isset($_POST['f']) || !$_POST['f']){
return jsonResult(0, '方法名不能为空');
}
if($_POST['menu_id']){
return $this->save($_POST);
}
$menuId=D("Menu")->insert($_POST);
if($menuId){
return jsonResult(1, '新增成功', $menuId);
}
return jsonResult(0, '新增失败', $menuId);
}else{
$this->display();
}
} public function edit(){
$menuId=$_REQUEST['id'];
$menu=D("Menu")->find($menuId);
$this->assign('menu',$menu);
$this->display();
} public function save($data){
$menuId=$data['menu_id'];
unset($data['menu_id']); try{
$id=D("Menu")->updateMenuById($menuid,$data);
if($id===FALSE){
return jsonResult(0, '保存失败');
}
return jsonResult(0,'保存成');
}catch(Exception $ex){
return jsonResult(0,$ex->getMessage());
}
} public function setStatus(){
try{
if($_POST){
$id=$_POST['id'];
$status=$_POST['status'];
$ret=D("Menu")->updateStatusById($id,$status);
if($ret){
return jsonResult(1,'操作成功');
}else{
return jsonResult(0,'操作失败');
}
}
}catch(Exception $ex){
return jsonResult(0,$ex->getMessage());
}
return jsonResult(0,'没有提交数据');
} /**
* 数据排序
*/
public function listorder(){
$listoreder=$_POST['listorder'];
$data =array('jump_url'=> $_SERVER['HTTP_REFERER']);
$errors=array();
if($listoreder){
try{
foreach($listorder as $emnuId=>$v){
$id=D("Menu")->updateMenuListorderById($menuId,$v);
if($id===false){
$errors[]=$menuId;
}
}
}catch(Exception $ex){
return jsonResult(0, $ex->getMessage(), $data)
}
if($errors){
return jsonResult(0,"排序失败-".implode(',', $errors), $data);
}
return jsonResult(1, '排序成功', $data)
}
return jsonResult(0,'数据排序失败', $data);
}
}
?>
今晚就暂时写这么点,明晚开始做前端的开发,明天就周五了,如果周六不用加班,我会加大马力在这周内结束该项目的。(^_−)☆
源码地址:https://github.com/YoZiLin/TP-CMS
前端到后台ThinkPHP开发整站(4)的更多相关文章
- 前端到后台ThinkPHP开发整站--php开发案例
前端到后台ThinkPHP开发整站--php开发案例 总结 还是需要做几个案例,一天一个为佳,那样才能做得快. 从需求分析着手,任务体系要构建好,这样才能非常高效. 转自: 前端到后台ThinkPHP ...
- 前端到后台ThinkPHP开发整站(2)
我这次使用的ThinkPHP版本是:3.2.3版本,还有会使用到一个弹出层插件,叫 layer,官网地址是:http://layer.layui.com/.废话不多说,进入撸码环节. 1.通用方法编写 ...
- 前端到后台ThinkPHP开发整站(6)
今天终于把整个后台管理系统弄好了,其实没什么难点,只是作为一个Thinphp学习的练手项目,这个项目,现在还只能算是做了一半,还有前台展示方面的功能没有完成.先过一遍后台的功能吧! 1.首页 2.菜单 ...
- 前端到后台ThinkPHP开发整站(5)
今天周五了,这个项目做了五个晚上了,明天周末不用上班有一整天的时间来结束这个项目了,今晚主要把后台界面给弄出来了. 大概的整个后台界面就是这个样子了,接下来的工作就是搬砖了,一个个菜单功能填上去就是了 ...
- 前端到后台ThinkPHP开发整站(1)
1.前言: 我个人从来没有写过博客文章,作为一个程序员没有自己的博客算是一个合格的程序员,所以我地想想也要经营起一个的博客,做一个小项目,写这博客算就做这个项目的一个项目笔记吧!现在自学着ThinkP ...
- 前端到后台ThinkPHP开发整站(3)
继续我的这个项目的第三晚的开发了,时间比较少,今晚写的代码不多,今晚仍然是造轮子写一个公共的控制器和一个公共的JS.直接上代码吧! 以下是一个公共的控制器,后台控制器都继承于它,构造函数中进行验证当前 ...
- 前端到后台ThinkPHP开发整站(7)
今晚我继续这个项目的前台开发,把前台的做出来了,现在项目进行一个收尾工作了,还有栏目页和一个文章页的开发,做完这两个算是完成了.说到这里感觉有点松懈了,把剩下两个功能页面做完在吹吧,先看看今天弄的代码 ...
- 前端到后台ThinkPHP开发整站(完)
久违了,今天终于抽空把最后的写完了,这是这个项目的最后一篇文章了,把前台的栏目控制器和文章内容控制器的功能实现了. 栏目控制器: <?php namespace Home\Controller; ...
- 前端资源多个产品整站一键打包&包版本管理(一)
来新公司工作的第五个月.整站资源打包管理也提上了日程. 问题: 首先.什么是整站的打包管理呢? 我们公司的几个重要产品都在同一个webapp里面,但是,不同的开发部门独立开发不同的产品,长期以来,我们 ...
随机推荐
- 9.如何解决出现AXIOS的Request header field Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.
问题描述: 由于restful接口需要在头部header传递两个字段: Content-Type: application/jsonAccess-Token: 84c6635800b14e0eba4f ...
- 4.Smarty模板之间调用
{include file="header.tpl" name="cai"}
- 由form表单来说说前后台数据之间的交互
为什么从表单提交说起呢?因为大部分与后台的交互都是在form表单中实现,恰巧我入职一个月来都是在处理与后台交互的数据整合中度过,期间也发现一些小坑,出于喜欢总结,所以才想写这篇小博客. 各位童鞋,可以 ...
- Unity 游戏框架搭建 (六) 关于框架的一些好文和一些思考
在进行项目架构阶段,游戏框架可以解决一部分问题.剩下的架构问题还需要根据不同的项目解决.总之游戏框架是游戏架构的一部分. 关于锤子和钉子: 最近又拿起了<代码大全>和<暗时间 ...
- Python之编写登陆接口
1.输入用户名密码: 2.认证成功后显示欢迎信息: 3.错误三次后,账号被锁定. 账号文件:user.txt 锁定文件:locked.txt 流程图如下: # -*- coding:utf-8 -*- ...
- JQuery中实现Ajax
简单小案例: $("input").click(function() { $.get("test.txt",function(data){ $("h1 ...
- jsonp的原理和实现
什么是JSONP? javascript高级程序设计中是这样介绍jsonp的: jsonp是JSON with padding(填充式JSON或参数式JSON )的简写,是应用JSON的一种新方法,在 ...
- JavaScript创建对象的方法
显示在浏览器中的控制台中. <script type="text/javascript"> //这个工厂方法返回一个新的"范围对象" functio ...
- 动态绑定DropDownList
1.首先前台创建一个dropdownlist控件,并为这个控件起名id ,并且不要忘记runat=server这个属性,否则后台不能获取到该控件. 2.后台自定义方法绑定控件(本方法以三层架构的写法为 ...
- vue vuex的用法
1.引入 vue.js vuex.js 文件 2.创建Store文件 var sSatte=new Vuex.Store({ state:{}, mutations:{}, actions:{ ...