广告
返回顶部
首页 > 资讯 > 精选 >如何进行ASP.NET Web开发框架中的查询
  • 629
分享到

如何进行ASP.NET Web开发框架中的查询

2023-06-17 09:06:18 629人浏览 安东尼
摘要

本篇文章为大家展示了如何进行asp.net web开发框架中的查询,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Enterprise Solution 支持用户自定义查询(query and loo

本篇文章为大家展示了如何进行asp.net web开发框架中的查询,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

Enterprise Solution 支持用户自定义查询(query and lookup),并把查询query定义为一个标准功能,查找lookup用于返回查询的值给数据输入窗体。

先配置数据库连接字符串,使用公司注册来注册一个新的数据库连接。再到查询设计器中,选取相应的对象,设计关联,WEB框架可以解析此查询,变成一个页面功能。

在客户页面中,添加TriggerBox,它的后面会显示一个小图标,以查于查找数据

 <ext:TriggerBox ID="tbxCustomerNo" ShowLabel="true" Readonly="false" TriggerIcon="Search"                             OnTriggerClick="tbxCustomerNo_TriggerClick" OnTextChanged="tbxCustomerNo_TextChanged"                             AutoPostBack="true" Label="Customer No." runat="server" Lookup="CustomerEntryLookup"                             DataBindingString="CustomerEntity:CustomerNo">  </ext:TriggerBox>

再来看后台代码的处理模式

string lookup = tbxCustomerNo.Lookup;               tbxCustomerNo.OnClientTriggerClick = Window1.GetSaveStateReference(tbxCustomerNo.ClientID, HiddenField1.ClientID, HiddenField2.ClientID)                 + Window1.GetShowReference(string.FORMat("lookup.aspx?id={0}", lookup), "Look-up:Customer");

从上面的Web页面中,我们已经指定了Lookup属性为CustomerEntryLookup。这一句是把Lookup与页面的Window1关联,以用于弹出窗口,同时指定了页面的HiddenField1为接受Lookup的返回值,***调用窗口的回发刷新过程,进行页面刷新,代码如下

protected void Window1_Close(object sender, EventArgs e)  {              string customerNo = tbxCustomerNo.Text;              if (!string.IsNullOrWhiteSpace(customerNo))              {                  ReloadEntity(customerNo);                          }  }

这样就完成了查询页面的弹出选择值,返回值给主窗体,***刷新主窗体。

再来看看lookup.aspx页面是如何设计的,它接受一个查询id为参数,这个参数,也就是我们指定的CustomerEntryLookup,在查询设计器中,它是这样被设计的

如何进行ASP.NET Web开发框架中的查询

lookup.aspx页面接受传入的参数,它的初试化页面是这样设计的

protected void Page_Init(object sender, EventArgs e)  {              LookupName = Request.QueryString["id"];                         ILookupDialogManager _lookupDialogManager = ClientProxyFactory.CreateProxyInstance<ILookupDialogManager>();              string companycode = "TS";              DataTable table = _lookupDialogManager.GetLookupDialogData(LookupName, null, null, 0, 0, companycode);              Grid1.RecordCount = table.Rows.Count;                 BindGrid();               }

根据查询,得到记录总数,进行分页查询,这里的代码是Grid的分页代码,来看看BindGrid方法的定义,并不复杂。

private void BindGrid()  {              DataSet ds = LoadData(Grid1.PageIndex+1);               while (Grid1.Columns.Count > 0)                  Grid1.Columns.RemoveAt(0);               foreach (DataColumn colu in ds.Tables[0].Columns)              {                  ExtAspNet.BoundField field = new ExtAspNet.BoundField();                  field.ColumnID = colu.ColumnName;                  field.DataField = colu.ColumnName;                  field.HeaderText = GetTranslation(colu.ColumnName);                  Grid1.Columns.Add(field);              }               Grid1.PageSize = PageSize;                          Grid1.DataSource = ds.Tables[0];              Grid1.DataBind();   }

它先删除grid中原有的列,然后根据结果产生新的列,并对列名应用多语言翻译。这里要注意动态控件的创建时机,要选择在Page_Init中,而不是Page_Load中。在Debug时,看到的分页代码是数据库分页,每次只返回设定的行数。

Grid的分页事件样例代码如下所示,与GridView完全一样

protected void Grid1_PageIndexChange(object sender, ExtAspNet.GridPageEventArgs e)  {           Grid1.PageIndex = e.NewPageIndex;           BindGrid();  }

下面来看看lookup.aspx页面的二个按钮方法的代码。最简单的是Close,直接关闭窗体,不返回任何值给主窗体,它的代码最容易,如下所示

btnClose.OnClientClick = ActiveWindow.GetHideReference();

复杂一点的,关闭后带值到主窗体中,代码如下所示

protected void btnSaveClose_Click(object sender, EventArgs e)  {              int rowIndex = Grid1.SelectedRowIndex;              GridRow row = Grid1.Rows[rowIndex];               ILookupDialogManager lookupManager=ClientProxyFactory.CreateProxyInstance<ILookupDialogManager>();              LookupDialogEntity lookup = lookupManager.GetLookupDialog(LookupName);              List<string> keyFields = new List<string>();                      keyFields.Add(lookup.KeyField1);              keyFields.Add(lookup.KeyField2);              keyFields.Add(lookup.KeyField3);               List<string> values = new List<string>();              foreach (string keyField in keyFields)              {                  string value = string.Empty;                  if (!string.IsNullOrWhiteSpace(keyField))                  {                      ExtAspNet.BoundField field = (ExtAspNet.BoundField)Grid1.FindColumn(keyField);                      string f1 = field.DataField;                      object f2 = Grid1.Rows[rowIndex].States[field.ColumnIndex];                      value = Convert.ToString(((DataRowView)(Grid1.Rows[rowIndex].Dataitem))[keyField]);                                }                  values.Add(value);              }              PageContext.ReGISterStartupScript(ActiveWindow.GetWriteBackValueReference(values[0], values[1], values[2]) + ActiveWindow.GetHidePostBackReference());   }

这部分代码,有两个意图,取Grid中的值,然后返回给主窗体,因为要刷新主窗体,所以***加一项GetHidePostBackReference(),让主窗体回发,以调用在文章开头设计的Window1_Close,ReloadEntity完成对实体的重新绑定。

查询query与查找lookup的实现原理是一样的,都用于自定义的查找数据。query用于相对独立的功能,是可执行的,lookup则用于字段值的查找与返回,方便窗体数据输入。查询设计器中,不仅仅用对象设计查询,也可以直接输入sql语句,或是调用存储过程来实现。

如何进行ASP.NET Web开发框架中的查询

这样很方便于用户扩充系统查询功能,而不需要二次开发

上述内容就是如何进行ASP.net Web开发框架中的查询,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 如何进行ASP.NET Web开发框架中的查询

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

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

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

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

下载Word文档
猜你喜欢
  • 如何进行ASP.NET Web开发框架中的查询
    本篇文章为大家展示了如何进行ASP.NET Web开发框架中的查询,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Enterprise Solution 支持用户自定义查询(query and loo...
    99+
    2023-06-17
  • 如何理解ASP.NET Web开发框架项目
    本篇文章为大家展示了如何理解ASP.NET Web开发框架项目,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。项目名称:Enterprise Solution技术参数1 C# ASP.NET Web ...
    99+
    2023-06-17
  • 如何使用ASP.NET AJAX框架来进行AJAX开发
    这篇文章主要为大家展示了“如何使用ASP.NET AJAX框架来进行AJAX开发”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用ASP.NET AJAX框...
    99+
    2022-10-19
  • 如何使用Java和Laravel框架进行Web开发?
    在如今的互联网时代,Web开发已经成为了一个非常热门的领域。Java和Laravel框架是Web开发中非常常用的技术,Java作为一种非常成熟的编程语言,Laravel框架则是一种非常流行的PHP框架。本文将介绍如何使用Java和Larav...
    99+
    2023-11-07
    laravel 教程 框架
  • PHP中如何进行RPC框架的开发?
    RPC(Remote Procedure Call),是一种进程间通信协议,它允许不同的进程在不同的物理机器上通过网络进行通信和协作。RPC框架越来越受到关注,因为它可以帮助开发者轻松地实现分布式系统的开发。在本篇文章中,我们会一步一步地介...
    99+
    2023-05-14
    开发 PHP RPC框架
  • ASP.NET Web开发中如何进行数据输入窗体
    这期内容当中小编将会给大家带来有关ASP.NET Web开发中如何进行数据输入窗体,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Web框架要达到快速开发,又便于维护,进行了一系列的努力。请看最初始的ASP...
    99+
    2023-06-17
  • django框架如何集成celery进行开发
    上一篇已经介绍了celery的基本知识,本篇以一个小项目为例,详细说明django框架如何集成celery进行开发。 本系列文章的开发环境: window 7 + python2.7 + pycharm...
    99+
    2022-06-04
    框架 django celery
  • Laravel 框架中如何使用 ASP 文件进行开发?
    Laravel 是一个流行的 PHP 开发框架,它提供了许多便利的功能和工具,让开发者可以快速地创建 Web 应用程序。在 Laravel 中,开发人员可以使用多种文件类型来完成应用程序的开发,其中包括 ASP 文件。本文将介绍 Larav...
    99+
    2023-09-01
    文件 laravel 框架
  • 如何进行基于Python+Django+Jquery架构的Web开发
    这期内容当中小编将会给大家带来有关如何进行基于Python+Django+Jquery架构的Web开发,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。    近来,公司要开发一个自动化运...
    99+
    2023-06-02
  • Python中的Spring框架:如何使用Numpy在Windows上进行开发?
    Python已经成为了一个广泛使用的编程语言,因为它的易学易用和广泛的应用领域。Python能够处理大量的数据并且非常适合科学计算,而Numpy则是Python中最常用的科学计算库之一。而Spring框架则是一个非常流行的Java框架,它...
    99+
    2023-10-23
    spring numpy windows
  • 如何使用 ASP 框架和 IDE 进行高效并发开发?
    ASP框架和IDE工具是一种非常流行的Web开发工具,它们可以帮助开发人员在并发开发中更高效地完成任务。本文将介绍如何使用ASP框架和IDE工具进行高效并发开发,以及一些最佳实践。 一、ASP框架 ASP是一种流行的Web开发框架,它允许开...
    99+
    2023-08-28
    框架 并发 ide
  • 如何使用Java分布式框架中的Shell进行快速开发?
    Java分布式框架中的Shell是一个非常强大的工具,可以帮助开发者快速开发出分布式应用程序。本文将介绍如何使用Java分布式框架中的Shell进行快速开发。 一、什么是Java分布式框架中的Shell? Java分布式框架中的Shell是...
    99+
    2023-08-18
    分布式 框架 shell
  • PHP开发中如何使用Memcache进行数据缓存和查询?
    PHP开发中如何使用Memcache进行数据缓存和查询?引言:在开发Web应用程序时,数据的访问和查询是非常常见的需求。然而,频繁的数据库查询操作会消耗系统资源并且导致应用程序响应速度变慢,影响用户体验。为了优化性能,我们可以使用Memca...
    99+
    2023-11-07
    查询 PHP Memcache
  • 如何分析Web应用架构中的查询传递
    本篇文章为大家展示了如何分析Web应用架构中的查询传递,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。在Web应用开发中,最常见也容易变化的一种需求是根据不同的查询条...
    99+
    2022-10-19
  • 借助 Django 框架,Go 开发者如何提高 Web 应用的开发效率?
    随着互联网的不断发展,Web 应用的开发需求也越来越高。为了提高开发效率,很多开发者选择使用框架。Django 是一款流行的 Python Web 框架,而 Go 语言则是近年来备受关注的高性能编程语言。那么,如何借助 Django 框架...
    99+
    2023-07-24
    开发技术 django 框架
  • 创业开发者必看?如何在Linux系统中使用Laravel框架进行PHP开发!
    作为一名创业开发者,选择一个合适的开发框架是至关重要的。Laravel框架是一个广泛使用的PHP开发框架,它提供了一种简单、优雅的方式来构建高质量的Web应用程序。在本文中,我们将介绍如何在Linux系统中使用Laravel框架进行PHP开...
    99+
    2023-08-15
    linux 框架 laravel
  • PHP开发中如何使用Memcache进行高效的数据写入和查询?
    PHP开发中如何使用Memcache进行高效的数据写入和查询?随着互联网应用的不断发展,对于系统性能的要求越来越高。在PHP开发中,为了提高系统的性能和响应速度,我们经常会使用各种缓存技术。而其中一个常用的缓存技术就是Memcache。Me...
    99+
    2023-11-07
    查询 Memcache PHP开发 高效 数据写入
  • PHP开发中如何使用Memcache进行高效的数据读写和查询?
    PHP开发中如何使用Memcache进行高效的数据读写和查询?Memcache是一个高性能的分布式内存对象缓存系统,它可以有效地处理数据的读写和查询操作,提高Web应用程序的性能和响应速度。在PHP开发中,使用Memcache可以极大地提升...
    99+
    2023-11-07
    Memcache 高效 数据读写
  • Python IDE中如何使用Django进行Web开发?
    Python是一门非常流行的编程语言,广泛应用于各个领域。在Web开发领域,Python也有着非常强大的工具和框架。其中,Django是最受欢迎的Python Web框架之一。在本文中,我们将探讨如何在Python IDE中使用Django...
    99+
    2023-07-31
    ide django numy
  • 如何进行Java和Python的Web开发分析
    今天就跟大家聊聊有关如何进行Java和Python的Web开发分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在Java里面有一种服务端的软件组件技术,叫做Servlet,其实它的...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作