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


      继续我的这个项目的第三晚的开发了,时间比较少,今晚写的代码不多,今晚仍然是造轮子写一个公共的控制器和一个公共的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

  • 相关阅读:
    Atlas学习手记(17):使用FilteredTextBox过滤字符
    Atlas学习手记(22):使用行为增强用户界面(二):Floating Behavior
    Atlas学习手记(27):JavaScript面向对象的扩展(一):命名空间Namespace
    Atlas学习手记(20):客户端简单控件示例
    Atlas学习手记(19):客户端简单控件介绍
    Atlas学习手记(15):使用RoundedCorners为控件加上圆角效果
    bootstraptable中的checkbox 操作事件
    Mysql: Table 'name' is specified twice, both as a target for 'UPDATE' and as a separate source for d
    ASP.NET配置KindEditor富文本编辑器
    js如何获取kindeditor的值
  • 原文地址:https://www.cnblogs.com/lzy138/p/7208665.html
Copyright © 2020-2023  润新知