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

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

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);
}

效果如下圖

 


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

更多相關文章
  • 在講工廠模式的時候,我將講一個早餐店創業故事來慢慢的引入簡單工廠模式,工廠方法模式和抽象工廠模式以及他們各自的區別。 創業初期,由於資金不足,最開始早餐店就賣一種商品包子,包子的種類有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 ...
一周排行
  • 本次課程就正式進入開發部分。 首先我們先搭建項目框架,還是和之前漸進式風格保持一致,除必備組件外,儘量使用原生功能以方便大家理解。 開發工具:vs 2019 或以上 資料庫:SQL SERVER 2017 或以上 其他需要用到的我們在項目過程中再提。 一、新建 MVC項目 1、打開VS 2019,C ...
  • 一.背景說明: 之前分享過一個微服務開發框架, “享一個集成.NET Core+Swagger+Consul+Polly+Ocelot+IdentityServer4+Exceptionless+Apollo+SkyWalking的微服務開發框架”,前兩天在Github上收到一個Issues,是想我 ...
  • 前言 Http我們都已經耳熟能詳了,而關於Http學習的文章網上有很多,各個知識點的講解也可說是深入淺出。然而,學習過後,我們對Http還是一知半解。問題出在了哪? Http是一個客戶機與伺服器之間的通信的協議,真的想學習Http,就必須把客戶機和伺服器也學了,也就是說,必須立體的學習,不然我們永遠 ...
  • 本人製作的這個 “簡易日誌 (SimpleLogger)” 包裡面包含的代碼邏輯,最開始也就是簡單地寫入文本,後來經過實際使用的演化,做了各種優化,添加了一些實用的特性,感覺用著還不錯。正所謂獨樂樂不如眾樂樂,於是將其打包上傳到微軟的包管理庫 NuGet 中,大家可以使用試試,相互交流。 ...
  • 1.需求示意圖 2.需求描述 原本是為了給做unity3d客戶端開發的同事提供不定時的消息推送,比如商城購買道具後服務端將道具信息推送給客戶端。 本篇文章簡化理解,用“相關部門開展活動,向全市人民徵集社會服務改善意見”為例子。但核心想法一致:單向推送(指這個需求上只需要單向)。所以這個功能並不是聊天 ...
  • 找到項目中ServiceStack.Text.dll文件的版本,比如我的版本是5.0.0,到GitHub上下載對應的源碼(https://github.com/ServiceStack/ServiceStack.Text/tags) 打開解決方案,重新生成ServiceStack.Text項目,如果 ...
  • 前言 上一篇文章主要介紹了IL的概念以及基礎的示例代碼,在這一篇文章中我們將通過對象調用看IL。 創建對象與調用方法 class Program { static void Main(string[] args) { var obj = new MyClass(); Console.WriteLin ...
  • abp版本5.9 概述 數據遷移無非就是兩件事情,1、創建資料庫,並根據實體創建對應的表;2、添加一些初始數據 abp的數據遷移也是完成這兩件事,比較特殊的是它是多租戶saas系統,而且支持不同的租戶有獨立的資料庫。所以abp中的遷移要先遷移戶主Host,再遷移租戶Tenant的資料庫 它的遷移定義 ...
  • 本文屬於OData系列 目錄 武裝你的WEBAPI-OData入門 武裝你的WEBAPI-OData便捷查詢 武裝你的WEBAPI-OData分頁查詢 武裝你的WEBAPI-OData資源更新Delta 武裝你的WEBAPI-OData之EDM 武裝你的WEBAPI-OData常見問題 武裝你的WE ...
  • 前言 面試總是會被問到有沒有用過分散式鎖、redis 鎖,大部分讀者平時很少接觸到,所以只能很無奈的回答 “沒有”。本文通過 Spring Boot 整合 redisson 來實現分散式鎖,並結合 demo 測試結果。 首先看下大佬總結的圖 正文 添加依賴 <!--redis--> <depende ...