WebService,jQuery,原生对象几种前端加载数据的性能比较(1)
📅 2026/7/6 4:16:00
👁️ 次浏览
详细分析1. 首先创建一系列的实体类代码/// summary/// 用户信息/// /summarypublic class UserInfo{public int UserId { get; set; }public string UserName { get; set; }public string Email { get; set; }public Class Class { get; set; }public ListUserRight UserRightList { get; set; }}/// summary/// 班级信息/// /summarypublic class Class{public int ClassId { get; set; }public string ClassName { get; set; }}/// summary/// 用户权限信息/// /summarypublic class UserRight{public int RightId { get; set; }public string RightName { get; set; }}其中包括用户信息类、班级信息类、用户权限类。2. 在Web.config配置一个appsettings节点appSettingsadd keyDataCount value3000//appSettings表示一次加载的数据量用户信息数为3000。并且将compilation节点的dubug属性设置为false。3. JSON加载数据测试1首先先测试 WebService客户端调用并且最后返回JSON加载数据代码function bindDataWebServiceJson() {var watch new Stopwatch();watch.start();JsonService.GetUserList(function(data) {var builder new Sys.StringBuilder();for (var i 0, length data.length; i length; i) {builder.append(String.format(divUserId:{0}, UserName:{1}, Email:{2}/div, data[i].UserId, data[i].UserName, data[i].Email));}$(#msg2).html(builder.toString());watch.stop();$(#time2).html(用时 watch.ms 毫秒.);});}注这里引入了一个Stopwatch计时器很简单具体可以参考JS版Stopwatch计时器 - Leepy - 博客园通过代码我们可以看到它调用了JsonService.asmx中Web服务的GetUserList方法代码[WebMethod]public ListUserInfo GetUserList(){int count Convert.ToInt32(ConfigurationManager.AppSettings[DataCount]);ListUserInfo list new ListUserInfo();for (int i 0; i count; i){list.Add(new UserInfo { UserId i, UserName leepy i, Email sunleepy i gmail.com });}return list;}返回了一个3000条记录的UserInfo实体列表而前端页面通过对列表返回客户端时的Json对象进行Html字符串拼接最后通过jQuery的Dom元素html(‘…’)方法赋值。运行加载结果为目前我的项目大多数就是采用这样的模式。2接着如果使用jQuery的$.ajax调用并且最后JSON加载数据代码function bindDatajQueryAjaxJson() {var watch new Stopwatch();watch.start();$.ajax({url: JsonHandler.ashx,dataType: json,cache: false,success: function(data) {var builder new Sys.StringBuilder();for (var i 0, length data.length; i length; i) {builder.append(String.format(divUserId:{0}, UserName:{1}, Email:{2}/div, data[i].UserId, data[i].UserName, data[i].Email));}$(#msg4).html(builder.toString());watch.stop();$(#time4).html(用时 watch.ms 毫秒.);}});}通过JsonHandler.ashx的页面处理程序执行返回数据代码public void ProcessRequest (HttpContext context) {context.Response.ContentType application/x-javascript;int count Convert.ToInt32(ConfigurationManager.AppSettings[DataCount]);ListUserInfo list new ListUserInfo();for (int i 0; i count; i){list.Add(new UserInfo { UserId i, UserName leepy i, Email sunleepy i gmail.com });}StringBuilder builder new StringBuilder();string data [;for (int i 0, length list.Count; i length; i){data { string.Format(UserId:{0},UserName:{1}, Email:{2}, list[i].UserId, list[i].UserName, list[i].Email) },;}data data.TrimEnd(,) ];context.Response.Write(data);}也是3000条用户数据运行加载结果为比WebService快了一些。3接着使用$.getJSON来调用并且JSON加载数据
一、创建(1)普通数据表创建
创建数据表需要一步步规划字段名、数据类型,还要配置主键、非空、外键等各类约束,建好之后表会占用物理磁盘空间存储真实数据,后续改动表结构比较繁琐。
代码示例:
CREATE TABLE…
📅 2026/7/6 4:16:00
如何用Video2X将模糊视频变高清:免费AI视频修复终极指南 【免费下载链接】video2x A machine learning-based video super resolution and frame interpolation framework. Est. Hack the Valley II, 2018. 项目地址: https://gitcode.com/GitHub_Trending/vi/vid…
📅 2026/7/6 4:16:00
1. 项目概述:从“手工作坊”到“自动化工厂”的范式转移几年前,当我和团队第一次尝试对上线前的图像分类模型进行安全测试时,我们采取的方式非常“原始”:几个人围在一起,手动调整图片的亮度、对比度,或者用…
📅 2026/7/6 4:14:00
1. GraphRAG 是什么?它不是另一个 RAG 套壳,而是对“知识如何被组织与调用”的一次底层重思考GraphRAG 这个名字里藏着两个关键信号:Graph(图)和RAG(检索增强生成)。但如果你把它简单理解为“在…
📅 2026/7/6 5:42:16
3分钟搞定!Windows平台最新ADB驱动一键安装终极指南 【免费下载链接】Latest-adb-fastboot-installer-for-windows A Simple Android Driver installer tool for windows (Always installs the latest version) 项目地址: https://gitcode.com/gh_mirrors/la/Late…
📅 2026/7/6 5:42:15
1、AI程序员系列文章 2、AI面试系列文章 3、AI编程系列文章 目录
开篇:你的职业是自动驾驶还是手动驾驶?
第一阶段:0-3年 技能积累期——打好地基,别急着盖楼
核心任务
⚠️ 避坑警告:别做"简历驱动开发"…
📅 2026/7/6 5:42:15
如何在Windows上一键安装最新ADB驱动:3分钟解决Android连接问题终极指南 【免费下载链接】Latest-adb-fastboot-installer-for-windows A Simple Android Driver installer tool for windows (Always installs the latest version) 项目地址: https://gitcode.com…
📅 2026/7/6 5:42:15
Video2X:免费AI视频增强工具,让模糊视频重获新生 【免费下载链接】video2x A machine learning-based video super resolution and frame interpolation framework. Est. Hack the Valley II, 2018. 项目地址: https://gitcode.com/GitHub_Trending/vi…
📅 2026/7/6 5:42:15
SMUDebugTool:锐龙处理器性能调试的终极指南,轻松实现超频优化与系统监控 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power …
📅 2026/7/6 5:40:14
Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘 【免费下载链接】rbtray A fork of RBTray from http://sourceforge.net/p/rbtray/code/. 项目地址: https://gitcode.com/gh_mirrors/rb/rbtray
你是否厌倦了Windows任务栏上密密麻麻的图标&…
📅 2026/7/6 0:01:19
1. 项目概述:一次对React Server Components核心安全机制的深度剖析 最近在安全研究圈里,CVE-2025-55182这个编号被频繁提及,它直指React生态中一个相对较新的概念——React Server Components(RSC)。作为一个长期关注…
📅 2026/7/6 0:01:20
星露谷物语终极MOD指南:5个步骤打造智能自动化农场 【免费下载链接】StardewMods Mods for Stardew Valley using SMAPI. 项目地址: https://gitcode.com/gh_mirrors/st/StardewMods
你是否厌倦了在星露谷物语中重复收割、加工、存储的繁琐操作?梦…
📅 2026/7/6 0:01:20
1. 项目背景与核心需求 在嵌入式系统开发中,快速精确的数据检索是一个常见但极具挑战性的需求。特别是在工业控制、医疗设备和物联网终端等场景下,系统往往需要在毫秒级时间内完成关键参数的读取和写入操作。传统基于Flash存储的方案存在擦写次数有限、操…
📅 2026/7/5 0:01:51
1. 工业电流环信号传输的基础认知在工业自动化领域,4-20mA电流环传输技术已经持续服役超过半个世纪。这种看似简单的信号传输方式之所以能经久不衰,核心在于其独特的抗干扰能力——电流信号在长距离传输时几乎不受线路电阻和电压波动的影响。我曾在化工厂…
📅 2026/7/5 0:01:51
最近在项目里尝试用 YOLO 做目标检测,从环境搭建到模型训练,再到推理部署,整个过程踩了不少坑。网上的资料虽然多,但要么版本老旧,要么步骤零散不成体系,对于刚入门的新手来说,很容易卡在某个环…
📅 2026/7/6 5:35:58
目录
第一步:选对模板,省心一半
第二步:打开扫码点餐功能
开启功能按钮
桌台管理与桌码生成
第三步:个性化设计,打造品牌感
调整点餐页面
设置点餐规则 你还在让顾客站着排队点餐吗?2025年ÿ…
📅 2026/7/5 6:01:04
在业务中快速构建一个能理解私有文档、准确回答专业问题的智能助手,是很多开发团队面临的共同挑战。传统方案往往需要从零开始搭建复杂的 RAG(检索增强生成)系统,涉及文档解析、向量化、检索、大模型调用等多个环节,整…
📅 2026/7/5 6:01:04
FAE放射组学分析工具:医学影像特征探索的完整解决方案 【免费下载链接】FAE FeAture Explorer 项目地址: https://gitcode.com/gh_mirrors/fae/FAE
你是否曾经面对海量医学影像数据感到无从下手?想要从CT、MRI等影像中提取有价值的定量特征&#…
📅 2026/7/5 23:45:08