亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

輕松學習jQuery插件EasyUI EasyUI創建CRUD應用

2019-11-20 11:07:19
字體:
來源:轉載
供稿:網友

數據收集并妥善管理數據是網絡應用共同的必要。CRUD 允許我們生成頁面列表,并編輯數據庫記錄。本教程將向你演示如何使用 jQuery EasyUI 框架實現一個 CRUD DataGrid。
我們將使用下面的插件:
datagrid:向用戶展示列表數據。
dialog:創建或編輯一條單一的用戶信息。
form:用于提交表單數據。
messager:顯示一些操作信息。

一、EasyUI創建CRUD應用
步驟 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,在瀏覽器運行代碼。

二、EasyUI創建展開行明細編輯表單的CRUD 應用

當切換數據網格視圖(datagrid view)到 'detailview',用戶可以展開一行來顯示一些行的明細在行下面。這個功能允許您為防止在明細行面板(panel)中的編輯表單(form)提供一些合適的布局(layout)。在本教程中,我們使用數據網格(datagrid)組件來減小編輯表單(form)所占據空間。

步驟 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?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)的空的 <div>。 當用戶點擊行展開按鈕('+')時,'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(<?php echo $_REQUEST['index'];?>)">Save</a> <a href="#" class="easyui-linkbutton" iconCls="icon-cancel" plain="true" onclick="cancelItem(<?php echo $_REQUEST['index'];?>)">Cancel</a> </div></form>

步驟 4:保存或取消編輯

調用 'saveItem' 函數來保存一個用戶或者調用 'cancelItem' 函數來取消編輯。

function saveItem(index){ var row = $('#dg').datagrid('getRows')[index]; var url = row.isNewRecord ? 'save_user.php' : 'update_user.php?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應用的七大步驟,分享給大家,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩国产欧美精品一区二区三区| 久久久伊人日本| 欧美日本中文字幕| 亚洲乱码国产乱码精品精| 国产欧美日韩综合精品| 欧美日韩亚洲国产一区| 日韩免费电影在线观看| 欧美性猛交xxxxx免费看| 一本色道久久88亚洲综合88| 欧美日韩免费区域视频在线观看| 日韩成人在线视频网站| 亚洲男人天堂2019| 97精品国产97久久久久久春色| 国产成人avxxxxx在线看| 日韩女优人人人人射在线视频| 日韩在线观看高清| 国产精品国产三级国产aⅴ9色| 久久精品夜夜夜夜夜久久| 97在线免费视频| 亚洲国产精品99久久| 中文字幕综合在线| 精品动漫一区二区| 日韩av网站大全| 日韩精品极品视频免费观看| 亚洲欧美综合v| 97人人模人人爽人人喊中文字| 国产精品视频播放| 美女福利精品视频| 亚洲精品综合精品自拍| 日韩美女在线观看一区| 精品少妇v888av| 538国产精品一区二区免费视频| 少妇高潮久久久久久潘金莲| 国产日韩欧美综合| 亚洲精品国产美女| 日韩成人中文字幕在线观看| 日韩欧美在线看| 亚洲欧美日韩图片| 亚洲精品国产拍免费91在线| 热久久这里只有精品| 欧美在线中文字幕| 日韩人体视频一二区| 中文字幕久精品免费视频| 久久777国产线看观看精品| 亚洲人成网站999久久久综合| 一区二区三区黄色| 成人免费看黄网站| 日韩视频免费中文字幕| 国产精品高清网站| 久久最新资源网| 久久不射热爱视频精品| 欧美日韩国产精品一区| 色老头一区二区三区| 亚洲国产精品久久久久| 亚洲成色www8888| 欧美丰满老妇厨房牲生活| 国产一区二区三区在线观看网站| 岛国精品视频在线播放| 久久九九国产精品怡红院| 欧美亚洲日本黄色| 日本精品免费一区二区三区| 午夜精品一区二区三区在线播放| 亚洲欧洲日产国码av系列天堂| 国产精品久久久av久久久| 亚洲二区在线播放视频| 国产成人在线视频| 国产精品久久综合av爱欲tv| 国产一区二区三区在线视频| 国产福利视频一区二区| 亚洲精品国产精品国自产观看浪潮| 亚洲人成网站在线播| 最近2019年好看中文字幕视频| 亚洲有声小说3d| 久久久91精品国产一区不卡| 欧美激情一区二区三区成人| 一色桃子一区二区| 伊人精品在线观看| 91精品视频一区| 亚洲性生活视频| 亚洲人成电影在线观看天堂色| 久久99国产精品久久久久久久久| 日本精品性网站在线观看| 国产精品第二页| 亚洲裸体xxxx| 国产成人在线一区| 日本久久久久亚洲中字幕| 亚洲欧美一区二区激情| 色爱精品视频一区| 91视频国产精品| 精品无人区太爽高潮在线播放| 欧美性猛交xxxx乱大交| 日韩av最新在线| 亚洲精品动漫久久久久| 日本精品在线视频| 永久免费毛片在线播放不卡| 国产精品一区二区三区成人| 国产精品福利在线观看网址| 精品国产依人香蕉在线精品| 久久亚洲精品毛片| 亲子乱一区二区三区电影| 亚洲欧美激情在线视频| 欧美中文字幕视频| 久久久免费高清电视剧观看| 亚洲欧美激情精品一区二区| 亚洲欧美日韩一区二区在线| 国产精品偷伦免费视频观看的| 亚洲欧美成人一区二区在线电影| 亚洲一区二区三区777| 国产成人精品日本亚洲专区61| 久久夜色精品国产亚洲aⅴ| 国精产品一区一区三区有限在线| 91精品国产综合久久香蕉的用户体验| 两个人的视频www国产精品| 亚洲bt欧美bt日本bt| 欧美超级免费视 在线| 国产午夜精品一区二区三区| 久久综合久中文字幕青草| 日韩av电影免费观看高清| 亚洲自拍中文字幕| 精品久久久久久中文字幕一区奶水| 国产欧美一区二区白浆黑人| 日本亚洲欧洲色| 日韩一区二区精品视频| 色综合天天综合网国产成人网| 亚洲第五色综合网| 97视频在线观看亚洲| 欧美国产日韩一区二区在线观看| 国产欧美一区二区白浆黑人| 亚洲欧美综合精品久久成人| 亚洲最新av网址| 91国内产香蕉| 97久久精品在线| 尤物yw午夜国产精品视频明星| 2025国产精品视频| 国产精品视频久久久久| 国产午夜精品免费一区二区三区| 亚洲偷欧美偷国内偷| 国产精自产拍久久久久久| 欧美香蕉大胸在线视频观看| 久久久精品在线观看| 亚洲精品久久久久久下一站| 国产精品91在线| 热久久这里只有精品| 国产精品狼人色视频一区| 国产精品嫩草视频| 国产在线视频一区| 亚洲国产欧美一区| 欧美有码在线视频| 日韩美女免费观看| 26uuu另类亚洲欧美日本老年| 91亚洲精品久久久久久久久久久久| 国产精品 欧美在线| 日韩免费在线电影| 久久中文字幕国产| www.久久久久久.com| 大伊人狠狠躁夜夜躁av一区| 亚洲综合成人婷婷小说| 国产精品91久久久久久| 久久久精品亚洲| 日本成人免费在线| 国内精品视频久久| 国产欧美一区二区| 国产午夜精品久久久| 全色精品综合影院|