继续我的这个项目的第三晚的开发了,时间比较少,今晚写的代码不多,今晚仍然是造轮子写一个公共的控制器和一个公共的JS。直接上代码吧!

  以下是一个公共的控制器,后台控制器都继承于它,构造函数中进行验证当前用户是否登录状态和提供快获取当前登录用户的数据。

<?php
namespace Admin\Controller;
use Think\Controller; /**
* 后台管理公共控制器
*/
class CommonController extends Controller{
public function __construct(){
parent::__construct();
$this->_init();
} /**
* 初始化
*/
private function _init(){
// 如果已经登录
$isLogin=$this->isLogin();
if(!$isLogin){
//跳转到登录页面
$this->redirect('/admin.php?c=login');
}
} /**
* 获取当前登录用户信息
*/
public function getLoginUser(){
return session('adminUser');
} /**
* 判断是否登录
*/
public function isLogin(){
$user=$this->getLoginUser();
return ($user && is_array($user));
} /**
* 更新数据状态
*/
public function setStatus($data,$models){
try{
if($_POST){
$id=$data['id'];
$status=$data['status'];
if(!$id){
return jsonResult(0, 'ID不存在');
}
$ret=D($models)->updateStatusById($id,$status);
if($ret){
return jsonResult(1, '操作成功');
}else{
return jsonResult(0, '操作失败');
}
}
return jsonResult(0,'没有提交的内容');
}catch(Exception $ex){
return jsonResult(0, $e->getMessage());
}
} /**
* 数据排序
*/
public function listorder($model=''){
$listorder=$_POST['listorder'];
$jumpUrl=$_SERVER['HTTP_REFERER'];
$errors=array();
$resultData=array('jump_url'=>$jumpUrl);
try{
if($listorder){
foreach($listorder as $id=>$v){
$id=D($model)->updateListorderById($id,$v);
if($id===FALSE){
$errors[]=$id;
}
}
if(array_count_values($errors)>0){
$group=implode(',', $errors);
return jsonResult(0, "排序失败-{$group}", $data,$resultData);
}
return jsonResult(1, '排序成功', $resultData);
}
}catch(Exception $ex){
return jsonResult(0, $ex->getMessage());
}
return jsonResult(0, '排序失败', $resultData);
}
}
?>

  以下一段JS,主要是做一些表单操作的方法。

var common = function(queryDom) {
if(!queryDom){
console.error('请传入需要操作的DOM选择字符');
return;
}
function commonObj() {
this.dom = '';
} function todelete(url, data) {
$.post(
url,
data,
function(s) {
if(s.status == 1) {
return dialog.success(s.message, '');
// 跳转到相关页面
} else {
return dialog.error(s.message);
}
}, "JSON");
} /**
* 提交form表单操作
*/
commonObj.prototype.add = function(formDom, func) {
$(this.dom).click(function() {
var data = $(formDom).serializeArray();
postData = {};
$(data).each(function(i) {
postData[this.name] = this.value;
});
console.log(postData);
// 将获取到的数据post给服务器
url = SCOPE.save_url;
jump_url = SCOPE.jump_url;
$.post(url, postData, function(result) {
if(result.status == 1) {
//成功
if(typeof(func) == 'function') {
func();
} else {
return dialog.success(result.message, jump_url);
}
} else if(result.status == 0) {
// 失败
return dialog.error(result.message);
}
}, "JSON");
});
} /**
* 编辑模块
*/
commonObj.prototype.click = function() {
$(this.dom).on('click', function() {
var id = $(this).attr('attr-id');
var url = SCOPE.edit_url + '&id=' + id;
window.location.href = url;
});
} /*
* 删除操作
*/
commonObj.prototype.delete = function() {
$(this.dom).on('click', function() {
var id = $(this).attr('attr-id');
var a = $(this).attr("attr-a");
var message = $(this).attr("attr-message");
var url = SCOPE.set_status_url; data = {};
data['id'] = id;
data['status'] = -1; layer.open({
type: 0,
title: '是否提交?',
btn: ['yes', 'no'],
icon: 3,
closeBtn: 2,
content: "是否确定" + message,
scrollbar: true,
yes: function() {
// 执行相关跳转
todelete(url, data);
},
});
});
} /**
* 排序操作
*/
commonObj.prototype.order = function() {
$(this.dom).click(function() {
// 获取 listorder内容
var data = $("#singcms-listorder").serializeArray();
postData = {};
$(data).each(function(i) {
postData[this.name] = this.value;
});
console.log(data);
var url = SCOPE.listorder_url;
$.post(url, postData, function(result) {
if(result.status == 1) {
//成功
return dialog.success(result.message, result['data']['jump_url']);
} else if(result.status == 0) {
// 失败
return dialog.error(result.message, result['data']['jump_url']);
}
}, "JSON");
});
} /**
* 更改状态
*/
commonObj.prototype.updateStatus = function() {
$(this.dom).on('click', function() {
var id = $(this).attr('attr-id');
var status = $(this).attr("attr-status");
var url = SCOPE.set_status_url;
data = {};
data['id'] = id;
data['status'] = status;
layer.open({
type: 0,
title: '是否提交?',
btn: ['yes', 'no'],
icon: 3,
closeBtn: 2,
content: "是否确定更改状态",
scrollbar: true,
yes: function() {
// 执行相关跳转
todelete(url, data);
},
});
});
} commonObj.prototype.push = function() {
$(this.dom).click(function() {
var id = $("#select-push").val();
if(id == 0) {
return dialog.error("请选择推荐位");
}
push = {};
postData = {};
$("input[name='pushcheck']:checked").each(function(i) {
push[i] = $(this).val();
}); postData['push'] = push;
postData['position_id'] = id;
//console.log(postData);return;
var url = SCOPE.push_url;
$.post(url, postData, function(result) {
if(result.status == 1) {
// TODO
return dialog.success(result.message, result['data']['jump_url']);
}
if(result.status == 0) {
// TODO
return dialog.error(result.message);
}
}, "json"); });
} return new commonObj();
}

  今晚就弄了那么点,反正慢慢来,不会有人催我项目进度的,主要是自己能坚持把这个项目做完。代码写到这里天色已晚,困了,都没去运行下,肯定会有些BUG的了,等一个模块开发完再去调试代码吧!

  源码地址:https://github.com/YoZiLin/TP-CMS

前端到后台ThinkPHP开发整站(3)的更多相关文章

  1. 前端到后台ThinkPHP开发整站--php开发案例

    前端到后台ThinkPHP开发整站--php开发案例 总结 还是需要做几个案例,一天一个为佳,那样才能做得快. 从需求分析着手,任务体系要构建好,这样才能非常高效. 转自: 前端到后台ThinkPHP ...

  2. 前端到后台ThinkPHP开发整站(2)

    我这次使用的ThinkPHP版本是:3.2.3版本,还有会使用到一个弹出层插件,叫 layer,官网地址是:http://layer.layui.com/.废话不多说,进入撸码环节. 1.通用方法编写 ...

  3. 前端到后台ThinkPHP开发整站(6)

    今天终于把整个后台管理系统弄好了,其实没什么难点,只是作为一个Thinphp学习的练手项目,这个项目,现在还只能算是做了一半,还有前台展示方面的功能没有完成.先过一遍后台的功能吧! 1.首页 2.菜单 ...

  4. 前端到后台ThinkPHP开发整站(5)

    今天周五了,这个项目做了五个晚上了,明天周末不用上班有一整天的时间来结束这个项目了,今晚主要把后台界面给弄出来了. 大概的整个后台界面就是这个样子了,接下来的工作就是搬砖了,一个个菜单功能填上去就是了 ...

  5. 前端到后台ThinkPHP开发整站(4)

    今晚继续我的这个项目的开发,今晚也是写的不多,主要写了一个菜单管理功能的CURD方法,前端界面还没有进行编写. 菜单管理Model层的代码: <?php namespace Common\Mod ...

  6. 前端到后台ThinkPHP开发整站(1)

    1.前言: 我个人从来没有写过博客文章,作为一个程序员没有自己的博客算是一个合格的程序员,所以我地想想也要经营起一个的博客,做一个小项目,写这博客算就做这个项目的一个项目笔记吧!现在自学着ThinkP ...

  7. 前端到后台ThinkPHP开发整站(7)

    今晚我继续这个项目的前台开发,把前台的做出来了,现在项目进行一个收尾工作了,还有栏目页和一个文章页的开发,做完这两个算是完成了.说到这里感觉有点松懈了,把剩下两个功能页面做完在吹吧,先看看今天弄的代码 ...

  8. 前端到后台ThinkPHP开发整站(完)

    久违了,今天终于抽空把最后的写完了,这是这个项目的最后一篇文章了,把前台的栏目控制器和文章内容控制器的功能实现了. 栏目控制器: <?php namespace Home\Controller; ...

  9. 前端资源多个产品整站一键打包&包版本管理(一)

    来新公司工作的第五个月.整站资源打包管理也提上了日程. 问题: 首先.什么是整站的打包管理呢? 我们公司的几个重要产品都在同一个webapp里面,但是,不同的开发部门独立开发不同的产品,长期以来,我们 ...

随机推荐

  1. tab切换实现方式2

    tab切换实现方式2: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...

  2. Unity应用架构设计(13)——日志组件的实施

    对于应用程序而言,日志是非常重要的功能,通过日志,我们可以跟踪应用程序的数据状态,记录Crash的日志可以帮助我们分析应用程序崩溃的原因,我们甚至可以通过日志来进行性能的监控.总之,日志的好处很多,特 ...

  3. 网络流入门—用于最大流的Dinic算法

    "网络流博大精深"-sideman语 一个基本的网络流问题 最早知道网络流的内容便是最大流问题,最大流问题很好理解: 解释一定要通俗! 如右图所示,有一个管道系统,节点{1,2,3 ...

  4. Java自学手记——Java中的关键字

    Java中的一些关键字对于初学者来说有时候会比较混乱,在这里整理一下,顺便梳理一下目前掌握的关键字. 权限修饰符 有四个,权限从大到小是public>protected>defaul(无修 ...

  5. Jenkins+Git配置

    Jenkins+Git配置 一.GitHub上配置 前提:Jenkins能正常打开 将本地文件上传到GitHub上:进入终端 cd Documents cd project git clone htt ...

  6. 优雅的封装ajax,含跨域

    之前写过一篇 先定一个小目标,自己封装个ajax,是基于原生js的,也就是jquery中ajax的简化版本实现的思路.众所周知,jquery的ajax是项目中最常用的请求后台的方式,也算是封装的很完美 ...

  7. USB的前世今生

    在人类的历史长河中,很少有一种技术或者传输标准能像USB那样跟我们的生活息息相关,甚至到了没有不行的地步.USB对于今天的人们来说,就好像是空气,是水,是我们每天必需但是又熟视无睹的东西,没有多少人知 ...

  8. H5读取本地文件操作

    H5读取本地文件操作 本文转自:转:http://hushicai.com/2014/03/29/html5-du-qu-ben-di-wen-jian.html感谢大神分享. 常见的语言比如php. ...

  9. Django学习(九)---Templates过滤器及Django shell和Admin增强

    一.Templates过滤器 过滤器属于django模板语言 修改模板中的变量,从而显示不同内容 {{ value | filter }} 举例:{{ list_nums | length}}    ...

  10. NOIP模拟:饼干(简单规律推导)

    题目描述 小美有一张很大的网格:2 n * 2 n .每次小美会选一个小矩阵 2 x * 2 x , x > 0,小矩阵不能超过网格的边界.然后把右上一半都放上饼干.下图是当 x=1或2 的时候 ...