- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个需要几分钟才能加载的网页。原因是此页面包含一个 ASP.NET GridView ,并且此网格的数据绑定(bind)需要花费大量时间。
每个 GridView 记录都包含一些复杂的用户详细信息,并且显示了与用户偏好相关的项目数。根据用户偏好进行此计数是对数据检索存储过程的相当昂贵的操作。我认为这就是加载此页面需要很长时间的原因。
作为解决方案,我想到了加载没有特定网格记录计数的 GridView (从数据检索存储过程中删除计数操作)。并通过对服务器的异步调用更新每个网格记录的计数标签。
谁能知道我如何使用 asp.net GridView 准确地实现此解决方案?
最佳答案
具有数据绑定(bind) GridView 控件的网页可能需要很长时间才能加载。直到所有控件都呈现页面才会呈现,并且在从数据库检索数据之前 GridView 无法呈现。因此,让我们异步加载 GridView,让页面加载更快,感知速度更快。
这个小技巧其实很简单,涉及到ASP.NET内置的客户端回调功能。尽管我不是那个特定功能的忠实粉丝,但它有时会非常方便。最好的部分是您不必对现有代码进行太多更改。网页
在托管 GridView 控件的网页上,您必须进行 2 处小更改。
第 1 步. 封装 GridViewGridView 控件必须由具有 id 属性的 HTML 控件封装,以便它可以被 JavaScript 引用。这是因为当没有数据绑定(bind)到 GridView 时,它不会呈现。
<div id="grid">
<span>Loading...</span>
<asp:GridView runat="Server" ID="gvAsync" />
</div>
第 2 步。添加 JavaScript然后需要一个 JavaScript 将呈现的和数据绑定(bind)的 GridView 加载到我们在步骤 1 中添加的 HTML 控件。将 JavaScript 放在 GridView 周围的 div 标记下方。
<script type="text/javascript">
function EndGetData(arg)
{
document.getElementById("grid").innerHTML = arg;
}
setTimeout("<asp:literal runat="server" id="ltCallback" />", 100);
</script>
代码隐藏
在代码隐藏文件中,需要执行三个小步骤。
第 3 步。实现 ICallbackEventHandler我们需要实现接口(interface)来开启客户端回调功能。
public partial class asyncgridview : System.Web.UI.Page, ICallbackEventHandler
第四步.绑定(bind)回调引用在步骤 2 中放置在 JavaScript 函数中的文本控件必须包含客户端回调引用。将以下内容添加到 Page_Load。
if (!Page.IsCallback)
ltCallback.Text = ClientScript.GetCallbackEventReference(this, "'bindgrid'", "EndGetData", "'asyncgrid'", false);
第 5 步. 绑定(bind)网格并返回呈现的 HTML要完成异步加载,我们必须实现我们在步骤 3 中实现的 ICallbackEventHandler
接口(interface)定义的两个方法。其中一个方法将 DataTable
绑定(bind)到 GridView
并呈现控件。第二个将呈现的 HTML 返回到我们在步骤 2 中定义的 JavaScript 方法。
privatestring _Callback;
publicstring GetCallbackResult()
{
return _Callback;
}
publicvoid RaiseCallbackEvent(string eventArgument)
{
DataTable table = RetrieveDataTableFromDatabase();
gvAsync.DataSource = table;
gvAsync.DataBind();
using (System.IO.StringWriter sw =new System.IO.StringWriter())
{
gvAsync.RenderControl(new HtmlTextWriter(sw));
_Callback = sw.ToString();
}
}
您可以使用现有的数据绑定(bind)方法来绑定(bind)GridView
。重要的部分是 GridView
在 RaiseCallbackEvent
方法呈现控件之前是数据绑定(bind)的。
相同的技术可用于所有数据控件,例如 Repeater、FormView
和 DataList
。
引用:http://madskristensen.net/post/Asynchronous-GridView-in-5-simple-steps
关于asp.net - 从异步调用加载 asp.net GridView ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20063579/
我有一个需要以编程方式作为列(而不是行)绑定(bind)到 gridview 的值列表。例如,如果我的 DAL 返回 10 个值,我需要将这 10 个值显示为 gridview 中的列作为标题文本,并
我有一个使用 out-gridview 显示结果的脚本.这是一个简单的例子: "hello world" | out-gridview 当我使用 Run with PowerShell 运行脚本时,它
我正在尝试使用工作正常的 Kartik 导出小部件,除了它没有在扩展“函数/网格”中获取数据。现在我当然明白它是如何工作的,它实际上并没有显示任何东西,只是呈现另一个 View 。但我不知道如何在导出
在 Android 教程中,GridView tutorial准确的说是有一行代码 GridView gridview = (GridView) findViewById(R.id.gridview)
我正在尝试为与我的 gridview 关联的每一列添加一个标题,这样当页面足够宽以显示多行项目时,列标题应该显示在每一列的顶部,如果页面缩小,以至于该列不再适合。 最终结果看起来像这样: 2 colu
在我使用 comboBox 而不是 default(textBox) 在 gridview 中使用这个搜索之前: [ 'attribute' => 'project_status',
我想在列中显示我的交易表中一个/所有帐户的总余额。余额列应显示添加上一行总余额的余额。 我的网格 View 代码是 'yii\grid\SerialColumn'],
我正在使用 gridview 列出我的所有数据。我的 table 看起来像这样。 $dataProvider, 'columns' => [ 'firstName',
我目前正在构建一个 Windows 8 XAML C# 应用程序。在一个页面中,我有一个用于水平滑动和滚动的滚动查看器。我有几个控件可以很好地与 scorllviewer 配合使用。但是当您滚动并且光
当调整 GridView 的大小时,它的元素被重新排列,该元素的动画似乎不起作用。 在这里你可以找到一个简单的例子:http://pastebin.com/BgST6sCv 如果单击示例中的其中一个方
如何动态更改 gridview 模板列顺序? 最佳答案 迭代 通通栏目 的网格 View 对象和 店铺 他们在 收藏 . List columns = new List(); foreach (Dat
我在 Yii2 中使用了 CRUD 生成器,它为我的 actionIndex 生成了以下代码 Controller ... public function actionIndex() { $s
在我的用户模型中我有一个函数: public function getRole() { if ($this->role == self::ROLE_USER) { return
我正在构建一个带有 Yii2 框架的 webapp,它将为用户(登录)提供下载管理员预先上传文件的能力。 我已经创建了操作 actionDownload在调用 sendFile() 的特定 Contr
我想在 GridView 中订购图像。我已经使用列表框并成功将图像添加到其中。它的显示如下 但我希望这些图像显示在 GridView 中。可能与否。 请帮助我......提前致谢 最佳答案 出于此类目
我试图通过在 QtQuick 2.0 (Qt 5) 中动态填充 ListModel 来填充 GridView。它可以工作,但应用程序启动速度非常慢: 应用程序窗口立即出现,但大约需要 2 秒才会出现浅
我在 Yii2 GridView 小部件中显示一些列,“执行人员名称”是其中之一,但它应该仅在主管登录时显示,而不是在执行人员登录时显示。 当我将可见值硬编码为零时,它不会显示如下: [ 'l
我想用 HTML 制作一个表格。所以我从数据库中获取了一些数据。 每个项目都是一个用户。用户有用户名、名字、姓氏和电子邮件。我想制作一个表格来列出这些用户。 每个用户都必须换行。我已经在互联网上搜索过
我想在 pjax 处于事件状态的排序 gridview 之后运行脚本。重新加载 gridview 后我找不到任何事件处理程序。 pjax调用和gridview刷新后有没有正确的事件处理方法? 最佳答案
在 WinRT 上,我有一个 GridView 。我想在到达 gridview 的末尾时执行一个方法。 但是,没有像 GridView 那样的事件方法。 我尝试检测对 gridview 的操纵,但似乎
我是一名优秀的程序员,十分优秀!