jQuery EasyUI
jQuery EasyUI 简介
jEasyUI 创建 CRUD 数据网格
jEasyUI 表单的 CRUD 应用
jEasyUI 创建 RSS 阅读器
jEasyUI 基本的拖动和放置
jEasyUI 创建拖放的购物车
jEasyUI 创建学校课程表
jEasyUI 创建简单的菜单
jEasyUI 创建链接按钮
jEasyUI 创建菜单按钮
jEasyUI 创建分割按钮
jEasyUI 创建边框布局
jEasyUI 创建复杂布局
jEasyUI 创建折叠面板
jEasyUI 创建标签页
jEasyUI 动态添加标签页
jEasyUI 添加自动播放标签页
jEasyUI 创建 XP 风格左侧面板
jEasyUI 转换 HTML 表格为数据网格
jEasyUI 取得选中行数据
jEasyUI 添加查询功能
jEasyUI 添加工具栏
jEasyUI 创建复杂工具栏
jEasyUI 设置冻结列
jEasyUI 动态改变列
jEasyUI 格式化列
jEasyUI 设置排序
jEasyUI 自定义排序
jEasyUI 创建列组合
jEasyUI 添加复选框
jEasyUI 自定义分页
jEasyUI 启用行内编辑
jEasyUI 扩展编辑器
jEasyUI 列运算
jEasyUI 合并单元格
jEasyUI 创建自定义视图
jEasyUI 创建页脚摘要
jEasyUI 条件设置行背景颜色
jEasyUI 创建属性网格
jEasyUI 扩展行显示细节
jEasyUI 创建子网格
jEasyUI 显示海量数据
jEasyUI 添加分页组件
jEasyUI 创建简单窗口
jEasyUI 自定义窗口工具栏
jEasyUI 窗口与布局
jEasyUI 创建对话框
jEasyUI 自定义对话框
jEasyUI 使用标记创建树形菜单
jEasyUI 创建异步树形菜单
jEasyUI 树形菜单添加节点
jEasyUI 创建带复选框的树形菜单
jEasyUI 树形菜单拖放控制
jEasyUI 树形菜单加载父/子节点
jEasyUI 创建基础树形网格
jEasyUI 创建复杂树形网格
jEasyUI 树形网格动态加载
jEasyUI 树形网格添加分页
jEasyUI 树形网格惰性加载节点
jEasyUI 创建异步提交表单
jEasyUI 表单验证
jEasyUI 创建树形下拉框
jEasyUI 格式化下拉框
jEasyUI 过滤下拉数据网格
jQuery EasyUI 插件
jQuery EasyUI 扩展
 

jEasyUI 创建 CRUD 应用

阅读:194      收藏:0      [点我收藏+]

jQuery EasyUI 应用 -创建 CRUD 应用

数据收集并妥善管理数据是网络应用共同的必要。CRUD 允许我们生成页面列表,并编辑数据库记录。本教程将向你演示如何使用 jQuery EasyUI 框架实现一个 CRUD DataGrid。

我们将使用下面的插件:

  • datagrid:向用户展示列表数据。
  • dialog:创建或编辑一条单一的用户信息。
  • form:用于提交表单数据。
  • messager:显示一些操作信息。

步骤 1:准备数据库

我们将使用 MySql 数据库来存储用户信息。创建数据库和 ‘users‘ 表。

步骤 2:创建 DataGrid 来显示用户信息

创建没有 javascript 代码的 DataGrid。

<table id="dg" title="My Users" class="easyui-datagrid" style="width:550px;height:250px"
		url="get_users.php"
		toolbar="#toolbar"
		rownumbers="true" fitColumns="true" singleSelect="true">
	<thead>
		<tr>
			<th field="firstname" width="50">First Name</th>
			<th field="lastname" width="50">Last Name</th>
			<th field="phone" width="50">Phone</th>
			<th field="email" width="50">Email</th>
		</tr>
	</thead>
</table>
<div id="toolbar">
	<a href="#" class="easyui-linkbutton" iconCls="icon-add" plain="true" onclick="newUser()">New User</a>
	<a href="#" class="easyui-linkbutton" iconCls="icon-edit" plain="true" onclick="editUser()">Edit User</a>
	<a href="#" class="easyui-linkbutton" iconCls="icon-remove" plain="true" onclick="destroyUser()">Remove User</a>
</div>

我们不需要写任何的 javascript 代码,就能向用户显示列表,如下图所示:

DataGrid 使用 ‘url‘ 属性,并赋值为 ‘get_users.php‘,用来从服务器检索数据。

get_users.php 文件的代码

$rs = mysql_query(‘select * from users‘);
$result = array();
while($row = mysql_fetch_object($rs)){
	array_push($result, $row);
}

echo json_encode($result);

步骤 3:创建表单对话框

我们使用相同的对话框来创建或编辑用户。

<div id="dlg" class="easyui-dialog" style="width:400px;height:280px;padding:10px 20px"
		closed="true" buttons="#dlg-buttons">
	<div class="ftitle">User Information</div>
	<form id="fm" method="post">
		<div class="fitem">
			<label>First Name:</label>
			<input name="firstname" class="easyui-validatebox" required="true">
		</div>
		<div class="fitem">
			<label>Last Name:</label>
			<input name="lastname" class="easyui-validatebox" required="true">
		</div>
		<div class="fitem">
			<label>Phone:</label>
			<input name="phone">
		</div>
		<div class="fitem">
			<label>Email:</label>
			<input name="email" class="easyui-validatebox" validType="email">
		</div>
	</form>
</div>
<div id="dlg-buttons">
	<a href="#" class="easyui-linkbutton" iconCls="icon-ok" onclick="saveUser()">Save</a>
	<a href="#" class="easyui-linkbutton" iconCls="icon-cancel" onclick="javascript:$(‘#dlg‘).dialog(‘close‘)">Cancel</a>
</div>

这个对话框已经创建,也没有任何的 javascript 代码:。

步骤 4:实现创建和编辑用户

当创建用户时,打开一个对话框并清空表单数据。

function newUser(){
	$(‘#dlg‘).dialog(‘open‘).dialog(‘setTitle‘,‘New User‘);
	$(‘#fm‘).form(‘clear‘);
	url = ‘save_user.php‘;
}

当编辑用户时,打开一个对话框并从 datagrid 选择的行中加载表单数据。

var row = $(‘#dg‘).datagrid(‘getSelected‘);
if (row){
	$(‘#dlg‘).dialog(‘open‘).dialog(‘setTitle‘,‘Edit User‘);
	$(‘#fm‘).form(‘load‘,row);
	url = ‘update_user.php?id=‘+row.id;
}

‘url‘ 存储着当保存用户数据时表单回传的 URL 地址。

步骤 5:保存用户数据

我们使用下面的代码保存用户数据:

function saveUser(){
	$(‘#fm‘).form(‘submit‘,{
		url: url,
		onSubmit: function(){
			return $(this).form(‘validate‘);
		},
		success: function(result){
			var result = eval(‘(‘+result+‘)‘);
			if (result.errorMsg){
				$.messager.show({
					title: ‘Error‘,
					msg: result.errorMsg
				});
			} else {
				$(‘#dlg‘).dialog(‘close‘);		// close the dialog
				$(‘#dg‘).datagrid(‘reload‘);	// reload the user data
			}
		}
	});
}

提交表单之前,‘onSubmit‘ 函数将被调用,该函数用来验证表单字段值。当表单字段值提交成功,关闭对话框并重新加载 datagrid 数据。

步骤 6:删除一个用户

我们使用下面的代码来移除一个用户:

function destroyUser(){
	var row = $(‘#dg‘).datagrid(‘getSelected‘);
	if (row){
		$.messager.confirm(‘Confirm‘,‘Are you sure you want to destroy this user?‘,function(r){
			if (r){
				$.post(‘destroy_user.php‘,{id:row.id},function(result){
					if (result.success){
						$(‘#dg‘).datagrid(‘reload‘);	// reload the user data
					} else {
						$.messager.show({	// show error message
							title: ‘Error‘,
							msg: result.errorMsg
						});
					}
				},‘json‘);
			}
		});
	}
}

移除一行之前,我们将显示一个确认对话框让用户决定是否真的移除该行数据。当移除数据成功之后,调用 ‘reload‘ 方法来刷新 datagrid 数据。

步骤 7:运行代码

开启 MySQL,在浏览器运行代码。


© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!