zoukankan      html  css  js  c++  java
  • 与数据库连接的页面增删改查 的easyui实现(主要是前端实现)

    一.首先看一下最终实现的效果,上图

    二.思路,主要是分两个文件实现,一个是页面显示文件:代码如下:

    <html>
    <head>
    <title>示例管理</title> #parse("ui:include")
    <script
        src="${path}/com/gdt/project/dsm/demo/demoModel/demoModel_script.vm"></script>
    <link type="text/css" rel="stylesheet" href="$path/ui/resource/common/css/global.css"  />
    <style>
    body {
        padding: 0;
        margin: 0
    }
    </style>
    </head>
    <body>
        <div class="easyui-layout" style=" 100%; height: 100%;">
            <div data-options="region:'north'"  class="query-panel"  title="查询条件" style="height: 80px;">
                    <form id="demoModelForm_Query" method="post">
                        <label>姓名:</label><input class="easyui-textbox" style=" 110px" name="name">
                        <label>地址:</label><input class="easyui-textbox" style=" 110px" name="address"> 
                        <label>身份证:</label><input class="easyui-textbox"style=" 110px" name="cardNo">
                         <input type="hidden" name="rule" value="name*eq@address*eq@cardNo*eq"> 
                         <a href="javascript:void(0);" class="easyui-linkbutton" iconCls="icon-search"
                            onclick='javascript:$("#grid_demoModel").datagrid("load",jQuery("#demoModelForm_Query").serializeObject());'>查询</a>
                    </form>
            </div>
            <div data-options="region:'center',title:'示例列表'">
                <table id="grid_demoModel"></table>
                <div id="dialog_demoModel" class="easyui-dialog"
                    style=" 400px; height: 280px; padding: 10px 20px;"
                    closed="true">
                    <form id="demoModelForm_Manager">
                        姓名:<input name="name" class="easyui-validatebox textbox"
                            style=" 150px" data-options="required:true  "><br>
                        地址:<input name="address" class="easyui-validatebox textbox"
                            style=" 150px" data-options="required:true  "><br>
                        身份证:<input id="uniquecardNo" name="cardNo"
                            class="easyui-validatebox textbox" style=" 150px"
                            data-options="required:true">
                    </form>
                </div>
            </div>
        </div>
    </body>
    </html>

    另一个是页面与后台交互的实现代码文件:

    #parse("ui:path")
    jQuery(document).ready(function(){
    	client.initView();
    });
    var client = {
    	grid:null,
    	updateEntity:false,
    	initView:function(){
    		var me = this;
    		var toolbar = me.createToolbar();
    		var grid = me.initGrid({toolbar:toolbar,url:'${path}/com/gdt/project/dsm/demo/demoModel/page.do'});
    	},
    	initGrid:function(param){
        	this.grid = jQuery("#grid_demoModel").datagrid({
        		url:param.url,
        		pagination:true,
        		singleSelect:true,
    			fit:true,
    			fitColumns:true,
    			toolbar:param.toolbar,
        		columns:[[   
    					    		{field:'name',title:'姓名' },			    		{field:'address',title:'地址' },			    		{field:'cardNo',title:'身份证' }			    			]]
        	});
    		return this.grid;
    	},
    	openInsertDialog:function(){
    		var me = this;
    		me.updateEntity = false;
    		jQuery("#uniquecardNo").attr("readonly",false);
    		me.clearForm();
    		me.setDialog({name:'#dialog_demoModel',button:me.executeButton(),title:'新增示例'});
    	},
    	openMergerDialog:function(){
    		var me = this;
    		var row = jQuery("#grid_demoModel").datagrid("getSelected");
            if (row) {
        		me.updateEntity = true;
    		jQuery("#uniquecardNo").attr("readonly",true);
        		me.setDialog({name:'#dialog_demoModel',button:me.executeButton(),title:'修改示例'});
        		me.clearForm();
                jQuery("#demoModelForm_Manager").form("load", row);
            }
    		
    	},
    	openRemoveConfirm:function(){
    		var row = jQuery("#grid_demoModel").datagrid("getSelected");
    		if (row) {
    			jQuery.messager.confirm('系统提示', '是否删除?', function (r) {
                    if (r) {
    					var rtn = server.deleteObject(row);
    					if(rtn.STATU == '801'){
    						client.reload();
    					}
        			}
    			});
    		}
    	},
    	executeButton:function(){
    		var me = this;
    		return [{
    				text:'保存',
    				iconCls:'icon-save',
    				handler:function(){
    					var obj = jQuery("#demoModelForm_Manager").serializeObject();
    				if(obj.cardNo){
    					var codecardNo = server.uniqueCode({cardNo:obj.cardNo,rule:'cardNo*eq'});
    					$('#uniquecardNo').tooltip("hide");
    					if(codecardNo&&!me.updateEntity){
    						$('#uniquecardNo').tooltip({
    				            position: 'right',
    				            content: '<span style="color:#000000">该编码已被占用.</span>',
    				            onShow: function(){
    				        		$(this).tooltip('tip').css({
    				        			borderColor: 'red'
    				        		});
    				            }
    				    	}).tooltip("show");
    						return;
    					}
    				}
    					var validate = jQuery("#demoModelForm_Manager").form('enableValidation').form('validate');
    					if(validate){
        					if(me.updateEntity){
        						var row = jQuery("#grid_demoModel").datagrid("getSelected");
    								obj['id'] = row.id;
    													    													    													    													        						
        					}
        					var rtn = server.saveOrUpdate(obj);
        					if(rtn.STATU == '801'){
        						me.reload();
        					}
        					me.dialogControl({dialog:'#dialog_demoModel',control:'close'});
    					}
    				}
    			},{
    				text:'关闭',
    				iconCls:'icon-cancel',
    				handler:function(){
    					me.dialogControl({dialog:'#dialog_demoModel',control:'close'});
    				}
    			}];
    	},
    	reload:function(){
    		var me = this;
    		me.grid.datagrid("load");
    	},
    	setDialog:function(param){
    		jQuery(param.name).dialog({
    			modal:true,
    			buttons:param.button
    		}).dialog('open').dialog('setTitle', param.title);
    	},
    	createToolbar:function(){
    		var btns = server.btns();
    		var toolbar = [];
    		jQuery.each(btns,function(i,n){
    			with(n){
    				toolbar.push({text:btnName,iconCls:icon,handler:function(){eval(fun);}});
    			}
    		});
    		return toolbar;
    	},
    	clearForm:function(){
    		jQuery("#demoModelForm_Manager").form('clear');
    	},
    	dialogControl:function(param){
    		jQuery(param.dialog).dialog(param.control);
    	}
    };
    var server = {
    	btns:function(){
    		var btns = [
    			{btnId:'1',btnName:'新增',icon:'icon-add',enabled:'Y',fun:'client.openInsertDialog();'},
    			{btnId:'2',btnName:'编辑',icon:'icon-edit',enabled:'Y',fun:'client.openMergerDialog();'},
    			{btnId:'3',btnName:'删除',icon:'icon-remove',enabled:'Y',fun:'client.openRemoveConfirm();'}];
    		return btns;
    	},
    	saveOrUpdate:function(param){
    		var rtn = null;
    		jQuery.ajax({
        		type: "POST",
        		data: param,
    			cache:false,
    			async:false,
    			url: "${path}/com/gdt/project/dsm/demo/demoModel/sou.do",
        		success: function(msg){
    				rtn = msg;
        		}
        	});
    		return rtn;
    	},
    	deleteObject:function(param){
    		var rtn = null;
    		jQuery.ajax({
        		type: "POST",
    			cache:false,
    			async:false,
    			data: param,
        		url: "${path}/com/gdt/project/dsm/demo/demoModel/delete.do",
        		success: function(msg){
    				rtn = msg;
        		}
        	});
    		return rtn;
    	},
    	uniqueCode:function(param){
    		var rtn = false;
    		jQuery.ajax({
        		type: "POST",
    			cache:false,
    			async:false,
    			data: param,
        		url: "${path}/com/gdt/project/dsm/demo/demoModel/findAll.do",
        		success: function(msg){
    				rtn = false;
    				if(msg.ReturnObjs.length>0){
    					rtn = true;
    				}
        		}
        	});
    		return rtn;
    	}
    };
    

     三.根据上述的ajax中的URL在controller、service、model中编写相应的处理代码 

  • 相关阅读:
    在Raspberry pi4上架设Minecraft1.17
    解决Android-x86在VMware中不能启动GUI的问题
    WMware player 16在超过两台显示器时的多显示器问题
    制动电阻的阻值和功率计算
    拉卡尼休在石块旷野
    在VirtualBox中调整Raspbian分辨率
    如何在VLC播放器中显示毫秒
    EXCEL高亮选中行/列
    Notepad++加强安全性检查,避免被CIA利用
    AutoCAD AutoLisp 脚本编写
  • 原文地址:https://www.cnblogs.com/zhangshitong/p/4826374.html
Copyright © 2011-2022 走看看