iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >MVC3如何快速搭建Web应用
  • 178
分享到

MVC3如何快速搭建Web应用

2024-04-02 19:04:59 178人浏览 独家记忆
摘要

这篇文章给大家分享的是有关mvc3如何快速搭建WEB应用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Web应用不像winform应用,要想让用户得到更流畅更舒适的体验,方法之一

这篇文章给大家分享的是有关mvc3如何快速搭建WEB应用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

Web应用不像winform应用,要想让用户得到更流畅更舒适的体验,方法之一就是模拟winfORM的窗口操作,使用户在浏览器中也能像桌面一样舒服。在界面框架方面我们有大家最熟悉的Jquery ui,有Ext等等,经过一系列的筛选,我们最终决定使用easyui,文档教程例子都比较全面的一个js ui框架。首先我们来看看用到的js文件

<script src="@Url.Content("~/Scripts/jquery-1.7.2.min.js")" type="text/javascript"></script> jquery主文件  <script src="@Url.Content("~/Scripts/jquery.easyui.min.js")" type="text/javascript"></script> easy ui主文件  <script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script> 校验组件   <script src="@Url.Content("~/Scripts/jquery.form.js")" type="text/javascript"></script> 表单组件  <script src="@Url.Content("~/Scripts/easyui-lang-zh_CN.js")" type="text/javascript"></script> easyui的中文化  <script src="@Url.Content("~/Scripts/messages_cn.js")" type="text/javascript"></script> 校验组件的中文化

我们把它添加到mvc的Shared/_Layout.cshtml中。这样我们的项目所有Layout=null的视图都拥有了easyui支持。

在MVC3中,当你右键添加一个控制器时,向导会让你选择:

MVC3如何快速搭建Web应用

其中模版我们选择使用实体框架并生成相关actions与views,Model选择你实体框架中对应的表名(类名),DataContext选择上下文类

Views引擎选择Razor,高级选项里的两个勾都去掉,因为我们不需要引用内置的脚本库,也不需要选择layout(不选择layout,MVC默认该view使用Shared/_Layout.cshtml,也就是刚才我们添加js文件link的那个文件)。

确认上一篇中你下载的t4模版放进了它应该存在的地方(最好备份一下原始的),当你点击Add时,vs会自动在Controllers下面添加相应的控制器,在views文件夹下添加Create、Edit、Delete、Details、Index五个文件。下面我们一一查看他们的内容:

控制器中,action已经自动帮你添加完毕

private BsmisEntities db = new BsmisEntities();          //          // GET: /User/           public ViewResult Index()          {              return View();          }           //          // GET: /User/Create          public ActionResult Create()          {              return View();          }            //          // POST: /User/Create          [HttpPost]          public ActionResult Create(T_User t_user)          {              JSONResult result = new JsonResult();              result.Data = true;              try             {                   if (t_user.Enable == null)                      t_user.Enable = 0;                   db.T_User.AddObject(t_user);                   db.SaveChanges();              }              catch (Exception ee)              {                  result.Data = ee.Message;              }              return result;          }           //          // GET: /User/Edit/5          [OutputCache(Location = OutputCacheLocation.None)]          public ActionResult Edit(int id)          {              T_User t_user = db.T_User.Single(t => t.UserID == id);              ViewBag.DepartmentID = new SelectList(db.T_DepartmentInfo, "DepartmentID", "Code", t_user.DepartmentID);              return View(t_user);          }           //          // POST: /User/Edit/5           [HttpPost]          [OutputCache(Location = OutputCacheLocation.None)]          public ActionResult Edit(T_User t_user)          {              JsonResult result = new JsonResult();              result.Data = true;              try             {                  db.T_User.Attach(t_user);                  db.ObjectStateManager.ChangeObjectState(t_user, EntityState.Modified);                  db.SaveChanges();              }              catch (Exception ee)              {                  result.Data = ee.Message;              }              return result;           }           //          // POST: /User/Delete/5          [HttpPost, ActionName("Delete")]          public ActionResult DeleteConfirmed(int id)          {    JsonResult json=new JsonResult();  json.Data=true;  try {            T_User t_user = db.T_User.Single(t => t.UserID ==id);              db.T_User.DeleteObject(t_user);              db.SaveChanges();  }  catch(Exception ee)  {  json.Data=ee.Message;  }  return json;        }            /// <summary>          /// 数据显示、分页信息          /// </summary>          /// <param name="page"></param>          /// <param name="rows"></param>          /// <returns></returns>          public JsonResult List(int page, int rows)          {              var q = from u in db.T_User                      join d in db.T_DepartmentInfo on u.DepartmentID equals d.DepartmentID                      orderby u.UserID                      select new                         {                              UserID = u.UserID,                              UserName = u.UserName,                              Address = u.Address,                              Birth = u.Birth,                              DepartmentID = u.DepartmentID,                              DepartmentName = d.Name,                              Enable = u.Enable,                              Gendar = u.Gendar,                              IDCardNumber = u.IDCardNumber,                              LastAccessIP = u.LastAccessIP,                              LastAccessTime = u.LastAccessTime,                              LoGonTimes = u.LogonTimes,                              PassWord = u.Password,                              PostCode = u.PostCode,                              RealName = u.RealName,                              Tel = u.Tel,                              Province = u.Province,                              City = u.City,                              Area = u.Area                          };                var result = q.Skip((page - 1) * rows).Take(rows).ToList();              Dictionary<string, object> json = new Dictionary<string, object>();              json.Add("total", q.ToList().Count);              json.Add("rows", result);               return Json(json, JsonRequestBehavior.AllowGet);          }

这些action分别对应create、delete、edit、index视图(detail我们一般情况下不需要它,所以我的模版里没有写对应的生成代码)你可以比较一下它与原生的模版生成的代码之间的区别。后期我们还会在控制器里添加一些譬如检查名称是否重名之类的action

[OutputCache(Location = OutputCacheLocation.None)]          public JsonResult CheckRealNameExist(string RealName, int UserID)          {              JsonResult result = new JsonResult();              result.JsonRequestBehavior = JsonRequestBehavior.AllowGet;               result.Data = false;              try             {                  if (UserID == 0)                  {                      if (db.T_User.Any(p => p.RealName == RealName))                      {                          return result;                      }                   }                  else                 {                      if (db.T_User.Any(p => ((p.UserID != UserID) && (p.RealName == RealName))))                      {                          return result;                      }                  }              }              catch (Exception)              {                  return result;              }               result.Data = true;              return result;           }

返回值一般都是jsonresult。这样的话,当你在浏览器中访问http://localhost:1233/User/CheckRealNameExist?RealName=张三&UserID=0时 你会获得一个true或false值。是不是跟webservice有点异曲同工?

同样,在Views文件夹中生成了Create、Edit、Details、Delete、Index五个文件,其中Details与Delete我们不需要,因为我们想使用更友好的异步删除(用户单击delete后,页面不刷新,成功后浏览器下方滑出提示,3秒后关闭,失败滑出失败信息,不自动关闭 /利用easyui中的messager组件)。以下是Index中的js:

//删除          function del() {              var id = getselectedRow();              if (id != undefined) {                  $.messager.confirm('确认', '确定删除?', function (r) {                      if (r) {                          var url = 'User/Delete/' + id;                          $.post(url, function () {                           }).success(function () {                              $.messager.show({                                  title: '提示',                                  msg: '删除成功',                                  timeout: 3000,                                  showType: 'slide'                             });                              $('#dg').datagrid('reload');                          })                              .error(function () {                                  $.messager.alert('错误', '删除发生错误');                              });                       }                  });              }          }

我们把Details与Delete删除后只剩下Index、Create、Edit三个文件,这三个文件之间的关系是,Index中包含添加、编辑按钮,点击后使用js将对应的actionresult加载到div中,以实现弹窗新建,编辑的效果。

//新建          function c_dlg() {              var url = 'User/Create';              $('#c_dlg').show();              $('#c_dlg').load(url, function () {                  $(this).dialog({                      title: '添加',                      buttons: [{                          text: '提交',                          iconCls: 'icon-ok',                          handler: function () {                              $('#c_form').submit();                          }                      }, {                          text: '取消',                          handler: function () {                              $('#c_dlg').dialog('close');                          }                      }]                  });              });          }           //编辑框          function e_dlg() {              var id = getselectedRow();              if (id != undefined) {                  var url = 'User/Edit/' + id;                  $('#e_dlg').show();                  $('#e_dlg').load(url, function () {                      $(this).dialog({                          title: '编辑',                          buttons: [{                              text: '提交',                              iconCls: 'icon-ok',                              handler: function () {                                  $('#e_form').submit();                              }                          }, {                              text: '取消',                              handler: function () {                                  $('#e_dlg').dialog('close');                              }                          }]                      });                  });              }          }

这里面的c_dlg与e_dlg是index页面的两个Div节点:

<div id="c_dlg" style="width:400px;height:520px;display: none"></div> <div id="e_dlg" style="width:400px;height:520px;display: none"></div>

以上的代码完成将控制器中的action返回的页面内容动态加载到div中,并以弹窗的特效显示在当前(Index)页面中。效果如图:

MVC3如何快速搭建Web应用

我们来看看Create\Edit视图的内容,首先是js

<script type="text/javascript">      $(function () {          $('#c_Department').combotree({              url: '@Url.Action("GetComboTreeJson","Department")'         });          $('#c_City').combobox();          $('#c_Area').combobox();                    $('#c_Province').combobox({ url:'CityDic/List/ID/0',              onSelect: function (record) {                  $('#c_City').combobox('reload', 'CityDic/List/ID/' + record.ID).combobox('clear');                  $('#c_Area').combobox('clear');              }          });           $('#c_City').combobox({              onSelect: function (record) {                  $('#c_Area').combobox('reload', 'CityDic/List/ID/' + record.ID).combobox('clear');              }          });                    $('#c_Birth').datebox().datebox('setValue', '@now');                    $("#c_form").validate({              rules: {                  UserName: {                      required: true,                      remote:                          {                              url: 'User/CheckNameExist',                              type: "get",                              dataType: "json",                              data: {                                  Name: function () { return $('#c_UserName').val(); },                                  UserID: function () { return 0; }                              }                          }                  },                  RealName: {                      required:true,                      remote: {                          url: 'User/CheckRealNameExist',                          type: "get",                          dataType: "json",                          data: {                              RealName: function () { return $('#c_RealName').val(); },                              UserID: function () { return 0; }                          }                      }                  }              },              messages: {                  UserName: {                      remote: '名称重复'                 },                   RealName: { remote: '名称重复' }              },              submitHandler: function (form) {                  ajaxAdd();              }          });      });  </script>

这部分js将本页面的控件初始化为对应的下拉框或日期选取框等等,Html为

@using (Html.BeginForm("Create", "User", FormMethod.Post, new { id = "c_form" }))  {   <fieldset>         <table class="editForm">             <tr>                 <td>                     @Html.LabelFor(model => model.UserName, "用户名:")                  </td>                 <td>                                          <input id="c_UserName" name="UserName" style="width: 160px;" required="true" /><span style="color: red">                         *</span>                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.DepartmentID, "组织机构:")                  </td>                 <td>                     <input id="c_Department" name="DepartmentID" style="width: 160px;" required="true" /><span style="color: red">                         *</span>                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Password, "密码:")                  </td>                 <td>                     @Html.PasswordFor(model => model.Password, new { @class = "{required:true,minlength:5}" })<span style="color: red">                         *</span>                 </td>             </tr>             <tr>                 <td>                     <label for="confirm_password">                         确认密码</label>                 </td>                 <td>                     <input id="confirm_password" name="confirm_password" type="password" class="{required:true,minlength:5,equalTo:'#Password'}" /><span style="color: red">                         *</span>                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.RealName, "真实姓名:")                  </td>                 <td>                     @Html.TextBoxFor(model => model.RealName, new { @id="c_RealName",@class = "{required:true}" })<span style="color: red">                         *</span>                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Gendar, "性别:")                  </td>                 <td>                     @Html.RadioButtonFor(model => model.Gendar, "男", new { @id = "radio1", @name = "Gendar", @checked = "checked" })                      <label for="radio1">                         男</label>                     @Html.RadioButtonFor(model => model.Gendar, "女", new { @id = "radio2", @name = "Gendar" })                      <label for="radio2">                         女</label>                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Birth, "出生日期:")                  </td>                 <td>                     <input id="c_Birth" required="true" name="Birth" />                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.IDCardNumber, "身份证号码:")                  </td>                 <td>                     @Html.EditorFor(model => model.IDCardNumber)                  </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Province, "省份:")                  </td>                 <td>                     <input name="Province" valuefield="Name" textfield="Name" panelheight="auto" id="c_Province" style="width: 150px">                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.City, "市:")                  </td>                 <td>                     <input name="City" valuefield="Name" textfield="Name" panelheight="auto" id="c_City" style="width:150px">                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Area, "区/县:")                  </td>                 <td>                     <input name="Area" valuefield="Name" textfield="Name" panelheight="auto" id="c_Area" style="width: 150px">                 </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.PostCode, "邮政编码:")                  </td>                 <td>                     @Html.EditorFor(model => model.PostCode)                  </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Address, "地址:")                  </td>                 <td>                     @Html.EditorFor(model => model.Address)                  </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Tel, "电话:")                  </td>                 <td>                     @Html.EditorFor(model => model.Tel)                  </td>             </tr>             <tr>                 <td>                     @Html.LabelFor(model => model.Enable, "启用:")                  </td>                 <td>                     @Html.CheckBoxForBool(model=>model.Enable,true,true)                  </td>             </tr>         </table>     </fieldset> }

编辑视图中也类似如此。当单击保存按钮后,执行

$('#c_form').submit();

这里我们的客户端校验在这里:

$("#c_form").validate({              rules: {                  UserName: {                      required: true,                      remote:                          {                              url: 'User/CheckNameExist',                              type: "get",                              dataType: "json",                              data: {                                  Name: function () { return $('#c_UserName').val(); },                                  UserID: function () { return 0; }                              }                          }                  },                  RealName: {                      required:true,                      remote: {                          url: 'User/CheckRealNameExist',                          type: "get",                          dataType: "json",                          data: {                              RealName: function () { return $('#c_RealName').val(); },                              UserID: function () { return 0; }                          }                      }                  }              },              messages: {                  UserName: {                      remote: '名称重复'                 },                   RealName: { remote: '名称重复' }              },              submitHandler: function (form) {                  ajaxAdd();              }          });

submitHandler方法提供校验前要做的事情:ajaxAdd()

//异步新建提交          function ajaxAdd() {              $('#c_form').ajaxSubmit({                  url: 'User/Create',                  beforeSubmit: function () {                      if ($('#c_form').form('validate') != true) {                          return false;                      }                      if ($("#c_form").valid() != true) {                          return false;                      }                      return true;                  },                  success: function (data) {                      if (data == true) {                          $('#c_dlg').dialog('close');                          $('#dg').datagrid('reload');                          $.messager.show({                              title: '提示',                              msg: '保存成功',                              timeout: 2000,                              showType: 'slide'                         });                      } else {                          $.messager.show({                              title: '提示',                              msg: '保存失败:' + data,                              timeout: 2000,                              showType: 'slide'                         });                      }                  }              });               return false;          }

异步提交成功后获取data,如果是true说明成功了,关闭“对话框”,刷新表格,弹出提示。失败的话将data弹出(一般是失败原因,由controller中的action返回)。下面是Index中的表格:

<table id="dg" class="easyui-datagrid"              toolbar="#toolbar"               rownumbers="true" fitColumns="true" singleSelect="true" pagination="true" fit="true">         <thead>                  <tr>                 <th field="DepartmentName" width="80">                     部门                  </th>                 <th field="UserName" width="100">                     用户名                  </th>                 <th field="RealName" width="100">                     真实姓名                  </th>                 <th field="Gendar" width="30">                     性别                  </th>                 <th field="Birth" width="70" formatter="formatDate">                     生日                  </th>                 <th field="Tel" width="50">                     电话                  </th>                 <th field="LogonTimes" width="50">                     登陆次数                  </th>                 <th field="LastAccessIP" width="120">                     最后访问IP                  </th>                 <th field="LastAccessTime" width="50">                     最后访问时间                  </th>                 <th field="Enable" width="50" formatter="formatBool">                     状态                  </th>             </tr>         </thead>     </table>     <div id="toolbar">         @if (userid != 0 && AuthMgr.HasAuth(userid, "add", 5))          {              <a href="#" class="easyui-linkbutton" iconCls="icon-add" plain="true" onclick="c_dlg();">添加</a>            }          @if (userid != 0 && AuthMgr.HasAuth(userid, "edit", 5))          {              <a href="#" class="easyui-linkbutton" iconCls="icon-edit" plain="true" onclick="e_dlg()" >编辑</a>         }      </div>

其中@if是用来判断权限,如果当前登陆用户拥有add权限,那么就显示“添加“按钮。

感谢各位的阅读!关于“MVC3如何快速搭建Web应用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: MVC3如何快速搭建Web应用

本文链接: https://www.lsjlt.com/news/86281.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MVC3如何快速搭建Web应用
    这篇文章给大家分享的是有关MVC3如何快速搭建Web应用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Web应用不像winform应用,要想让用户得到更流畅更舒适的体验,方法之一...
    99+
    2024-04-02
  • SpringBoot如何快速搭建
    这篇文章主要介绍SpringBoot如何快速搭建,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Spring Boot 概述Build Anything with Spring Boot:Spring Boot is ...
    99+
    2023-06-02
  • 如何快速搭建并使用ThinkPHP5
    这篇文章主要介绍“如何快速搭建并使用ThinkPHP5”,在日常操作中,相信很多人在如何快速搭建并使用ThinkPHP5问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何快速搭建并使用ThinkPHP5”的疑...
    99+
    2023-06-25
  • 如何使用Kubeadm快速搭建Kubernetes
    这篇文章主要讲解了“如何使用Kubeadm快速搭建Kubernetes”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用Kubeadm快速搭建Kubernetes”吧!##版本说明 ##...
    99+
    2023-06-19
  • 如何快速搭建Firekylin博客
    小编给大家分享一下如何快速搭建Firekylin博客,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1).安装 Node.jscurl --silent&...
    99+
    2023-06-27
  • 如何使用node快速搭建后台
    这篇文章主要介绍了如何使用node快速搭建后台,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。首先安装node,express,express-generator (4.x版本...
    99+
    2023-06-22
  • 如何使用dede快速搭建网站
    使用dede快速搭建网站的方法:安装xampp虚拟环境。打开xampp,运行Apache和MySQL。下载dedeCMS,进行解压。解压后将uploads中所有文件复制到XAMPP/htdocs文件中。打开浏览器,访问“localhost”...
    99+
    2024-04-02
  • 如何快速搭建spring boot2.0项目
    这篇文章主要讲解了“如何快速搭建spring boot2.0项目”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何快速搭建spring boot2.0项目”...
    99+
    2024-04-02
  • 如何快速搭建SVO-SLAM环境
    这篇文章主要介绍“如何快速搭建SVO-SLAM环境”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何快速搭建SVO-SLAM环境”文章能帮助大家解决问题。首先,建立一个工作目录比如:workspac...
    99+
    2023-06-27
  • 如何快速使用mysqlreplicate搭建MySQL主从
    简介 mysql-utilities工具集是一个集中了多种工具的合集,可以理解为是DBA的工具箱,本文介绍利用其中的mysqlreplicate工具来快速搭建MySQL主从环境。 HE1:192.168.1...
    99+
    2024-04-02
  • 个人如何快速搭建网站
    个人快速搭建网站方法:1.注册建站系统。2.安装样板网站。3.在样板网站上,修改网站logo,导航栏目名称,产品图片、文章等。4.在后台设置处,设置网站名称、联系人等。5.根据需求添加动画效果、优化细节。个人快速搭建网站的方法:登录建站提供...
    99+
    2024-04-02
  • 如何快速地搭建GitLab环境
    作为一种web-based代码托管平台,GitLab已经成为了不少公司和团队的不二之选。通过GitLab,我们可以方便地管理和维护代码,以实现更加高效和协同的开发。但是,对于一些没有使用过GitLab的用户来说,可能在安装和配置方面遇到些问...
    99+
    2023-10-22
  • Python web实战 | 用 Flask 框架快速构建 Web 应用【实战】
     概要 Python web 开发已经有了相当长的历史,从最早的 CGI 脚本到现在的全栈 Web 框架,现在已经成为了一种非常流行的方式。 Python 最早被用于 Web 开发是在 1995 年(90年代早期),当时使用 CGI ...
    99+
    2023-09-22
    python 前端 flask webkit
  • 索引、HTTP和NPM:如何用PHP构建快速、高效的Web应用?
    PHP是一种流行的编程语言,广泛用于Web开发。它具有简单易学、开发速度快、可扩展性强等特点,使得它成为了Web开发人员的首选语言之一。本文将介绍如何利用PHP构建快速、高效的Web应用,主要从索引、HTTP和NPM三个方面进行阐述。 一...
    99+
    2023-08-07
    索引 http npm
  • 如何使用golang搭建web应用程序
    近年来,Go语言(简称golang)因其高效、简洁、并发安全等特点,逐渐成为了Web开发领域的宠儿。Golang易于学习和使用,并且拥有庞大的基础库和框架。本文将介绍如何使用golang搭建web应用程序,包括路由设置、模板处理、ORM等内...
    99+
    2023-05-14
  • 如何快速搭建一个springboot项目
    本篇内容主要讲解“如何快速搭建一个springboot项目”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何快速搭建一个springboot项目”吧!一、空项目现在开发过程中大都是idea这个集...
    99+
    2023-06-30
  • 如何利用Python和NPM快速构建可扩展的Web应用程序?
    Web应用程序是如今互联网世界中的重要组成部分。而Python和NPM分别是构建Web应用程序的两个最流行的工具。Python是一种高级编程语言,非常适合构建Web应用程序,而NPM则是JavaScript包管理器,可以帮助您管理Web应...
    99+
    2023-08-08
    apache npm javascript
  • PHP打包Shell框架:如何快速创建高效的Web应用程序?
    在Web应用程序开发中,选择一个高效的框架是至关重要的。PHP打包Shell框架是一个值得考虑的选择。它是一个轻量级的框架,允许快速创建高效的Web应用程序。在本文中,我们将探讨如何使用PHP打包Shell框架来创建一个简单的Web应用程...
    99+
    2023-08-14
    打包 shell 框架
  • 如何用VS code快速搭建一个Golang项目
    本篇内容主要讲解“如何用VS code快速搭建一个Golang项目”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何用VS code快速搭建一个Golang项目”吧!安装go...
    99+
    2023-07-06
  • 如何使用Bash脚本快速搭建Docker容器?
    Docker 是一种开源的虚拟化技术,它可以帮助我们快速创建、部署和运行应用程序。而 Bash 脚本是一种命令行脚本语言,它可以帮助我们自动化执行一些任务。在本文中,我们将介绍如何使用 Bash 脚本快速搭建 Docker 容器。 安装...
    99+
    2023-08-14
    并发 bash 容器
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作