適合小白的Demo_easyui+core3第五章用戶數據操作

来源:https://www.cnblogs.com/sunyong8860/archive/2020/05/25/12960654.html
-Advertisement-
Play Games

1、用戶列表頁面 @{ Layout = Layout = null;}<table id="datalistuser" class="easyui-datagrid" url="/userlist/getuserlist" toolbar="#toolbaruser" rownumbers="tr ...


1、用戶列表頁面

@{
Layout = Layout = null;
}
<table id="datalistuser" class="easyui-datagrid"
    url="/userlist/getuserlist"
    toolbar="#toolbaruser"
    rownumbers="true" fitColumns="true" singleSelect="true">
  <thead>
    <tr>
      <th data-options="field:'id',width:'150'" hidden>主鍵</th>
      <th data-options="field:'username'" width="150">登錄名</th>
      <th data-options="field:'nickname'" width="150">昵稱</th>
      <th data-options="field:'phone'" width="150">手機號</th>
      <th data-options="field:'wchart'" width="150">微信號</th>
      <th data-options="field:'email'" width="150">郵箱</th>
      <th data-options="field:'createuser'" width="150">創建人</th>
      <th data-options="field:'createtime'" width="180">創建時間</th>
      <th data-options="field:'state',formatter: function (value, row, index) {
        if(value='Y'){return '可用'}
        else{return '禁用'}
        }" width="100">狀態</th>
    </tr>
  </thead>
</table>
<div id="toolbaruser">
  <a href="#" class="easyui-linkbutton" iconCls="icon-add" plain="true" onclick="adduser()">添加</a>
  <a href="#" class="easyui-linkbutton" iconCls="icon-edit" plain="true" onclick="editUser()">編輯</a>
  <a href="#" class="easyui-linkbutton" iconCls="icon-remove" plain="true" onclick="removeuser()">刪除</a>
  <a href="#" class="easyui-linkbutton" iconCls="icon-arrow_down" plain="true" onclick="onloaduser()">下載</a>
  <a href="#" class="easyui-linkbutton" iconCls="icon-email_go" plain="true" onclick="emailuser()">郵件發送</a>
</div>
@*-----------------------------------------------編輯-------------------------------------------------------------------------------*@
<div id="dlguser" class="easyui-dialog" style="width:400px" data-options="closed:true,modal:true,border:'thin',buttons:'#dlguser-buttons'">
  <form id="fmuser" method="post" novalidate style="margin:0;padding:20px 50px">
    <h3>用戶信息</h3>
    <div style="margin-bottom:10px">
      <input name="id" hidden>
    </div>
    <div style="margin-bottom:10px">
      <input name="username" class="easyui-textbox" required label="登錄名:" style="width:100%">
    </div>
    <div style="margin-bottom:10px">
      <input name="nickname" class="easyui-textbox" label="昵稱:" style="width:100%">
    </div>
    <div style="margin-bottom:10px">
       <input name="phone" class="easyui-textbox" label="手機號:" style="width:100%">
    </div>
    <div style="margin-bottom:10px">
      <input name="wchart" class="easyui-textbox" label="微信:" style="width:100%">
    </div>
    <div style="margin-bottom:10px">
      <input name="email" class="easyui-textbox" label="郵箱:" style="width:100%">
    </div>
  </form>
</div>
<div id="dlguser-buttons">
  <a href="javascript:void(0)" class="easyui-linkbutton c6" iconCls="icon-print" onclick="printuser()" style="width:90px">列印</a>
  <a href="javascript:void(0)" class="easyui-linkbutton c6" iconCls="icon-ok" onclick="saveuser()" style="width:90px">保存</a>
  <a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-cancel" onclick="javascript:$('#dlguser').dialog('close')" style="width:90px">Cancel</a>
</div>
@*-----------------------------------------------編輯-------------------------------------------------------------------------------*@
<script>
function adduser() {
  $('#dlguser').dialog('open').dialog('center').dialog('setTitle', 'New User');
  $('#fmuser').form('clear');
}
function editUser() {
  var row = $('#datalistuser').datagrid('getSelected');
  if (row) {
    $('#dlguser').dialog('open').dialog('center').dialog('setTitle', 'Edit User');
    $('#fmuser').form('load', row);
    url = '/userlist/edituse?id=' + row.id;
  }
}
function saveuser() {
  $('#fmuser').form('submit', {
    url: '/userlist/saveuser',
    onSubmit: function () {
    return $(this).form('validate');
  },
  success: function (result) {
    if (result == "OK") {
      $('#dlguser').dialog('close');
      $('#datalistuser').datagrid('reload');
    $.messager.show({
      title: 'Success',
      msg: "添加成功"
    });
    }
    else {
      $.messager.show({
        title: 'Error',
        msg: "添加失敗"
      });
    }
  }
});
}
function removeuser() {
  var row = $('#datalistuser').datagrid('getSelected');
  if (row) {
      $.messager.confirm('刪除', '確定要刪除這條數據?', function (r) {
      if (r) {
        $.post('/userlist/removeuser', { id: row.id }, function (result) {
          if (result.success) {
            $('#datalistuser').datagrid('reload');
              $.messager.show({
              title: 'Success',
              msg: "刪除成功"
            });
          } else {
            $.messager.show({
              title: 'Error',
              msg: "添加失敗"
            });
          }
        }, 'json');
      }
    });
  }
}
function emailuser() {
  var row = $('#datalistuser').datagrid('getSelected');
  if (row) {
    $.messager.confirm('郵件', '確定要發郵件?', function (r) {
    if (r) {
      $.post('/userlist/emailuser', { id: row.id }, function (result) {
        if (result == "OK") {
          $('#datalistuser').datagrid('reload');
          $.messager.show({
            title: 'Success',
            msg: "發送成功"
          });
        } else {
          $.messager.show({
            title: 'Error',
            msg: "發送失敗"
          });
        }
    }, 'json');
   }
  });
}
}
function printuser() {
  $('#dlguser').printThis();
}
function onloaduser() {
  var myDate = new Date();
  var rows = getdownloaduser("/userlist/downloaduser");
  $('#datalistuser').datagrid('toExcel', { filename: '用戶信息-' + myDate.getFullYear() + myDate.getMonth() + myDate.getDate() + '.xls', rows: rows })
}
function getdownloaduser(url) {
  $.ajax({
    url: url,
    type: "post",
    dataType: "json",
    async: false,
    cache: false,
    success: function (data) {
    rows = data.rows;
  },
  error: function () {
    layer.msg("數據查詢錯誤!");
    return;
  }
});
  return rows;
}
</script>

2、後臺對應的操作

#region operation 增刪改查
public JsonResult getuserlist() {
  List<user> us = new List<user>();
  us = db.hr_user.Where(x => x.State == "Y").OrderByDescending(x => x.Createtime).ToList();
  return Json(us);
}
public JsonResult edituse(int id) {
  user u = db.hr_user.Find(id);
  return Json(u);
}
public ContentResult saveuser(user u) {
  user user = new user();
  var result = "NO";
  try {
    if ( u.Id != 0 ) {
      user = db.hr_user.Find(u.Id);
      user.Updatetime = DateTime.Now;
      user.Updateuser = CurrentUsers.UserId;
      db.Update(user);
      result = "OK";
    }
    else {
      user.Password = "88888888";
      user.Createtime = DateTime.Now;
      user.Createuser = CurrentUsers.UserId;
      db.Add(user);
      result = db.hr_user.Where(x => x.Username == u.Username).Count() == 0 ? "OK" : "NO";
    }
    if ( result == "OK" ) {
      user.Nickname = u.Nickname;
      user.Phone = u.Phone;
      user.State = "Y";
      user.Username = u.Username;
      user.Wchart = u.Wchart;
      user.Email = u.Email;
      db.SaveChanges();
      return Content(result);
    }
    else {
      return Content(result);
    }
  }
  catch ( Exception ex ) {
    return Content(result);
  }

}
public ContentResult removeuser(int id) {
  try {
    var u = db.hr_user.Find(id);
    u.State = "N";
    u.Updateuser = CurrentUsers.UserId;
    u.Updatetime = DateTime.Now;
    db.Update(u);
    db.SaveChanges();
    return Content("OK");
  }
  catch ( Exception ex ) {
      return Content("NO");
  }
}
#endregion

3、郵件發送和下載處理

//郵件
public ContentResult emailuser(int id) {
  try {
    var u = db.hr_user.Find(id);
    _sendMail.acceptmail = u.Email;
    send_email.get_send_email(_sendMail, "郵件", "請登錄您賬戶");
    u.Updateuser = CurrentUsers.UserId;
    u.Updatetime = DateTime.Now;
    db.Update(u);
    db.SaveChanges();
    return Content("OK");
  }
  catch ( Exception ex ) {
    return Content("NO");
  }
}
//下載
public ActionResult downloaduser() {
  List<user> users = db.hr_user.Where(x => x.State == "Y").ToList();
  return Json(users);
}

效果如下圖

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在講工廠模式的時候,我將講一個早餐店創業故事來慢慢的引入簡單工廠模式,工廠方法模式和抽象工廠模式以及他們各自的區別。 創業初期,由於資金不足,最開始早餐店就賣一種商品包子,包子的種類有3種,肉包,菜包,和糖包,現在我們不用工廠模式來實現下這個代碼: 包子介面: public interface St ...
  • 我們都知道面向對象編程有三大特征:封裝,集成和多態,那我們如何在實際開發中去靈活運用它呢,今天我給大家聊一聊簡單工廠設計模式。簡單工廠設計模式的一個核心思想就是高內聚,低耦合,使具體的業務邏輯實現功能和效果展示分離開來。 先給大家舉一個沒有應用到工廠設計模式的例子: 題目:要求設計一個計算器程式,輸 ...
  • SunnyUI.Net, 基於 C# .Net WinForm 開源控制項庫、工具類庫、擴展類庫、多頁面開發框架 Blog: https://www.cnblogs.com/yhuse Gitee: https://gitee.com/yhuse/SunnyUI GitHub: https://git ...
  • #nginx功能 反向代理,負載均衡,緩存靜態資源,如圖片、CSS、JS #正向代理和反向代理 ##正向代理 代理客戶端,代客戶端發出請求,客戶端知道要訪問的真實地址,如vpn ##反向代理 代理服務端,代服務端接收請求,客戶端不知道要訪問的真實地址 #win10 docker部署nginx對dot ...
  • SunnyUI控制項庫安裝,其實也是常規的Winform控制項庫安裝方法。 ...
  • Entity Framework Core配置DbContext的兩種方式 ​ 使用Entity Framework 遷移過程 中遇到過一個問題,在這裡拿出來曬曬。 Unable to create an object of type 'xxxContext'. For the different ...
  • 序言:博客是為了別人寫?還是自己寫。在我看來,博客可以幫助我記錄自己的知識的歡愉,以別人的角度去審視自己的想法,博客幫助我記錄自己的成長,也等待著一位位有緣人。好了,不多說了,進入正題。回去做了做coderbeginner166的題,看到了一串非常有感覺的代碼,還是一樣的簡潔明瞭。此處,原題鏈接ht... ...
  • 1、引用包 Microsoft.EntityFrameworkCore.Tools Microsoft.EntityFrameworkCore.SqlServer Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation Microsoft.AspNetCo ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...