>웹 프론트엔드 >JS 튜토리얼 >CRUD를 생성하기 위한 jQuery 플러그인 EasyUI EasyUI를 쉽게 배워보세요.

CRUD를 생성하기 위한 jQuery 플러그인 EasyUI EasyUI를 쉽게 배워보세요.

WBOY
WBOY원래의
2016-05-16 15:28:561182검색

데이터 수집 및 적절한 데이터 관리는 네트워크 애플리케이션의 일반적인 필수 요소입니다. CRUD를 사용하면 페이지 목록을 생성하고 데이터베이스 레코드를 편집할 수 있습니다. 이 튜토리얼에서는 jQuery EasyUI 프레임워크를 사용하여 CRUD DataGrid를 구현하는 방법을 보여줍니다.
우리는 다음 플러그인을 사용할 것입니다:
datagrid: 사용자에게 목록 데이터를 표시합니다.
대화상자: 단일 사용자 메시지를 생성하거나 편집합니다.
양식: 은 양식 데이터를 제출하는 데 사용됩니다.
메시지: 일부 작업 정보를 표시합니다.

1. EasyUI로 CRUD 애플리케이션 만들기
1단계: 데이터베이스 준비

MySql 데이터베이스를 사용하여 사용자 정보를 저장합니다. 데이터베이스와 '사용자' 테이블을 만듭니다.

2단계: DataGrid를 생성하여 사용자 정보 표시

자바스크립트 코드 없이 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>

아래와 같이 사용자에게 목록을 표시하기 위해 자바스크립트 코드를 작성할 필요가 없습니다.

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>

이 대화 상자는 자바스크립트 코드 없이 생성되었습니다.

4단계: 사용자 생성 및 편집

사용자를 생성할 때 대화 상자를 열고 양식 데이터를 지웁니다.

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

사용자를 편집할 때 대화 상자를 열고 데이터 그리드의 선택한 행에서 양식 데이터를 로드합니다.

var row = $('#dg').datagrid('getSelected');
if (row){
 $('#dlg').dialog('open').dialog('setTitle','Edit User');
 $('#fm').form('load',row);
 url = 'update_user.php&#63;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&#63;',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을 열고 브라우저에서 코드를 실행하세요.

2. EasyUI는 행 세부 편집 양식을 확장하는 CRUD 애플리케이션을 생성합니다.

DataGrid 보기를 'detailview'로 전환하면 사용자는 행을 확장하여 행 아래에 일부 행 세부정보를 표시할 수 있습니다. 이 기능을 사용하면 세부 정보 패널에서 양식을 편집하는 데 적합한 레이아웃을 제공할 수 있습니다. 이 튜토리얼에서는 DataGrid 구성 요소를 사용하여 편집 양식이 차지하는 공간을 줄입니다.

1단계: HTML 태그에 데이터 그리드(DataGrid) 정의

<table id="dg" title="My Users" style="width:550px;height:250px"
 url="get_users.php"
 toolbar="#toolbar"
 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="newItem()">New</a>
 <a href="#" class="easyui-linkbutton" iconCls="icon-remove" plain="true" onclick="destroyItem()">Destroy</a>
</div>

2단계: DataGrid에 세부정보 보기 적용

$('#dg').datagrid({
 view: detailview,
 detailFormatter:function(index,row){
 return '<div class="ddv"></div>';
 },
 onExpandRow: function(index,row){
 var ddv = $(this).datagrid('getRowDetail',index).find('div.ddv');
 ddv.panel({
  border:false,
  cache:true,
  href:'show_form.php&#63;index='+index,
  onLoad:function(){
  $('#dg').datagrid('fixDetailRowHeight',index);
  $('#dg').datagrid('selectRow',index);
  $('#dg').datagrid('getRowDetail',index).find('form').form('load',row);
  }
 });
 $('#dg').datagrid('fixDetailRowHeight',index);
 }
});

为了为数据网格(DataGrid)应用明细视图,在 html 页面头部引入 'datagrid-detailview.js' 文件。
我们使用 'detailFormatter' 函数来生成行明细内容。 在这种情况下,我们返回一个用于放置编辑表单(form)的空的 dc6dce4a544fdca2df29d5ac0ea9906b。 当用户点击行展开按钮('+')时,'onExpandRow' 事件将被触发,我们将通过 ajax 加载编辑表单(form)。 调用 'getRowDetail' 方法来得到行明细容器,所以我们能查找到行明细面板(panel)。 在行明细中创建面板(panel),加载从 'show_form.php' 返回的编辑表单(form)。
步骤 3:创建编辑表单(Form)

编辑表单(form)是从服务器加载的。
show_form.php

<form method="post">
 <table class="dv-table" style="width:100%;background:#fafafa;padding:5px;margin-top:5px;">
 <tr>
  <td>First Name</td>
  <td><input name="firstname" class="easyui-validatebox" required="true"></input></td>
  <td>Last Name</td>
  <td><input name="lastname" class="easyui-validatebox" required="true"></input></td>
 </tr>
 <tr>
  <td>Phone</td>
  <td><input name="phone"></input></td>
  <td>Email</td>
  <td><input name="email" class="easyui-validatebox" validType="email"></input></td>
 </tr>
 </table>
 <div style="padding:5px 0;text-align:right;padding-right:30px">
 <a href="#" class="easyui-linkbutton" iconCls="icon-save" plain="true" onclick="saveItem(<&#63;php echo $_REQUEST['index'];&#63;>)">Save</a>
 <a href="#" class="easyui-linkbutton" iconCls="icon-cancel" plain="true" onclick="cancelItem(<&#63;php echo $_REQUEST['index'];&#63;>)">Cancel</a>
 </div>
</form>

步骤 4:保存或取消编辑

调用 'saveItem' 函数来保存一个用户或者调用 'cancelItem' 函数来取消编辑。

function saveItem(index){
 var row = $('#dg').datagrid('getRows')[index];
 var url = row.isNewRecord &#63; 'save_user.php' : 'update_user.php&#63;id='+row.id;
 $('#dg').datagrid('getRowDetail',index).find('form').form('submit',{
 url: url,
 onSubmit: function(){
  return $(this).form('validate');
 },
 success: function(data){
  data = eval('('+data+')');
  data.isNewRecord = false;
  $('#dg').datagrid('collapseRow',index);
  $('#dg').datagrid('updateRow',{
  index: index,
  row: data
  });
 }
 });
}

决定要回传哪一个 URL,然后查找表单(form)对象,并调用 'submit' 方法来提交表单(form)数据。当保存数据成功时,折叠并更新行数据。

function cancelItem(index){
 var row = $('#dg').datagrid('getRows')[index];
 if (row.isNewRecord){
 $('#dg').datagrid('deleteRow',index);
 } else {
 $('#dg').datagrid('collapseRow',index);
 }
}

当取消编辑动作时,如果该行是新行而且还没有保存,直接删除该行,否则折叠该行。

以上就是关于EasyUI创建CRUD应用的七大步骤,分享给大家,希望对大家的学习有所帮助。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.