正常情况下,在一个部门管理页面,不仅仅需要展示列表数据,还需要基本的增删改操作,所以,我们先把之前写好的新增功能集成进来。

在toolbar中,添加一个新增按钮。

<div id="toolbar" style="padding:10px 12px;">

	<a href="javascript:openDialog()" class="easyui-linkbutton" iconCls="icon-add" plain="true">新增部门</a>

	<br><br>

	请输入部门名称:<input type="text" name="deptname" id="deptname" />

	<button onclick="search();" id="submit" style="float:right;">查询</button>

</div>

然后,编写其点击事件:

function openDialog(){
alert();
}

测试一下,在页面中点击这个新增按钮,能不能成功的alert,如果不能,那么就去仔细查看是不是哪里写错了,比如少了个括号什么的。

在body区域加上dialog的div标签块。

<div id="dialog0" class="easyui-dialog" style="width:500px;height:300px;padding:10px 20px;" closed="true"
data-options="title:'部门新增'" buttons="#dialog0-buttons">
<!-- 在对话框中画一个简单的表达组件 -->
<form id="form0" method="post">
<table cellspacing="5px;" cellpadding="0px">
<tr> <td>部门编号:</td>
<td><input type="text" id="deptid" name="deptid" class="easyui-validatebox" required="true"/></td>
</tr> <tr> <td>部门名称:</td>
<td><input type="text" id="deptname" name="deptname" class="easyui-validatebox" required="true"/></td>
</tr> </table> </form> </div> <div id="dialog0-buttons">
<a href="javascript:save();" class='easyui-linkbutton' iconCls="icon-ok">保存</a>
</div>

别忘了修改openDialog方法的内容:

function openDialog(){
$("#dialog0").dialog("open");
}

效果:

当我们点击保存按钮,回去调用一下save方法, 因为这个保存按钮:

<a href="javascript:save();" class='easyui-linkbutton' iconCls="icon-ok">保存</a>

它拥有一个save的点击事件。

Save函数:

function save(){

  $("#form0").form("submit",{

  	//提交的目标服务器地址
url : "saveDept.php" , //验证表单内元素是否有效?
onSubmit : function(){
return $(this).form("validate");
} , //如果服务器成功返回数据,就会启动这个方法
//参数data就是服务器返回的数据
success : function(data){
$.messager.alert("系统提醒","保存成功!");
$("#dialog0").dialog("close");
} }); }

表单提交的地址是saveDept.php.

<?php

	//建立MYSQL数据库连接
$conn = mysql_connect("localhost","root","");
//选择test数据库
$db = mysql_select_db("test",$conn);
//设置编码格式为UTF-8,以便支持中文
mysql_query("set names utf8"); $deptid = $_POST["deptid"];
$deptname = $_POST["deptname"]; //echo "部门编号:$deptid<br>";
//echo "部门名称:$deptname"; //编写sql语句 $sql = "INSERT INTO tm_dept (id, deptid, deptname, createtime, updatetime) VALUES (NULL, '$deptid', '$deptname', now(), now());"; //执行sql语句
mysql_query($sql) or die(mysql_error()); echo "success"; ?>

如果你希望在新增成功后,默认刷新列表,就在回调函数中加一个search方法的调用即可:

后台错误返回

正常情况下,后台代码的运行不会一帆风顺,可能会发生一些错误,这个时候我们就需要告诉页面有没有错,发生了什么错。在企业里面,一般会设置一个错误对象,包含错误信息和错误码。

php:

在执行sql之前,定义一个通用的返回对象,包含错误码和错误信息

$resultData = array();
$resultData['errCode'] = 0; //默认错误码为0,表示没有错误
$resultData['errMsg'] = ""; //默认错误信息为空

然后,执行sql语句的时候,调用err函数:

//编写sql语句

	$sql = "INSERT INTO tm_dept (id, deptid, deptname, createtime, updatetime) VALUES (NULL, '$deptid', '$deptname', now(), now());";

	//执行sql语句
mysql_query($sql) or die( err() ); function err(){
$resultData['errCode'] = -1;
$resultData['errMsg'] = mysql_error();
echo json_encode($resultData);
}

前台接收的方式:

$("#form0").form("submit",{

  	//提交的目标服务器地址
url : "saveDept.php" , //验证表单内元素是否有效?
onSubmit : function(){
return $(this).form("validate");
} , //如果服务器成功返回数据,就会启动这个方法
//参数data就是服务器返回的数据
success : function(data){ data = eval("("+data+")"); if(data.errCode < 0){
$.messager.alert("系统提醒","后台程序发生错误,原因是:<br><font style='color:red;'>"+data.errMsg+"</font>");
return;
} $.messager.alert("系统提醒","保存成功!");
$("#dialog0").dialog("close");
search();
} }); }

PS:如果sql语句成功执行,就应该把resultData输出到页面。

//执行sql语句
mysql_query($sql) or die( err() ); echo json_encode($resultData);

下载地址:https://pan.baidu.com/s/1OXvqQwAmz7usgD4KqiUXLw

【php增删改查实例】第十节 - 部门管理模块(新增功能)的更多相关文章

  1. 【php增删改查实例】第九节 - 部门管理模块(模糊查询)

    给datagrid添加一个工具栏. 效果: 模糊查询部门名称. 接下来,在工具栏区域画一个input框: <div id="toolbar" style="padd ...

  2. 【php增删改查实例】第八节 - 部门管理模块(编写PHP程序)

    首先,在同级目录新建一个query.php文件: 接着,去刷新页面,打开F12,NetWork,看看当前的请求能不能走到对应的php文件? 这就说明datagrid确实能够访问到query.php 只 ...

  3. 【php增删改查实例】 第二节 - MYSQL环境配置

    安装好xampp后,会自带一个mysql,也就是说,正常情况下,你直接这样: 就可以启动mysql了. 如果你了,下面的步骤就别看了哈. if( 启动成功 ){ return; } 如果你的电脑上已经 ...

  4. 【php增删改查实例】第一节 - PHP开发环境配置

    最近需要使用PHP,于是把平时的积累整理一下,就有了这个教程. 首先是环境配置: 1.操作系统:windos7 2.后台:PHP 3.前台:Html + js + css 4.数据库:MYSQL 5. ...

  5. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  6. java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)

    1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...

  7. yii2.0增删改查实例讲解

    yii2.0增删改查实例讲解一.创建数据库文件. 创建表 CREATE TABLE `resource` ( `id` int(10) NOT NULL AUTO_INCREMENT, `textur ...

  8. SpringBoot JPA实现增删改查、分页、排序、事务操作等功能

    今天给大家介绍一下SpringBoot中JPA的一些常用操作,例如:增删改查.分页.排序.事务操作等功能.下面先来介绍一下JPA中一些常用的查询操作: //And --- 等价于 SQL 中的 and ...

  9. 【php增删改查实例】第十四节 - 用户管理模块(起步)

    从这一节开始,开始着手开发部门管理模块. 之后的内容就在此基础上进行增加. 1.用户查询 在目录中建立一个user文件夹,作为我们用户管理的模块. 打开这个文件,新建一个userManage.html ...

随机推荐

  1. ThreadLocal深入理解 修订版

    本文是传智博客多线程视频的学习笔记. 原版本见 http://blog.csdn.net/dlf123321/article/details/42531979 ThreadLocal是一个和线程安全相 ...

  2. eclipse 设置maven来自动下载源码与doc

    通常我们通过maven来使用各种库文件,想要真正了解别人的类实现方法,需要查看别人的源码,maven给我们提供了这个便利,它不仅可以下载各种库文件,还会下载对应的源码和doc文档. 一.在工具栏找到W ...

  3. kettel的stream lookup报错

    kettel的stream lookup报错: you can't use the 'integer-pair' algorithm when you have more than one key o ...

  4. 一个简单的基于 DirectShow 的播放器 2(对话框类)

    上篇文章分析了一个封装DirectShow各种接口的封装类(CDXGraph):一个简单的基于 DirectShow 的播放器  1(封装类) 本文继续上篇文章,分析一下调用这个封装类(CDXGrap ...

  5. 【Android 应用开发】BluetoothSocket详解

    一. BluetoothSocket简介 1. 简介 客户端与服务端 : BluetoothSocket 和 BluetoothServerSocket 类似于Java中的套接字的 Socket 和 ...

  6. Spring 学习笔记---Bean的生命周期

    生命周期图解 由于Bean的生命周期经历的阶段比较多,我们将通过一个图形化的方式进行描述.下图描述了BeanFactory中Bean生命周期的完整过程: Bean 的生命周期从Spring容器着手实例 ...

  7. Java工程师成神之路思维导图

    前面看Hollis的微信公众号更新了Java工程师成神之路的文档,感觉里面的内容清晰.齐全,可以用来审视自己,也能够知道自己在那些方面可以继续前行,想着有时间把它画下来,画下来之后分享出来. 主要内容 ...

  8. Eclipse常见设置

    当新建一个workspace时,习惯做下面的设置: 1. 在eclipse中,默认的Text file encoding是GBK(操作系统是中文简体):如果操作系统是中文繁体,默认是MS950(Big ...

  9. WebService学习--(一)webservice相关概念

    一.序言 大家或多或少都听过 WebService(Web服务),有一段时间很多计算机期刊.书籍和网站都大肆的提及和宣传WebService技术,其中不乏很多吹嘘和做广告的成 分.但是不得不承认的是W ...

  10. Spring Cloud入门教程-Ribbon实现客户端负载均衡

    简介 我们继续以之前博客的代码为基础,增加Ribbon组件来提供客户端负载均衡.负载均衡是实现高并发.高性能.可伸缩服务的重要组成部分,它可以把请求分散到一个集群中不同的服务器中,以减轻每个服务器的负 ...