在asp中怎样实现像timer似的定时自动触发的事件?

310cdt 2000-10-29 09:48:00
这么说吧,怎样做一个按时间走的进度条?
我想可以做一个定时自动更新的frame,不过,不用frame最好,而且一直更新frame是不是很费资源?
请高手指点。谢了
...全文
100 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
ciml 2000-10-29
  • 打赏
  • 举报
回复
上面的程序是可以的
关键就是setTimeout()函数
上面的程序的意思是每隔200(毫秒?)就执行timerFun函数。
monday 2000-10-29
  • 打赏
  • 举报
回复
我也试试
Edward 2000-10-29
  • 打赏
  • 举报
回复
改进版:

<!doctype html public "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title> New Document </title>
<script type="text/javascript">
var g_var;

g_var = 0;

function timerFun()
{
var s;
var i;

if(g_var <= 20)
{
s = "";
for(i = 0; i < g_var; i++)
s += ".";
window.status = g_var++;
window.setTimeout(timerFun, 200);
}
else
window.status = "Complete!";
}

function init()
{
window.setTimeout(timerFun, 200);
}
</script>

</head>

<body bgcolor="#FFFFFF" onload="init()">

</body>
</html>
手动优化了PDF的书签,书签可折叠,书签链接以目录方式保存,多达1000多页,每页都做了书签定位,手都累酸啦。 ============================== 因权限只能到60MB,分卷压缩了,共3个压缩包,需下载完3个一起解压, ============================== ASP.NET 4高级程序设计(第4版)》【原版书为:Pro ASP.NET 4 in C# 2010】是ASP.NET领域的鸿篇巨制,全面讲解了ASP.NET4的各种特性及其背后的工作原理,并给出了许多针对如何构建复杂、可扩展的网站从实践得出的建议。书还深入讲述了其他ASP.NET图书遗漏的高级主题,如自定义控件的创建、图像处理、加密等。此外,《ASP.NET 4高级程序设计(第4版)》专门提供了两章的内容来教你如何用Ajax 技术制作快速响应的页面,以及如何使用微软的ASP.NETAJAX平台。另外,还专门介绍了ASP.NET4 新增的功能,如MVC 和动态数据等。   《ASP.NET 4高级程序设计(第4版)》适合各层次的ASP.NET程序员阅读。 =================== 第一部分 核心概念 第1章 ASP.NET简介 1.1 ASP.NET的7大要点 1.1.1 要点1:ASP.NET是同.NETFramework集成在一起的 1.1.2 要点2:ASP.NET是编译执行的,而不是解释执行的 1.1.3 要点3:ASP.NET支持多语言 1.1.4 要点4:ASP.NET运行在公共语言运行库内 1.1.5 要点5:ASP.NET是面向对象的 1.1.6 要点6:ASP.NET支持所有的浏览器 1.1.7 要点7:ASP.NET易于部署和配置 1.2 ASP.NET的演变 1.2.1 ASP.NET1.0和ASP.NET1.1 1.2.2  ASP.NET2.0 1.2.3 ASP.NET3.5 1.2.4 ASP.NET4 1.2.5 Silverlight 1.3 总结 第2章 Visual Studio 2.1 Visual Studio 2.1.1 网站和Web项目 2.1.2 创建无项目文件的网站 2.1.3 设计网页 2.2 Visual StudioIDE 2.2.1 解决方案资源管理器 2.2.2 文档窗口 2.2.3 工具箱 2.2.4 错误列表和任务列表 2.2.5 服务器资源管理器 2.3 代码编辑器 2.3.1 添加程序集引用 2.3.2 智能感知和大纲显示 2.3.3 Visual Studio 2010改进 2.4 编码模型 2.4.1 代码隐藏文件如何与页面连接 2.4.2 控件标签如何与页面变量连接 2.4.3 事件如何与事件处理程序连接 2.5 Web项目 2.5.1 基于项目的开发 2.5.2 创建Web项目 2.5.3 迁移旧版Visual Studio创建的网站 2.6 Visual Studio调试 2.6.1 单步调试 2.6.2 变量监视 2.6.3 高级断点 2.7 WebDevelopment Helper 2.8 总结 第3章 Web窗体 3.1 页面处理 3.1.1 HTML表单 3.1.2 动态用户界面 3.1.3 ASP.NET事件模型 3.1.4 自动回送 3.1.5 视图状态 3.1.6 XHTML兼容性 3.1.7 客户端控件ID 3.2 Web窗体处理阶段 3.2.1 页面框架初始化 3.2.2 用户代码初始化 3.2.3 验证 3.2.4 事件处理 3.2.5 自动数据绑定 3.2.6 清除 3.2.7 页面流示例 3.3 作为控件容器的页面 3.3.1 显示控件树 3.3.2 页头 3.3.3 动态控件的创建 3.4 Page类 3.4.1 Session、Application和Cache 3.4.2 Request 3.4.3 Response 3.4.4 Server 3.4.5 User 3.4.6 Trace 3.4.7 访问其他类的HTTP上下文 3.5 总结 第4章 服务器控件 4.1 服务器控件的类型 4.2 HTML服务器控件 4.2.1 HtmlControl类 4.2.2 HtmlContainerControl类 4.2.3 HtmlInputControl类 4.2.4 HTML服务器控件类 4.2.5 设置Style特性和其他属性 4.2.6 通过编程创建服务器控件 4.2.7 处理服务器端事件 4.3 Web控件 4.3.1 WebControl基类 4.3.2 基本的Web控件类 4.3.3 单位 4.3.4 枚举 4.3.5 颜色 4.3.6 字体 4.3.7 焦点 4.3.8 默认按钮 4.3.9 可滚动面板 4.3.10 处理Web控件事件 4.4 List控件 4.4.1 Selectable列表控件 4.4.2 BulletedList控件 4.5 输入验证控件 4.5.1 验证控件 4.5.2 验证流程 4.5.3 BaseValidator类 4.5.4 RequiredFieldValidator控件 4.5.5 RangeValidator控件 4.5.6 CompareValidator控件 4.5.7 RegularExpressionValidator控件 4.5.8 CustomValidator控件 4.5.9 ValidationSummary控件 4.5.10 通过编程使用验证器 4.5.11 验证组 4.6 富控件 4.6.1 AdRotator控件 4.6.2 Calendar控件 4.7 总结 第5章 ASP.NET应用程序 5.1 剖析ASP.NET应用程序 5.1.1 应用程序域 5.1.2 应用程序生命周期 5.1.3 应用程序更新 5.1.4 应用程序目录结构 5.2 global.asax应用程序文件 5.2.1 应用程序事件 5.2.2 演示应用程序事件 5.3 ASP.NET配置 5.3.1 machine.config文件 5.3.2 web.config文件 5.3.3 设置 5.3.4 5.3.5 5.3.6 5.3.7 通过编程读写配置节 5.3.8 网站管理工具(WAT) 5.3.9 扩展配置文件结构 5.3.10 加密配置节 5.4 .NET组件 5.4.1 创建组件 5.4.2 通过App_Code目录使用组件 5.4.3 通过Bin目录使用组件 5.5 扩展HTTP管道 5.5.1 HTTP处理程序 5.5.2 创建自定义的HTTP处理程序 5.5.3 配置自定义的HTTP处理程序 5.5.4 使用无须配置的HTTP处理程序 5.5.5 创建高级的HTTP处理程序 5.5.6 为非HTML内容创建HTTP处理程序 5.5.7 HTTP模块 5.5.8 创建自定义HTTP模块 5.6 总结 第6章 状态管理 6.1 ASP.NET状态管理 6.2 视图状态 6.2.1 视图状态示例 6.2.2 在视图状态保存对象 6.2.3 视图状态评估 6.2.4 有选择地禁用视图状态 6.2.5 视图状态安全 6.3 在页面间传送信息 6.3.1 查询字符串 6.3.2 跨页回发 6.4 cookie 6.5 会话状态 6.5.1 会话架构 6.5.2 使用会话状态 6.5.3 配置会话状态 6.5.4 会话状态安全 6.6 应用程序状态 6.7 总结 第二部分 数据访问 第7章 基础 7.1 ADO.NET架构 7.1.1 ADO.NET数据提供程序 7.1.2 ADO.NET的标准化 7.1.3 基本ADO.NET类 7.2 Connection类 7.2.1 连接字符串 7.2.2 测试连接 7.2.3 连接池 7.3 Command类和DataReader类 7.3.1 Command基础 7.3.2 DataReader类 7.3.3  ExecuteReader()方法和DataReader 7.3.4 ExecuteScalar()方法 7.3.5 ExecuteNonQuery()方法 7.3.6 SQL注入攻击 7.3.7 使用参数化命令 7.3.8 调用存储过程 7.4 事务 7.4.1 事务和ASP.NET应用程序 7.4.2 隔离级别 7.4.3 保存点 7.5 提供程序无关的代码 7.5.1 创建工厂 7.5.2 用工厂创建对象 7.5.3 使用提供程序无关的代码的查询 7.6 总结 第8章 数据组件和DataSet 8.1 构建数据访问组件 8.1.1 数据包 8.1.2 存储过程 8.1.3 数据应用类 8.1.4 测试数据库组件 8.2 非连接的数据 8.2.1 Web应用程序和DataSet 8.2.2 XML集成 8.3 DataSet类 8.4  DataAdapter类 8.4.1 填充DataSet 8.4.2 使用多个表和关系 8.4.3 查找特定行 8.4.4 在数据访问类里使用DataSet 8.4.5 数据绑定 8.5 DataView类 8.5.1 使用DataView排序 8.5.2 使用DataView过滤 8.5.3 使用关系的高级过滤 8.5.4 计算列 8.6 总结 第9章 数据绑定 9.1 基本的数据绑定 9.1.1 单值绑定 9.1.2 其他类型的表达式 9.1.3 重复值绑定 9.2 数据源控件 9.3 SqlDataSource 9.3.1 选择记录 9.3.2 参数化命令 9.3.3 错误处理 9.3.4 更新记录 9.3.5 删除记录 9.3.6 插入记录 9.3.7 SqlDataSource的不足 9.4 ObjectDataSource 9.4.1 选择记录 9.4.2 更新记录 9.4.3 使用数据对象执行更新 9.5 数据源控件的限制 9.5.1 问题 9.5.2 添加其他项 9.5.3 使用SqlDataSource处理其他选项 9.5.4 使用ObjectDataSource处理其他选项 9.6 总结 第10章 富数据控件 10.1 GridView 10.2 格式化GridView 10.2.1 格式化字段 10.2.2 样式 10.2.3 格式化特定值 10.3 GridView行选择 10.3.1 使用选择来创建主-从表单 10.3.2 SelectedIndexChanged事件 10.3.3 将数据字段用作选择按钮 10.4 对GridView排序 10.4.1 使用SqlDataSource排序 10.4.2 使用ObjectDataSource排序 10.4.3 排序和选择 10.4.4 高级排序 10.5 GridView分页 10.5.1 自动分页 10.5.2 分页和选择 10.5.3 ObjectDataSource的自定义分页 10.5.4 定制分页栏 10.6 GridView模板 10.6.1 使用多个模板 10.6.2 在Visual Studio编辑模板 10.6.3 绑定到方法 10.6.4 处理模板事件 10.6.5 使用模板编辑 10.6.6 模板的客户端ID 10.7 ListView 10.7.1 分组 10.7.2 分页 10.8 DetailsView和FormView 10.8.1 DetailsView 10.8.2 FormView 10.9 高级网格 10.9.1 GridView的汇总 10.9.2 单个表的父/子视图 10.9.3 使用查找表编辑字段 10.9.4 处理来自数据库的图片 10.9.5 探测并发冲突 10.10 总结 第11章 缓存和异步页面 11.1 理解ASP.NET缓存 11.2 输出缓存 11.2.1 声明性的输出缓存 11.2.2 缓存和查询字符串 11.2.3 使用特定查询字符串参数的缓存 11.2.4 自定义缓存控制 11.2.5 使用HttpCachePolicy类进行缓存 11.2.6 缓存后替换和部分页缓存 11.2.7 缓存用户配置 11.2.8 缓存配置 11.2.9 输出缓存扩展 11.3 数据缓存 11.3.1 向缓存添加项目 11.3.2 简单的缓存测试 11.3.3 缓存优先级 11.3.4 使用数据源控件的缓存 11.4 缓存依赖 11.4.1 文件和缓存项目依赖 11.4.2 聚合依赖 11.4.3 移除项目回调 11.4.4 理解SQL缓存通知 11.4.5 缓存通知的工作方式 11.4.6 启用通知 11.4.7 创建缓存依赖 11.5 自定义缓存依赖 11.5.1 基本的自定义缓存依赖 11.5.2 使用消息队列的自定义缓存依赖 11.6 异步页面 11.6.1 创建异步页面 11.6.2 在异步页面查询数据 11.6.3 错误处理 11.6.4 在异步任务使用缓存 11.6.5 多异步任务和超时 11.7 总结 第12章 文件和流 12.1 使用文件系统 12.1.1 Directory类和File类 12.1.2 DirectoryInfo类和FileInfo类 12.1.3 DriveInfo类 12.1.4 使用Attributes 12.1.5 使用通配符过滤文件 12.1.6 获取文件的版本信息 12.1.7 Path类 12.1.8 文件浏览器 12.2 使用流读写文件 12.2.1 文本文件 12.2.2 二进制文件 12.2.3 上传文件 12.2.4 使文件对多用户安全 12.2.5 压缩 12.3 序列化 12.4 总结 第13章 LINQ 13.1 LINQ基础 13.1.1 延迟执行 13.1.2 LINQ是如何工作的 13.1.3 LINQ表达式 13.1.4 揭秘LINQ表达式 13.2 LINQ to DataSet 13.2.1 强类型的DataSet 13.2.2 空值 13.3 LINQ to Entities 13.3.1 生成数据模型 13.3.2 数据模型类 13.3.3 实体关系 13.3.4 查询存储过程 13.3.5 LINQ to Entities查询揭秘 13.4 数据库操作 13.4.1 插入 13.4.2 更新 13.4.3 删除 13.4.4 管理并发 13.4.5 处理并发冲突 13.5 EntityDataSource控件 13.5.1 显示数据 13.5.2 获取关联数据 13.5.3 编辑数据 13.5.4 验证 13.6 使用QueryExtender控件 13.6.1 使用SearchExperssion 13.6.2 使用RangeExpression 13.6.3 使用PropertyExpression 13.6.4 使用MethodExpression 13.7 总结 第14章 XML 14.1 什么时候使用XML 14.2 XML简介 14.2.1 XML的优点 14.2.2 格式良好的XML 14.2.3 XML命名空间 14.2.4 XML架构 14.3 基于流的XML处理 14.3.1 写XML文件 14.3.2 读取XML文件 14.4 内存的XML处理 14.4.1 XmlDocument 14.4.2 XPathNavigator 14.4.3 XDocument 14.5 搜索XML内容 14.5.1 搜索XmlDocument 14.5.2 使用XPath搜索XmlDocument 14.5.3 使用LINQ搜索XDocument 14.6 验证XML内容 14.6.1 基本架构 14.6.2 验证XmlDocument 14.6.3 使用XDocument进行验证 14.7 转换XML内容 14.7.1 基本的样式表 14.7.2 使用XslCompiledTransform 14.7.3 使用Xml控件 14.7.4 使用LINQ to XML转换XML 14.8 XML数据绑定 14.8.1 非层次化绑定 14.8.2 使用XPath 14.8.3 嵌套的网格 14.8.4 使用TreeView的层次化绑定 14.8.5 使用XSLT 14.8.6 绑定到来自其他源的XML内容 14.8.7 通过XmlDataSource更新XML 14.9 XML和ADO.NET数据集 14.9.1 把DataSet转换为XML 14.9.2 把DataSet作为XML访问 14.10 总结 第三部分 构建ASP.NET网站 第15章 用户控件 15.1 用户控件基础 15.1.1 创建简单的用户控件 15.1.2 把页面转换成用户控件 15.2 为用户控件添加代码 15.2.1 处理事件 15.2.2 添加属性 15.2.3 使用自定义对象 15.2.4 添加事件 15.2.5 公开内部Web控件 15.3 动态加载用户控件 15.4 局部页面缓存 15.4.1 VaryByControl 15.4.2 共享缓存控件 15.5 总结 第16章 主题和母版页 16.1 层叠样式表 16.1.1 创建样式表 16.1.2 应用样式表规则 16.2 主题 16.2.1 主题文件夹和外观 16.2.2 应用简单主题 16.2.3 处理主题冲突 16.2.4 为同一控件创建多个外观 16.2.5 含有模板和图片的外观 16.2.6 在主题里使用CSS 16.2.7 通过配置文件来应用主题 16.2.8 动态应用主题 16.3 标准化网站布局 16.4 母版页基础 16.4.1 简单的母版页 16.4.2 简单的内容页 16.4.3 默认内容 16.4.4 具有表格和CSS布局的母版页 16.4.5 母版页和相对路径 16.4.6 通过配置文件应用母版页 16.5 高级母版页 16.5.1 和母版页类交互 16.5.2 动态设置母版页 16.5.3 嵌套母版页 16.6 总结 第17章 网站导航 17.1 多视图页面 17.1.1 MultiView控件 17.1.2 Wizard控件 17.2 站点地图 17.2.1 定义站点地图 17.2.2 绑定站点地图 17.2.3 导航路径 17.2.4 显示站点地图的一部分 17.2.5 站点地图对象 17.2.6 加入自定义站点地图信息 17.2.7 创建自定义的SiteMapProvider 17.2.8 安全调整 17.3 URL映射和路由 17.3.1 URL映射 17.3.2 URL路由 17.4 TreeView控件 17.4.1 TreeNode 17.4.2 按需填充节点 17.4.3 TreeView样式 17.5 Menu控件 17.5.1 Menu样式 17.5.2 Menu模板 17.6 总结 第18章 网站部署 18.1 安装和配置IIS 18.1.1 安装IIS 7 18.1.2 管理IIS 7 18.2 部署网站 18.2.1 通过复制文件进行部署 18.2.2 使用Web部署 18.2.3 通过FTP部署 18.3 管理网站 18.3.1 创建新站点 18.3.2 创建虚拟目录 18.3.3 使用VirtualPathProvider 18.3.4 使用应用程序池 18.3.5 使用应用程序预热 18.4 扩展集成管道 18.4.1 创建处理程序 18.4.2 部署处理程序 18.4.3 配置处理程序 18.4.4 测试处理程序 18.5 总结 第四部分 安全 第19章 ASP.NET安全模型 19.1 为何创建安全软件 19.1.1 理解潜在的威胁 19.1.2 安全编程原则 19.1.3 理解Gatekeeper 19.2 理解安全级别 19.2.1 验证 19.2.2 授权 19.2.3 机密性和完整性 19.2.4 互相协作 19.3 理解SSL 19.3.1 理解证书 19.3.2 理解SSL 19.3.3 在IIS 7.x配置SSL 19.4 总结 第20章 表单验证 20.1 表单验证介绍 20.1.1 为什么使用表单验证 20.1.2 为什么不使用表单验证 20.1.3 为什么不自己实现cookie验证 20.1.4 表单验证类 20.2 实现表单验证 20.2.1 配置表单验证 20.2.2 禁止匿名用户访问 20.2.3 创建自定义登录页面 20.2.4 自定义凭证存储 20.2.5 表单验证的持久化cookie 20.3 IIS 7.x和表单验证 20.4 总结 第21章 成员资格 21.1 介绍ASP.NET的成员资格API 21.2 使用成员资格API 21.2.1 配置表单验证 21.2.2 创建数据存储 21.2.3 配置连接字符串和成员资格提供程序 21.2.4 创建并验证用户 21.3 使用安全控件 21.3.1 Login控件 21.3.2 LoginStatus控件 21.3.3 LoginView控件 21.3.4 PasswordRecovery控件 21.3.5 ChangePassword控件 21.3.6 CreateUserWizard控件 21.4 在IIS 7.x里配置成员资格 21.4.1 配置提供程序和用户 21.4.2 在其他应用程序里使用成员资格API 21.5 使用Membership类 21.5.1 从存储获得用户 21.5.2 更新存储的用户 21.5.3 创建和删除用户 21.5.4 检验用户 21.6 总结 第22章 Windows验证 22.1 介绍Windows验证 22.1.1 为什么使用Windows验证 22.1.2 为什么不使用Windows验证 22.1.3 Windows验证机制 22.2 实现Windows验证 22.2.1 配置IIS 7.x 22.2.2 配置ASP.NET 22.2.3 IIS 7.x管道 22.2.4 禁止匿名用户访问 22.2.5 访问Windows用户信息 22.3 身份模拟 22.3.1 Windows的身份模拟和委托 22.3.2 经过配置的身份模拟 22.3.3 可编程的身份模拟 22.4 总结 第23章 授权和角色 23.1 URL 授权 23.2 文件授权 23.3 在代码检查授权 23.3.1 使用IsInRole()方法 23.3.2 使用PrincipalPermission类 23.4 为基于角色的授权使用角色API 23.4.1 和角色一起使用LoginView控件 23.4.2 通过编程访问角色 23.4.3 在Windows验证使用角色API 23.5 IIS 7.x里的授权和角色 23.5.1 在IIS 7.x里使用ASP.NET角色授权 23.5.2 在IIS 7.x管理ASP.NET角色 23.6 总结 第24章 用户配置 24.1 理解用户配置 24.1.1 用户配置的性能 24.1.2 用户配置如何存储数据 24.1.3 用户配置和验证 24.1.4 用户配置与自定义的数据组件 24.2 使用SqlProfileProvider 24.2.1 创建用户配置表 24.2.2 配置提供程序 24.2.3 定义用户配置属性 24.2.4 使用用户配置属性 24.2.5 用户配置序列化 24.2.6 用户配置组 24.2.7 用户配置和自定义的数据类型 24.2.8 用户配置API 24.2.9 匿名用户配置 24.3 自定义的用户配置提供程序 24.3.1 自定义的用户配置提供程序类 24.3.2 设计FactoredProfileProvider 24.3.3 通过编码实现FactoredProfileProvider 24.3.4 测试FactoredProfileProvider 24.4 总结 第25章 加密 25.1 加密数据:机密性问题 25.2 .NET加密命名空间 25.3 理解.NET加密类 25.3.1 对称加密算法 25.3.2 非对称加密 25.3.3 抽象加密类 25.3.4 ICryptoTransform接口 25.3.5 CryptoStream类 25.4 加密敏感数据 25.4.1 管理秘密信息 25.4.2 使用对称算法 25.4.3 使用非对称算法 25.4.4 加密数据库的敏感数据 25.5 加密查询字符串 25.5.1 包装查询字符串 25.5.2 创建一个测试页面 25.6 总结 第26章 自定义成员资格提供程序 26.1 自定义提供程序的架构 26.2 创建自定义提供程序的基本步骤 26.2.1 自定义提供程序的总体设计 26.2.2 设计并实现自定义存储 26.2.3 实现提供程序类 26.2.4 使用自定义提供程序类 26.3 总结 第五部分 高级用户界面 第27章 自定义服务器控件 27.1 自定义服务器控件入门 27.1.1 创建简单的自定义控件 27.1.2 使用自定义控件 27.1.3 工具箱的自定义控件 27.1.4 创建支持样式属性的Web控件 27.1.5 呈现过程 27.2 处理不同的浏览器 27.2.1 HtmlTextWriter 27.2.2 浏览器检测 27.2.3 浏览器属性 27.2.4 覆盖浏览器类型侦测 27.2.5 自适应呈现 27.3 控件状态和事件 27.3.1 视图状态 27.3.2 控件状态 27.3.3 回传数据和change事件 27.3.4 触发回传 27.4 扩展现有的Web控件 27.4.1 组合控件 27.4.2 派生控件 27.5 总结 第28章 图形、GDI+和图表 28.1 ImageMap控件 28.1.1 创建热点 28.1.2 处理热点单击 28.1.3 自定义热点 28.2 使用GDI+画图 28.2.1 简单绘制 28.2.2 图像格式和质量 28.2.3 Graphics类 28.2.4 使用GraphicsPath 28.2.5 画笔 28.2.6 画刷 28.3 在网页上嵌入动态图形 28.3.1 使用PNG格式 28.3.2 传递信息给动态图像 28.3.3 使用GDI+的自定义控件 28.4 使用Chart控件 28.4.1 创建基本的图表 28.4.2 用数据填充图表 28.5 总结 第29章 JavaScript和Ajax技术 29.1 JavaScript本质 29.1.1 HTML DOM 29.1.2 客户端事件 29.1.3 脚本块 29.1.4 操纵HTML元素 29.1.5 调试JavaScript 29.2 基本的JavaScript示例 29.2.1 创建JavaScript页面处理器 29.2.2 使用JavaScript异步下载图片 29.2.3 呈现脚本块 29.3 脚本注入攻击 29.3.1 请求验证 29.3.2 禁用请求验证 29.3.3 扩展请求验证 29.4 带有JavaScript的自定义控件 29.4.1 弹出窗口 29.4.2 滚动按钮 29.5 框架 29.5.1 框架导航 29.5.2 内联框架 29.6 理解Ajax 29.6.1 XMLHttpRequest对象 29.6.2 Ajax示例 29.7 在客户端回调使用Ajax 29.7.1 创建客户端回调 29.7.2 深入了解客户端回调 29.7.3 自定义控件里的客户端回调 29.8 总结 第30章 ASP.NETAJAX 30.1 介绍ASP.NETAJAX 30.1.1 客户端的ASP.NETAJAX:脚本库 30.1.2 服务器端的ASP.NETAJAX:ScriptManager 30.2 服务器回调 30.2.1 ASP.NETAJAX的Web服务 30.2.2 在页面里放置Web方法 30.2.3 ASP.NETAJAX应用程序服务 30.3 ASP.NETAJAX服务器控件 30.3.1 使用UpdatePanel的局部呈现 30.3.2 使用Timer定时刷新 30.3.3 使用UpdateProgress的耗时更新 30.3.4 管理浏览器历史 30.4 深入客户端库 30.4.1 理解客户端模型 30.4.2 JavaScript的面向对象编程 30.4.3 网页框架 30.5 控件扩展器 30.5.1 安装ASP.NETAJAX控件工具包 30.5.2 AutoCompleteExtender 30.5.3 ASP.NETAJAX控件工具包 30.6 总结 第31章 使用Web部件页面的门户网站 31.1 典型门户页面 31.2 基本Web部件页面 31.2.1 创建页面设计 31.2.2 WebPartManager和WebPartZone 31.2.3 向页面添加Web部件 31.2.4 定制页面 31.3 创建Web部件 31.3.1 简单的Web部件任务 31.3.2 开发高级Web部件 31.3.3 Web部件编辑器 31.3.4 连接Web部件 31.3.5 自定义动词和Web部件 31.3.6 用户控件和高级Web部件 31.3.7 动态上传Web部件 31.3.8 对Web部件的授权 31.3.9 个性化的最后任务 31.4 总结 第32章 MVC 32.1 MVC和Web表单的选择 32.2 创建基本的MVC应用程序 32.2.1 创建模型 32.2.2 创建控制器 32.2.3 创建Index视图 32.2.4 测试(未完成的)应用程序 32.2.5 完成控制器和视图 32.2.6 修改Site.Master文件 32.3 扩展基础的MVC应用程序 32.3.1 配置路由 32.3.2 增加错误处理 32.3.3 增加验证 32.3.4 增强数据存储访问 32.3.5 增加对外键约束的支持 32.4 自定义视图 32.4.1 修改视图 32.4.2 增加视图数据 32.5 强化模型 32.6 验证数据 32.6.1 执行基本的验证 32.6.2 增加验证标注 32.7 使用动作结果 32.7.1 返回JSON数据 32.7.2 调用其他控制器方法 32.8 总结 第33章 动态数据 33.1 创建动态数据应用程序 33.1.1 创建动态数据网站 33.1.2 检验动态数据网站 33.2 深入理解动态数据项目 33.3 自定义动态数据网站 33.3.1 使用模板进行自定义 33.3.2 使用路由进行自定义 33.3.3 使用元数据进行自定义 33.3.4 自定义验证 33.4 总结 第34章 Silverlight 34.1 理解Silverlight 34.1.1 Silverlight与Flash对比 34.1.2 Silverlight系统需求 34.2 创建Silverlight解决方案 34.2. 1 Silverlight编译 34.2.2 入口页面 34.3 创建Silverlight项目 34.3.1 设计Silverlight页面 34.3.2 理解XAML 34.3.3 设置属性 34.3.4 XAML 代码隐藏 34.3.5 处理事件 34.3.6 了解Silverlight类库 34.4 布局 34.4.1 Canvas 34.4.2 网格 34.5 动画 34.5.1 动画基础知识 34.5.2 定义动画 34.5.3 StoryBoard类 34.5.4 交互式动画实例 34.5.5 变换 34.6 Silverlight使用Web服务 34.6.1 创建Web服务 34.6.2 添加Web引用 34.6.3 调用Web服务 34.6.4 配置Web服务URL 34.6.5 跨域Web服务调用 34.7 总结
内容简介   《ASP.NET 4高级程序设计(第4版)》是ASP.NET领域的鸿篇巨制,全面讲解了ASP.NET4的各种特性及其背后的工作原理,并给出了许多针对如何构建复杂、可扩展的网站从实践得出的建议。书还深入讲述了其他ASP.NET图书遗漏的高级主题,如自定义控件的创建、图像处理、加密等。此外,《ASP.NET 4高级程序设计(第4版)》专门提供了两章的内容来教你如何用Ajax 技术制作快速响应的页面,以及如何使用微软的ASP.NETAJAX平台。另外,还专门介绍了ASP.NET4 新增的功能,如MVC 和动态数据等。   《ASP.NET 4高级程序设计(第4版)》适合各层次的ASP.NET程序员阅读。 作者简介 作者:(美)麦克唐纳 目录 第一部分 核心概念 第1章 ASP.NET简介 2 1.1 ASP.NET的7大要点 2 1.1.1 要点1:ASP.NET是同.NETFramework集成在一起的 2 1.1.2 要点2:ASP.NET是编译执行的,而不是解释执行的 3 1.1.3 要点3:ASP.NET支持多语言 4 1.1.4 要点4:ASP.NET运行在公共语言运行库内 6 1.1.5 要点5:ASP.NET是面向对象的 7 1.1.6 要点6:ASP.NET支持所有的浏览器 8 1.1.7 要点7:ASP.NET易于部署和配置 8 1.2 ASP.NET的演变 9 1.2.1 ASP.NET1.0和ASP.NET1.1 9 1.2.2  ASP.NET2.0 9 1.2.3 ASP.NET3.5 10 1.2.4 ASP.NET4 12 1.2.5 Silverlight 14 1.3 总结 15 第2章 Visual Studio 16 2.1 Visual Studio 16 2.1.1 网站和Web项目 17 2.1.2 创建无项目文件的网站 18 2.1.3 设计网页 21 2.2 Visual StudioIDE 26 2.2.1 解决方案资源管理器 28 2.2.2 文档窗口 29 2.2.3 工具箱 29 2.2.4 错误列表和任务列表 30 2.2.5 服务器资源管理器 31 2.3 代码编辑器 32 2.3.1 添加程序集引用 33 2.3.2 智能感知和大纲显示 35 2.3.3 Visual Studio 2010改进 37 2.4 编码模型 42 2.4.1 代码隐藏文件如何与页面连接 44 2.4.2 控件标签如何与页面变量连接 44 2.4.3 事件如何与事件处理程序连接 46 2.5 Web项目 47 2.5.1 基于项目的开发 47 2.5.2 创建Web项目 48 2.5.3 迁移旧版Visual Studio创建的网站 49 2.6 Visual Studio调试 51 2.6.1 单步调试 52 2.6.2 变量监视 54 2.6.3 高级断点 55 2.7 WebDevelopment Helper 56 2.8 总结 57 第3章 Web窗体 58 3.1 页面处理 58 3.1.1 HTML表单 59 3.1.2 动态用户界面 60 3.1.3 ASP.NET事件模型 61 3.1.4 自动回送 62 3.1.5 视图状态 63 3.1.6 XHTML兼容性 66 3.1.7 客户端控件ID 71 3.2 Web窗体处理阶段 73 3.2.1 页面框架初始化 74 3.2.2 用户代码初始化 74 3.2.3 验证 74 3.2.4 事件处理 75 3.2.5 自动数据绑定 75 3.2.6 清除 76 3.2.7 页面流示例 76 3.3 作为控件容器的页面 78 3.3.1 显示控件树 78 3.3.2 页头 82 3.3.3 动态控件的创建 82 3.4 Page类 84 3.4.1 Session、Application和Cache 84 3.4.2 Request 85 3.4.3 Response 86 3.4.4 Server 88 3.4.5 User 90 3.4.6 Trace 91 3.4.7 访问其他类的HTTP上下文 96 3.5 总结 96 第4章 服务器控件 97 4.1 服务器控件的类型 97 4.2 HTML服务器控件 99 4.2.1 HtmlControl类 100 4.2.2 HtmlContainerControl类 100 4.2.3 HtmlInputControl类 100 4.2.4 HTML服务器控件类 101 4.2.5 设置Style特性和其他属性 102 4.2.6 通过编程创建服务器控件 103 4.2.7 处理服务器端事件 104 4.3 Web控件 107 4.3.1 WebControl基类 107 4.3.2 基本的Web控件类 108 4.3.3 单位 109 4.3.4 枚举 110 4.3.5 颜色 110 4.3.6 字体 111 4.3.7 焦点 12 4.3.8 默认按钮 113 4.3.9 可滚动面板 114 4.3.10 处理Web控件事件 114 4.4 List控件 116 4.4.1 Selectable列表控件 117 4.4.2 BulletedList控件 120 4.5 输入验证控件 121 4.5.1 验证控件 121 4.5.2 验证流程 122 4.5.3 BaseValidator类 122 4.5.4 RequiredFieldValidator控件 124 4.5.5 RangeValidator控件 124 4.5.6 CompareValidator控件 125 4.5.7 RegularExpressionValidator控件 125 4.5.8 CustomValidator控件 127 4.5.9 ValidationSummary控件 128 4.5.10 通过编程使用验证器 129 4.5.11 验证组 130 4.6 富控件 132 4.6.1 AdRotator控件 132 4.6.2 Calendar控件 134 4.7 总结 136 第5章 ASP.NET应用程序 137 5.1 剖析ASP.NET应用程序 137 5.1.1 应用程序域 137 5.1.2 应用程序生命周期 138 5.1.3 应用程序更新 139 5.1.4 应用程序目录结构 139 5.2 global.asax应用程序文件 140 5.2.1 应用程序事件 141 5.2.2 演示应用程序事件 143 5.3 ASP.NET配置 144 5.3.1 machine.config文件 144 5.3.2 web.config文件 147 5.3.3 设置 150 5.3.4  150 5.3.5  150 5.3.6  152 5.3.7 通过编程读写配置节 152 5.3.8 网站管理工具(WAT) 155 5.3.9 扩展配置文件结构 156 5.3.10 加密配置节 159 5.4 .NET组件 161 5.4.1 创建组件 161 5.4.2 通过App_Code目录使用组件 162 5.4.3 通过Bin目录使用组件 163 5.5 扩展HTTP管道 165 5.5.1 HTTP处理程序 165 5.5.2 创建自定义的HTTP处理程序 167 5.5.3 配置自定义的HTTP处理程序 168 5.5.4 使用无须配置的HTTP处理程序 169 5.5.5 创建高级的HTTP处理程序 169 5.5.6 为非HTML内容创建HTTP处理程序 171 5.5.7 HTTP模块 173 5.5.8 创建自定义HTTP模块 174 5.6 总结 176 第6章 状态管理 177 6.1 ASP.NET状态管理 177 6.2 视图状态 179 6.2.1 视图状态示例 180 6.2.2 在视图状态保存对象 181 6.2.3 视图状态评估 183 6.2.4 有选择地禁用视图状态 184 6.2.5 视图状态安全 185 6.3 在页面间传送信息 186 6.3.1 查询字符串 187 6.3.2 跨页回发 188 6.4 cookie 193 6.5 会话状态 194 6.5.1 会话架构 194 6.5.2 使用会话状态 196 6.5.3 配置会话状态 197 6.5.4 会话状态安全 202 6.6 应用程序状态 203 6.7 总结 206 第二部分 数据访问 第7章 基础 208 7.1 ADO.NET架构 209 7.1.1 ADO.NET数据提供程序 209 7.1.2 ADO.NET的标准化 210 7.1.3 基本ADO.NET类 211 7.2 Connection类 212 7.2.1 连接字符串 212 7.2.2 测试连接 214 7.2.3 连接池 215 7.3 Command类和DataReader类 217 7.3.1 Command基础 217 7.3.2 DataReader类 218 7.3.3  ExecuteReader()方法和DataReader 218 7.3.4 ExecuteScalar()方法 223 7.3.5 ExecuteNonQuery()方法 223 7.3.6 SQL注入攻击 224 7.3.7 使用参数化命令 226 7.3.8 调用存储过程 227 7.4 事务 229 7.4.1 事务和ASP.NET应用程序 230 7.4.2 隔离级别 234 7.4.3 保存点 235 7.5 提供程序无关的代码 235 7.5.1 创建工厂 236 7.5.2 用工厂创建对象 237 7.5.3 使用提供程序无关的代码的查询 237 7.6 总结 239 第8章 数据组件和DataSet 240 8.1 构建数据访问组件 240 8.1.1 数据包 241 8.1.2 存储过程 242 8.1.3 数据应用类 243 8.1.4 测试数据库组件 248 8.2 非连接的数据 249 8.2.1 Web应用程序和DataSet 250 8.2.2 XML集成 251 8.3 DataSet类 251 8.4  DataAdapter类 252 8.4.1 填充DataSet 253 8.4.2 使用多个表和关系 254 8.4.3 查找特定行 257 8.4.4 在数据访问类里使用DataSet 257 8.4.5 数据绑定 258 8.5 DataView类 259 8.5.1 使用DataView排序 259 8.5.2 使用DataView过滤 261 8.5.3 使用关系的高级过滤 262 8.5.4 计算列 263 8.6 总结 264 第9章 数据绑定 265 9.1 基本的数据绑定 265 9.1.1 单值绑定 266 9.1.2 其他类型的表达式 268 9.1.3 重复值绑定 271 9.2 数据源控件 277 9.3 SqlDataSource 278 9.3.1 选择记录 279 9.3.2 参数化命令 281 9.3.3 错误处理 285 9.3.4 更新记录 286 9.3.5 删除记录 289 9.3.6 插入记录 289 9.3.7 SqlDataSource的不足 290 9.4 ObjectDataSource 291 9.4.1 选择记录 291 9.4.2 更新记录 295 9.4.3 使用数据对象执行更新 296 9.5 数据源控件的限制 299 9.5.1 问题 299 9.5.2 添加其他项 300 9.5.3 使用SqlDataSource处理其他选项 301 9.5.4 使用ObjectDataSource处理其他选项 301 9.6 总结 302 第10章 富数据控件 303 10.1 GridView 303 10.2 格式化GridView 307 10.2.1 格式化字段 307 10.2.2 样式 308 10.2.3 格式化特定值 311 10.3 GridView行选择 313 10.3.1 使用选择来创建主-从表单 314 10.3.2 SelectedIndexChanged事件 315 10.3.3 将数据字段用作选择按钮 315 10.4 对GridView排序 316 10.4.1 使用SqlDataSource排序 317 10.4.2 使用ObjectDataSource排序 318 10.4.3 排序和选择 319 10.4.4 高级排序 319 10.5 GridView分页 320 10.5.1 自动分页 320 10.5.2 分页和选择 322 10.5.3 ObjectDataSource的自定义分页 322 10.5.4 定制分页栏 324 10.6 GridView模板 325 10.6.1 使用多个模板 327 10.6.2 在Visual Studio编辑模板 328 10.6.3 绑定到方法 328 10.6.4 处理模板事件 330 10.6.5 使用模板编辑 330 10.6.6 模板的客户端ID 335 10.7 ListView 336 10.7.1 分组 338 10.7.2 分页 340 10.8 DetailsView和FormView 341 10.8.1 DetailsView 341 10.8.2 FormView 344 10.9 高级网格 345 10.9.1 GridView的汇总 345 10.9.2 单个表的父/子视图 347 10.9.3 使用查找表编辑字段 349 10.9.4 处理来自数据库的图片 351 10.9.5 探测并发冲突 355 10.10 总结 359 第11章 缓存和异步页面 360 11.1 理解ASP.NET缓存 360 11.2 输出缓存 361 11.2.1 声明性的输出缓存 361 11.2.2 缓存和查询字符串 362 11.2.3 使用特定查询字符串参数的缓存 363 11.2.4 自定义缓存控制 364 11.2.5 使用HttpCachePolicy类进行缓存 365 11.2.6 缓存后替换和部分页缓存 365 11.2.7 缓存用户配置 367 11.2.8 缓存配置 368 11.2.9 输出缓存扩展 369 11.3 数据缓存 373 11.3.1 向缓存添加项目 373 11.3.2 简单的缓存测试 375 11.3.3 缓存优先级 376 11.3.4 使用数据源控件的缓存 376 11.4 缓存依赖 379 11.4.1 文件和缓存项目依赖 379 11.4.2 聚合依赖 380 11.4.3 移除项目回调 381 11.4.4 理解SQL缓存通知 383 11.4.5 缓存通知的工作方式 384 11.4.6 启用通知 384 11.4.7 创建缓存依赖 385 11.5 自定义缓存依赖 386 11.5.1 基本的自定义缓存依赖 386 11.5.2 使用消息队列的自定义缓存依赖 387 11.6 异步页面 389 11.6.1 创建异步页面 390 11.6.2 在异步页面查询数据 392 11.6.3 错误处理 393 11.6.4 在异步任务使用缓存 395 11.6.5 多异步任务和超时 397 11.7 总结 399 第12章 文件和流 400 12.1 使用文件系统 400 12.1.1 Directory类和File类 400 12.1.2 DirectoryInfo类和FileInfo类 402 12.1.3 DriveInfo类 404 12.1.4 使用Attributes 405 12.1.5 使用通配符过滤文件 407 12.1.6 获取文件的版本信息 407 12.1.7 Path类 408 12.1.8 文件浏览器 410 12.2 使用流读写文件 414 12.2.1 文本文件 415 12.2.2 二进制文件 416 12.2.3 上传文件 417 12.2.4 使文件对多用户安全 419 12.2.5 压缩 423 12.3 序列化 423 12.4 总结 426 第13章 LINQ 427 13.1 LINQ基础 427 13.1.1 延迟执行 429 13.1.2 LINQ是如何工作的 429 13.1.3 LINQ表达式 430 13.1.4 揭秘LINQ表达式 436 13.2 LINQ to DataSet 439 13.2.1 强类型的DataSet 441 13.2.2 空值 441 13.3 LINQ to Entities 441 13.3.1 生成数据模型 442 13.3.2 数据模型类 442 13.3.3 实体关系 444 13.3.4 查询存储过程 446 13.3.5 LINQ to Entities查询揭秘 447 13.4 数据库操作 452 13.4.1 插入 452 13.4.2 更新 454 13.4.3 删除 454 13.4.4 管理并发 455 13.4.5 处理并发冲突 455 13.5 EntityDataSource控件 459 13.5.1 显示数据 459 13.5.2 获取关联数据 463 13.5.3 编辑数据 464 13.5.4 验证 464 13.6 使用QueryExtender控件 465 13.6.1 使用SearchExperssion 466 13.6.2 使用RangeExpression 467 13.6.3 使用PropertyExpression 467 13.6.4 使用MethodExpression 468 13.7 总结 468 第14章 XML 470 14.1 什么时候使用XML 470 14.2 XML简介 471 14.2.1 XML的优点 472 14.2.2 格式良好的XML 472 14.2.3 XML命名空间 473 14.2.4 XML架构 474 14.3 基于流的XML处理 475 14.3.1 写XML文件 476 14.3.2 读取XML文件 478 14.4 内存的XML处理 481 14.4.1 XmlDocument 482 14.4.2 XPathNavigator 485 14.4.3 XDocument 486 14.5 搜索XML内容 491 14.5.1 搜索XmlDocument 491 14.5.2 使用XPath搜索XmlDocument 493 14.5.3 使用LINQ搜索XDocument 494 14.6 验证XML内容 496 14.6.1 基本架构 496 14.6.2 验证XmlDocument 497 14.6.3 使用XDocument进行验证 498 14.7 转换XML内容 499 14.7.1 基本的样式表 499 14.7.2 使用XslCompiledTransform 500 14.7.3 使用Xml控件 501 14.7.4 使用LINQ to XML转换XML 502 14.8 XML数据绑定 504 14.8.1 非层次化绑定 504 14.8.2 使用XPath 506 14.8.3 嵌套的网格 508 14.8.4 使用TreeView的层次化绑定 509 14.8.5 使用XSLT 511 14.8.6 绑定到来自其他源的XML内容 512 14.8.7 通过XmlDataSource更新XML 513 14.9 XML和ADO.NET数据集 513 14.9.1 把DataSet转换为XML 514 14.9.2 把DataSet作为XML访问 515 14.10 总结 517 第三部分 构建ASP.NET网站 第15章 用户控件 520 15.1 用户控件基础 520 15.1.1 创建简单的用户控件 521 15.1.2 把页面转换成用户控件 522 15.2 为用户控件添加代码 523 15.2.1 处理事件 523 15.2.2 添加属性 524 15.2.3 使用自定义对象 525 15.2.4 添加事件 528 15.2.5 公开内部Web控件 530 15.3 动态加载用户控件 531 15.4 局部页面缓存 534 15.4.1 VaryByControl 535 15.4.2 共享缓存控件 536 15.5 总结 537 第16章 主题和母版页 538 16.1 层叠样式表 538 16.1.1 创建样式表 538 16.1.2 应用样式表规则 540 16.2 主题 542 16.2.1 主题文件夹和外观 543 16.2.2 应用简单主题 544 16.2.3 处理主题冲突 545 16.2.4 为同一控件创建多个外观 546 16.2.5 含有模板和图片的外观 547 16.2.6 在主题里使用CSS 549 16.2.7 通过配置文件来应用主题 549 16.2.8 动态应用主题 550 16.3 标准化网站布局 551 16.4 母版页基础 552 16.4.1 简单的母版页 552 16.4.2 简单的内容页 554 16.4.3 默认内容 556 16.4.4 具有表格和CSS布局的母版页 556 16.4.5 母版页和相对路径 559 16.4.6 通过配置文件应用母版页 559 16.5 高级母版页 560 16.5.1 和母版页类交互 560 16.5.2 动态设置母版页 561 16.5.3 嵌套母版页 561 16.6 总结 563 第17章 网站导航 564 17.1 多视图页面 564 17.1.1 MultiView控件 565 17.1.2 Wizard控件 568 17.2 站点地图 575 17.2.1 定义站点地图 576 17.2.2 绑定站点地图 577 17.2.3 导航路径 578 17.2.4 显示站点地图的一部分 580 17.2.5 站点地图对象 583 17.2.6 加入自定义站点地图信息 584 17.2.7 创建自定义的SiteMapProvider 584 17.2.8 安全调整 590 17.3 URL映射和路由 592 17.3.1 URL映射 592 17.3.2 URL路由 593 17.4 TreeView控件 594 17.4.1 TreeNode 595 17.4.2 按需填充节点 597 17.4.3 TreeView样式 598 17.5 Menu控件 601 17.5.1 Menu样式 603 17.5.2 Menu模板 605 17.6 总结 606 第18章 网站部署 607 18.1 安装和配置IIS 607 18.1.1 安装IIS 7 607 18.1.2 管理IIS 7 608 18.2 部署网站 610 18.2.1 通过复制文件进行部署 611 18.2.2 使用Web部署 614 18.2.3 通过FTP部署 621 18.3 管理网站 626 18.3.1 创建新站点 626 18.3.2 创建虚拟目录 627 18.3.3 使用VirtualPathProvider 628 18.3.4 使用应用程序池 631 18.3.5 使用应用程序预热 633 18.4 扩展集成管道 634 18.4.1 创建处理程序 634 18.4.2 部署处理程序 635 18.4.3 配置处理程序 635 18.4.4 测试处理程序 636 18.5 总结 636 第四部分 安全 第19章 ASP.NET安全模型 638 19.1 为何创建安全软件 638 19.1.1 理解潜在的威胁 638 19.1.2 安全编程原则 639 19.1.3 理解Gatekeeper 640 19.2 理解安全级别 641 19.2.1 验证 641 19.2.2 授权 642 19.2.3 机密性和完整性 643 19.2.4 互相协作 643 19.3 理解SSL 644 19.3.1 理解证书 645 19.3.2 理解SSL 645 19.3.3 在IIS 7.x配置SSL 646 19.4 总结 649 第20章 表单验证 650 20.1 表单验证介绍 650 20.1.1 为什么使用表单验证 650 20.1.2 为什么不使用表单验证 652 20.1.3 为什么不自己实现cookie验证 653 20.1.4 表单验证类 654 20.2 实现表单验证 655 20.2.1 配置表单验证 655 20.2.2 禁止匿名用户访问 657 20.2.3 创建自定义登录页面 658 20.2.4 自定义凭证存储 662 20.2.5 表单验证的持久化cookie 663 20.3 IIS 7.x和表单验证 665 20.4 总结 669 第21章 成员资格 670 21.1 介绍ASP.NET的成员资格API 670 21.2 使用成员资格API 672 21.2.1 配置表单验证 673 21.2.2 创建数据存储 674 21.2.3 配置连接字符串和成员资格提供程序 679 21.2.4 创建并验证用户 681 21.3 使用安全控件 683 21.3.1 Login控件 684 21.3.2 LoginStatus控件 693 21.3.3 LoginView控件 693 21.3.4 PasswordRecovery控件 694 21.3.5 ChangePassword控件 697 21.3.6 CreateUserWizard控件 698 21.4 在IIS 7.x里配置成员资格 702 21.4.1 配置提供程序和用户 702 21.4.2 在其他应用程序里使用成员资格API 703 21.5 使用Membership类 705 21.5.1 从存储获得用户 706 21.5.2 更新存储的用户 708 21.5.3 创建和删除用户 708 21.5.4 检验用户 709 21.6 总结 709 第22章 Windows验证 710 22.1 介绍Windows验证 710 22.1.1 为什么使用Windows验证 710 22.1.2 为什么不使用Windows验证 711 22.1.3 Windows验证机制 712 22.2 实现Windows验证 717 22.2.1 配置IIS 7.x 717 22.2.2 配置ASP.NET 718 22.2.3 IIS 7.x管道 719 22.2.4 禁止匿名用户访问 722 22.2.5 访问Windows用户信息 723 22.3 身份模拟 727 22.3.1 Windows的身份模拟和委托 728 22.3.2 经过配置的身份模拟 729 22.3.3 可编程的身份模拟 729 22.4 总结 732 第23章 授权和角色 733 23.1 URL 授权 733 23.2 文件授权 738 23.3 在代码检查授权 739 23.3.1 使用IsInRole()方法 739 23.3.2 使用PrincipalPermission类 740 23.4 为基于角色的授权使用角色API 742 23.4.1 和角色一起使用LoginView控件 747 23.4.2 通过编程访问角色 748 23.4.3 在Windows验证使用角色API 750 23.5 IIS 7.x里的授权和角色 752 23.5.1 在IIS 7.x里使用ASP.NET角色授权 754 23.5.2 在IIS 7.x管理ASP.NET角色 756 23.6 总结 757 第24章 用户配置 758 24.1 理解用户配置 758 24.1.1 用户配置的性能 758 24.1.2 用户配置如何存储数据 759 24.1.3 用户配置和验证 760 24.1.4 用户配置与自定义的数据组件 760 24.2 使用SqlProfileProvider 761 24.2.1 创建用户配置表 761 24.2.2 配置提供程序 763 24.2.3 定义用户配置属性 764 24.2.4 使用用户配置属性 764 24.2.5 用户配置序列化 766 24.2.6 用户配置组 767 24.2.7 用户配置和自定义的数据类型 768 24.2.8 用户配置API 771 24.2.9 匿名用户配置 773 24.3 自定义的用户配置提供程序 775 24.3.1 自定义的用户配置提供程序类 775 24.3.2 设计FactoredProfileProvider 777 24.3.3 通过编码实现FactoredProfileProvider 778 24.3.4 测试FactoredProfileProvider 781 24.4 总结 784 第25章 加密 785 25.1 加密数据:机密性问题 785 25.2 .NET加密命名空间 786 25.3 理解.NET加密类 789 25.3.1 对称加密算法 790 25.3.2 非对称加密 791 25.3.3 抽象加密类 791 25.3.4 ICryptoTransform接口 792 25.3.5 CryptoStream类 793 25.4 加密敏感数据 793 25.4.1 管理秘密信息 794 25.4.2 使用对称算法 795 25.4.3 使用非对称算法 799 25.4.4 加密数据库的敏感数据 801 25.5 加密查询字符串 806 25.5.1 包装查询字符串 806 25.5.2 创建一个测试页面 808 25.6 总结 810 第26章 自定义成员资格提供程序 811 26.1 自定义提供程序的架构 811 26.2 创建自定义提供程序的基本步骤 812 26.2.1 自定义提供程序的总体设计 813 26.2.2 设计并实现自定义存储 813 26.2.3 实现提供程序类 820 26.2.4 使用自定义提供程序类 837 26.3 总结 840 第五部分 高级用户界面 第27章 自定义服务器控件 842 27.1 自定义服务器控件入门 842 27.1.1 创建简单的自定义控件 842 27.1.2 使用自定义控件 844 27.1.3 工具箱的自定义控件 845 27.1.4 创建支持样式属性的Web控件 847 27.1.5 呈现过程 850 27.2 处理不同的浏览器 852 27.2.1 HtmlTextWriter 852 27.2.2 浏览器检测 852 27.2.3 浏览器属性 853 27.2.4 覆盖浏览器类型侦测 854 27.2.5 自适应呈现 855 27.3 控件状态和事件 856 27.3.1 视图状态 856 27.3.2 控件状态 858 27.3.3 回传数据和change事件 860 27.3.4 触发回传 862 27.4 扩展现有的Web控件 863 27.4.1 组合控件 864 27.4.2 派生控件 866 27.5 总结 869 第28章 图形、GDI+和图表 870 28.1 ImageMap控件 870 28.1.1 创建热点 871 28.1.2 处理热点单击 872 28.1.3 自定义热点 873 28.2 使用GDI+画图 875 28.2.1 简单绘制 875 28.2.2 图像格式和质量 877 28.2.3 Graphics类 878 28.2.4 使用GraphicsPath 880 28.2.5 画笔 881 28.2.6 画刷 883 28.3 在网页上嵌入动态图形 885 28.3.1 使用PNG格式 885 28.3.2 传递信息给动态图像 886 28.3.3 使用GDI+的自定义控件 888 28.4 使用Chart控件 892 28.4.1 创建基本的图表 892 28.4.2 用数据填充图表 897 28.5 总结 904 第29章 JavaScript和Ajax技术 905 29.1 JavaScript本质 905 29.1.1 HTML DOM 906 29.1.2 客户端事件 906 29.1.3 脚本块 908 29.1.4 操纵HTML元素 910 29.1.5 调试JavaScript 910 29.2 基本的JavaScript示例 912 29.2.1 创建JavaScript页面处理器 912 29.2.2 使用JavaScript异步下载图片 915 29.2.3 呈现脚本块 919 29.3 脚本注入攻击 920 29.3.1 请求验证 921 29.3.2 禁用请求验证 922 29.3.3 扩展请求验证 923 29.4 带有JavaScript的自定义控件 925 29.4.1 弹出窗口 925 29.4.2 滚动按钮 928 29.5 框架 931 29.5.1 框架导航 932 29.5.2 内联框架 933 29.6 理解Ajax 934 29.6.1 XMLHttpRequest对象 935 29.6.2 Ajax示例 936 29.7 在客户端回调使用Ajax 939 29.7.1 创建客户端回调 940 29.7.2 深入了解客户端回调 945 29.7.3 自定义控件里的客户端回调 946 29.8 总结 949 第30章 ASP.NETAJAX 950 30.1 介绍ASP.NETAJAX 950 30.1.1 客户端的ASP.NETAJAX:脚本库 951 30.1.2 服务器端的ASP.NETAJAX:ScriptManager 952 30.2 服务器回调 952 30.2.1 ASP.NETAJAX的Web服务 953 30.2.2 在页面里放置Web方法 959 30.2.3 ASP.NETAJAX应用程序服务 960 30.3 ASP.NETAJAX服务器控件 966 30.3.1 使用UpdatePanel的局部呈现 966 30.3.2 使用Timer定时刷新 973 30.3.3 使用UpdateProgress的耗时更新 974 30.3.4 管理浏览器历史 976 30.4 深入客户端库 979 30.4.1 理解客户端模型 980 30.4.2 JavaScript的面向对象编程 981 30.4.3 网页框架 987 30.5 控件扩展器 991 30.5.1 安装ASP.NETAJAX控件工具包 992 30.5.2 AutoCompleteExtender 993 30.5.3 ASP.NETAJAX控件工具包 996 30.6 总结 999 第31章 使用Web部件页面的门户网站 1000 31.1 典型门户页面 1000 31.2 基本Web部件页面 1002 31.2.1 创建页面设计 1002 31.2.2 WebPartManager和WebPartZone 1003 31.2.3 向页面添加Web部件 1004 31.2.4 定制页面 1008 31.3 创建Web部件 1010 31.3.1 简单的Web部件任务 1010 31.3.2 开发高级Web部件 1017 31.3.3 Web部件编辑器 1024 31.3.4 连接Web部件 1029 31.3.5 自定义动词和Web部件 1036 31.3.6 用户控件和高级Web部件 1037 31.3.7 动态上传Web部件 1040 31.3.8 对Web部件的授权 1044 31.3.9 个性化的最后任务 1045 31.4 总结 1046 第32章 MVC 1047 32.1 MVC和Web表单的选择 1047 32.2 创建基本的MVC应用程序 1047 32.2.1 创建模型 1048 32.2.2 创建控制器 1049 32.2.3 创建Index视图 1050 32.2.4 测试(未完成的)应用程序 1050 32.2.5 完成控制器和视图 1051 32.2.6 修改Site.Master文件 1053 32.3 扩展基础的MVC应用程序 1053 32.3.1 配置路由 1054 32.3.2 增加错误处理 1055 32.3.3 增加验证 1056 32.3.4 增强数据存储访问 1057 32.3.5 增加对外键约束的支持 1059 32.4 自定义视图 1059 32.4.1 修改视图 1060 32.4.2 增加视图数据 1062 32.5 强化模型 1063 32.6 验证数据 1066 32.6.1 执行基本的验证 1067 32.6.2 增加验证标注 1068 32.7 使用动作结果 1071 32.7.1 返回JSON数据 1072 32.7.2 调用其他控制器方法 1072 32.8 总结 1074 第33章 动态数据 1075 33.1 创建动态数据应用程序 1075 33.1.1 创建动态数据网站 1075 33.1.2 检验动态数据网站 1077 33.2 深入理解动态数据项目 1080 33.3 自定义动态数据网站 1080 33.3.1 使用模板进行自定义 1081 33.3.2 使用路由进行自定义 1087 33.3.3 使用元数据进行自定义 1094 33.3.4 自定义验证 1099 33.4 总结 1103 第34章 Silverlight 1104 34.1 理解Silverlight 1105 34.1.1 Silverlight与Flash对比 1106 34.1.2 Silverlight系统需求 1107 34.2 创建Silverlight解决方案 1108 34.2. 1 Silverlight编译 1109 34.2.2 入口页面 1110 34.3 创建Silverlight项目 1114 34.3.1 设计Silverlight页面 1114 34.3.2 理解XAML 1117 34.3.3 设置属性 1118 34.3.4 XAML 代码隐藏 1119 34.3.5 处理事件 1120 34.3.6 了解Silverlight类库 1121 34.4 布局 1122 34.4.1 Canvas 1123 34.4.2 网格 1127 34.5 动画 1131 34.5.1 动画基础知识 1132 34.5.2 定义动画 1132 34.5.3 StoryBoard类 1133 34.5.4 交互式动画实例 1135 34.5.5 变换 1138 34.6 Silverlight使用Web服务 1141 34.6.1 创建Web服务 1141 34.6.2 添加Web引用 1142 34.6.3 调用Web服务 1143 34.6.4 配置Web服务URL 1144 34.6.5 跨域Web服务调用 1144 34.7 总结 1146
ExtAspNet v2.2.1 ExtAspNet是一组专业的Asp.net控件库,拥有原生的AJAX支持和丰富的UI效果, 目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。 支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+ 注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。 示例: http://extasp.net/ 开源: http://extaspnet.codeplex.com/ 博客: http://sanshi.cnblogs.com/ 邮箱: sanshi.ustc@gmail.com 发布历史: +2010-03-28 v2.2.1 +为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。 -隐藏示例首页最外层RegionPanel的边框ShowBorder="false"。 +集成Extjs最新版本v3.1.1。 -增加一个新的Theme - Access。 -修正了Firefox下Zoom In/Out时页面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax提交)(feedback:261629698)。 +TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。 -增加示例tabstrip/tabstrip_addtab.aspx。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window控件更新。 -关闭按钮默认直接关闭,不会弹出确认对话框。 -GetConfirmFormModifiedHideReference的函数的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居,而不是黄金分割位置。 +Button, Window等控件弹出位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后一个参数target变为枚举类型。 -Alert.GetShowReference的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Extjs最新版本v3.1.0。 -修正灰色皮肤的CSS问题。 -修正Grid的列名不能包含文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏ExtAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其的Close全部改为Hide。 -增加TabStripTab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocumentIcon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时会出现空白页面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid的一个JS问题(feedback:lqm4108)。 -修正Alert消息引号未编码导致的JS错误(feedback:sun1299shine)。 +集成extjs3.0.3。 -修正弹出对话框的宽度计算错误(会保持最小的状态)。 -增加新的皮肤Gray。 -为示例工程添加改变语言和皮肤的下拉列表。 -为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。 +2009-12-01 v2.1.7 -增加示例(iframe/parent_postback_run3.aspx),如何通过简单的Javascript代码回发父页面(feedback:eroach)。 -修正一些书写错误(feedback:bmck)。 -从Region控件删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加国的省市县三级联动示例(data/shengshixian.aspx)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程会重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。 +2009-11-26 v2.1.6 +修正动态创建Grid列的BUG(feedback:gxpan)。 -增加示例(data/grid_dynamic_columns.aspx)。 -修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。 -增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。 -为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。 -重新设计模拟树的下拉列表的实现,避免选某项后的闪烁。 +2009-11-21 v2.1.5 +Tree优化。 -修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。 -GetNodeById更名为FindNode,保持和FindControl一致命名。 -删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。 -删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。 -增加示例(data/tree_select_run.aspx),如何选当前节点的所有子节点(feedback:wjl_wjl520)。 +TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet的一个命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。 -增加示例(other/custom_postback.aspx)(feedback:thebox)。 -如何自定义Javascript脚本和C#处理函数来响应键盘事件。 -为Tree增加AutoLeafIdentification属性。 -增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。 +2009-11-17 v2.1.4 -修正Window的关闭按钮提示信息一直是文的BUG(feedback:thebox)。 -部分ExtAspNet控件的设计时支持(会在后续版本逐步完善)。 -v0.2beta2版本关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。 -修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。 +为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.aspx +2009-10-19 v2.1.3 +增加支持在AJAX时改变的控件属性列表(/ajax.aspx)。 -ExtAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程会反映到页面,但并不是所有的控件属性都支持AJAX改变。 -加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保Asp.net的按钮控件仍然具有AJAX的特性。 -更新/basic/login.aspx示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.aspx(feedback:chenguizhu2006)。 -为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。 -GridTemplateField生成到页面控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。 -修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。 -增加pt_BR语言,由Ujvari提供。 +为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其包含1700多个小图标。 -如果Panel具有IconUrl属性,则IconUrl优先于Icon。 -所有Icon的列表在icon.aspx。 -为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。 +2009-09-15 v2.1.1 -修正不能动态修改AccordionPane属性Items的BUG。 +为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。 -如果需要在父页面弹出确认对话框,需要设置ConfirmTarget="_parent"(类似Window控件的Target="_parent")。 +为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。 -一个典型应用,在Window控件打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。 -ExtAspNet.Alert.Show("参数错误!", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference()); +TreeNode的前面的多选框可以自动回发了。 -为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://extasp.net/data/tree_run.aspx -Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选任何一项时在父页面弹出对话框的JS代码。 -修正IE7下不能以下划线作为CSS类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree控件的AJAX实现。 +为页面的Form添加autocomplete="off"属性。 -参考http://www.cnblogs.com/sanshi/archive/2009/09/04/1560146.html#1635830 +添加对extjs3.0所有语言的支持。 -ExtAspNet扩展的多语言包在js\languages\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现 -你可以向其添加自己的语言版本,并执行js\languages下的pack.bat打包,最后编译工程。 +2009-09-01 v2.0.9 -为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。 +在aspx页面必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。 -这将会影响所有的aspx页面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将会影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config修改。 -将所有的示例转化为英语版本。 -修正Tree控件的一个BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。 -这个BUG导致Asp.net compatibility的示例无法完成,现在已经修正。 +去除PageManager方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。 -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility的示例。 +2009-08-25 v2.0.7 -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。 -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid每个单元格的值了。 -增加示例-如何将Grid控件导出为Excel(data\grid_excel_run.aspx)(feedback:503684912)。 -如果TreeNode的属性Enabled="false",则此项变灰并且不会被选(feedback:your568)。 -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~/开头)的BUG。 -增加Accordion和Tree配合使用的示例(other\accordion_tree_run.aspx)。 -修正Panel图标不能显示的BUG(CSSclass名不能有$字符)。 +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。 -简单方便,示例可以参考 default.aspx 或者 other\accordion_tree_run.aspx。 +2009-08-14 v2.0.6 -动态生成菜单实例(other\menu_dynamic_run.aspx和other\menu_dynamic2_run.aspx)(feedback:shguo)。 -优化AJAX的内部实现,每个页面保存的ViewState现在减少1/3左右(重要更新)。 -优化Tree节点的NodeId自动生成,减少ViewState占用。 +2009-08-09 v2.0 beta5 +ExtAspNet和Asp.net的提交按钮兼容问题(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们做了优化,现在要使一个Asp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load设置需要在AJAX需要更新的Asp.net控件了。 -在Page_Load设置了哪些需要在AJAX更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。 -示例在aspnet\fckeditor_run.aspx和aspnet\aspnet_run.aspx。 -FCKEditor和上传控件兼容。示例在aspnet\fileupload_run.aspx。 -修正ToolbarText的文本在AJAX下更新的BUG。 -Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。 -更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。 +2009-08-02 v2.0 beta4 +和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。 -采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。 -现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.PageContext.Redirect重定向页面,两者效果一样。 -支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。 -Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。 -修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。 -修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。 -增加Menu和Accordion的示例。 -修正Window控件的IconUrl有时不显示(Target="_parent")的BUG[feedback:xmq&mgzhenhong]。 +2009-07-22 v2.0 beta3 -兼容FCKEditor。 -在IE8.0,Firefox3.5下测试通过。以后ExtAspNet将不会对IE6.0提供支持。 +2009-07-13 v2.0 beta2 -集成extjs最新版本v3.0。 +兼容IE6.0-7.0-8.0。 -这应该是Extjs3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新extjs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。 -ExtAspNet自身的CSS会紧挨着页面标签引入,这样在<head><em>中</em>自定义的样式可以覆盖Ext<em>Asp</em>Net缺省样式。 +Alert对话框会遮挡所有的Window窗口。 -使用一个变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选<em>中</em>第一项。 -重新绑定模拟树的下拉列表后,选<em>中</em>项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed] -Window<em>中</em>的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed] -页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例<em>asp</em>net/fileupload.<em>asp</em>x)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(Ext-Window)含有<em>ASP</em>.NET控件FileUpload,则此弹出窗口在关闭时出现JS错误(http://extjs.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果页面<em>中</em>存在<em>ASP</em>.NET控件(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed] -页面上放置Ext<em>Asp</em>Net-Button和<em>ASP</em>.NET-Button,则点击Ext<em>Asp</em>Net-Button时激发的是<em>ASP</em>.NET-Button的<em>事件</em>,这个BUG和Extjs2.2.1<em>中</em>Ext.Ajax.serializeForm的<em>实现</em>有关。[fixed] -Ext<em>Asp</em>Net内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added] +如果以前你听过不要在Ext<em>Asp</em>Net工程<em>中</em>使用<em>ASP</em>.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在Ext<em>Asp</em>Net控件和<em>ASP</em>.NET标准控件和平共处了。[fixed] -如果一个<em>ASP</em>.NET按钮控件要使用Ext<em>Asp</em>Net的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次Ext<em>Asp</em>Net的原生AJAX回发时更新<em>ASP</em>.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:<em>asp</em>net/<em>asp</em>net.<em>asp</em>x)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed] -<em>自动</em>测试功能会在以后版本<em>中</em>逐步完善。这个版本完成测试框架,采用Extjs<em>中</em>JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。 -PageContext静态类<em>中</em>的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面<em>中</em>表单修改的确认提示框的脚本”。 ---[updated]删除PageContext<em>中</em>的GetConfirmFormModifiedReference,使用CurrentActiveWindow<em>中</em>的GetConfirmFormModifiedCloseReference/GetConfirmFormModifiedCloseRefreshReference/GetConfirmFormModifiedClosePostBackReference三个方法代替。 -不会修改弹出页面的URL(Ext-Window<em>中</em>的IFrame),以前为了<em>实现</em>功能为每个弹出页面添加box_parent_client_id查询字符串 -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能<em>实现</em>为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的<em>ASP</em>X页面<em>中</em>查找RegisterPageStateChangedScript属性,并删除,否则会运行错误! -A页面有Ext-Window控件弹出B页面,B页面有Ext-Window控件弹出C页面,B页面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C页面)会覆盖整个A页面,这是正确的。 ---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不会出错了。 -Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面<em>中</em>表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。 ---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。 -如果弹出窗口(Window控件)<em>中</em>IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。 ---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window控件的IFrameName属性是<em>自动</em>生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel<em>中</em>内容不能<em>自动</em>扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed] -DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed] -升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed] -页面加载过程<em>中</em>的时间信息保存在Javascript变量window.box.timeInfo<em>中</em>。[added] +增加部分<em>自动</em>测试支持(使用WatiN和NUnit),下个版本将会提供完整的<em>自动</em>测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选<em>中</em>任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageContext优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其<em>中</em>target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image控件增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包<em>中</em>增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +TabStrip的Tab控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed] -有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-<em>asp</em>net-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemText/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new Ext<em>Asp</em>Net.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选<em>中</em>[feedback:jqpeng]。 -和<em>Asp</em>.net<em>中</em>的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列表项。 -处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会<em>自动</em>设置为false(避免开发人员发生此类错误)。[fixed] -注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS<em>中</em>的height不同,CSS<em>中</em>的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有控件属性增加在VS<em>中</em>的智能提示。[fixed] -需要将Ext<em>Asp</em>Net.XML和Ext<em>Asp</em>Net.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。 +控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:一个属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink<em>实现</em>为控件。[fixed] -可以方便的在子页面(iframe)<em>中</em>通过js切换父页面<em>中</em>选<em>中</em>的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.<em>asp</em>x,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的动态添加控件,并且可以给控件添加服务器端<em>事件</em>(示例在form/form_dynamic_run.<em>asp</em>x)。[fixed] +2008-10-15 v1.2 beta5 -验证表单字段的ValueToCompare属性,为字符串时会出错的BUG。[fixed] +优化下拉列表。[fixed] -验证下拉列表时,应该取ListItem的Value属性进行验证,而不是Text属性。 -DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。 -DropDownList不支持EmptyText属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(<em>ASP</em>X)<em>中</em>设置哪些项不可选择,以及创建模拟下拉树。 -DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则<em>自动</em>将EnableSimulateTree设置为true。 +2008-09-27 v1.2 beta4 +EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other/accordion_run.<em>asp</em>x)。[fixed] -Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。 -影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。 -AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed] +AccordionPanel增加Links属性,可以绑定列表数据到AccordionPanel,呈现的是链接的列表(示例在other/accordion_links_run.<em>asp</em>x)。[fixed] -原来放置在AccordionPanel<em>中</em>的容器,比如ContentPanel需要在外层加上<Items>标签。 -适当增大AccordionPanel<em>中</em>链接的高度20px->22px,同时对链接的样式也做了微调。 -通过BodyPadding控制链接列表的边距。 -这样能大大减少<em>ASP</em>X<em>中</em>HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在<em>ASP</em>X页切换到“设计时”,方便属性的更改和<em>事件</em>处理函数的添加)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -TabStrip/Toolbar -TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form<em>中</em>动态添加控件的BUG,现在form/form_dynamic_run.<em>asp</em>x示例已经能正确运行。[fixed] +大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed] -影响的控件包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留TabStrip的Tabs(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选<em>中</em>项(SelectedRowIndexArray)在ajax回发过程<em>中</em>存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选<em>中</em>项<em>中</em>会存在当前不存在的行序号,导致服务器端遍历选<em>中</em>项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例<em>中</em>表单控件都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/Label/Image/LinkButton/TextBox -TriggerBox/TwinTriggerBox/Window/TextArea/HtmlEditor/DatePicker/NumberBox -CheckBox/RadioButton/RadioButtonList/DropDownList -Grid +2008-09-19 v1.2 beta1 -Image/LinkButton/HyperLink增加一些Ajax可更新属性。[fixed] +隐藏的方式由HideMode属性控制Visibility/Offsets/Display。[fixed] -修正Form/SimpleForm<em>中</em>隐藏一个表单字段(Hidden=false)会占据页面空间的BUG。 -ToolbarText/ToolbarFill/ToolbarSeparator在<em>ASP</em>X<em>中</em>设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报<em>中</em>可以用自定义样式<em>实现</em>,而不应该写在控件<em>中</em>。[fixed] -网报:CssClass="toolbar-pagemenu" CssStyle="border:0px;",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(../images/pagemenu_toolbar_background.gif) repeat-x left top;}。 -Region去除默认的Layout=Fit,如果希望Region使用Fit/Anchor/Column/Row等布局的话,需要手工指定。[fixed] -ToolbarSeparator/ToolbarFill在Ajax更新Hidden属性的BUG。[fixed] +布局整理。[fixed] -新增Column/Absolute/Row三种布局,加上以前的Container/Fit/Anchor/Accordion/Border/Form六种布局,总共有9<em>中</em>布局可供使用。 -其<em>中</em>一些控件默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/TabStrip(Card),所有布局控件默认的布局是Container。 -经常用到的布局控件:SimpleForm/Form/Accordion/TabStrip/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的Ext<em>Asp</em>Net控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。 -US的Ext<em>Asp</em>Net改造强烈依赖于此属性,这个版本发布后可以继续。 -网报<em>中</em>唯一没有用到Ext<em>Asp</em>NetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageContext.Redirect支持普通页面转向和Ext<em>Asp</em>NetAjax下页面转向。[fixed] +模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。 -解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) >= 0){ok}。 -DropDownList在Ajax时应该先更新数据再设置选定项 [feedback:xmzhu]。[fixed] -Button/MenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed] -Tree的Ajax支持(尚需优化)。[fixed] +2008-09-02 v1.1 beta5 -DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed] -模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有数据也需要设置DataTextField/DataValueField/DataSimulateTreeLevelField/DataEnableSelectField等属性的值,否则Ajax回发时会出错)。[fixed] -UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用<em>Asp</em>netAjax,这个控件已经完成使命)。[fixed] -不要使用<em>Asp</em>.net的控件HiddenField,而是使用Ext<em>Asp</em>Net的HiddenField,因为<em>Asp</em>.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList<em>中</em>项如果存在汉字,则会换行的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab<em>中</em>如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个问题。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第一个Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config<em>中</em>增加配置项FormLabelWidth="80"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm/Form的表单字段标题的宽度。[fixed] +完善Ajax。[fixed] -RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue/SelectedItem)。 -DropDownList增加Ajax可更新属性Enable/SelectedIndex(SelectedValue/SelectedItem)/DataSource。 -Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。 -ToolbarText增加Ajax可更新属性Text。 +2008-08-31 v1.1 beta3 -TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。 -基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。 -整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。 -网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window控件是否弹出的状态在回发时维持。[fixed] -控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃<em>Asp</em>.NetAjax,Ext<em>Asp</em>Net控件内置Ajax支持。[fixed] -这是一个值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和<em>Asp</em>.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager<em>中</em>有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击一个按钮弹出窗口,可以在Button的OnClick<em>事件</em><em>中</em>设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的做法是尽量用客户端<em>实现</em>,客户端<em>实现</em>复杂的直接用服务器端<em>实现</em>。 +目前Ext<em>Asp</em>NetAjax的限制。 -只对Ext<em>Asp</em>Net控件起作用,对<em>Asp</em>.net控件不起作用。 -对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。 -对改变控件的Visible属性会有错误。 -Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading控件。[fixed] -Grid<em>中</em>的回发<em>事件</em>(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选<em>中</em>的状态在回发后会得到保持。[fixed] -Grid选<em>中</em>行的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。 -主要是父页面加载一个比较大的css文件(~100k),则每次打开iframe页面,onload<em>事件</em>的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹出窗口<em>中</em>IFrame的显示速度。[fixed] -在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报<em>中</em>需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config<em>中</em>设置(推荐方法),也可以为每个页面设置。[fixed] -一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器<em>中</em>Cookie设置的值)(示例在default.<em>asp</em>x)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +TabStrip<em>中</em>非当前Tab会延迟渲染。[fixed] -这会明显加快页面的渲染速度,网报<em>中</em>一个典型的费用审批页面可以减少200ms的渲染时间。 -由于非当前Tab不会在页面加载时渲染,所以那些Tab<em>中</em>的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render<em>事件</em><em>中</em>。 -不能比较两个DataPicker大小的BUG。[fixed] -TabStrip延迟加载引起的BUG(非当前Tab<em>中</em>的ContentPanel会占据页面空间,已修正)。[fixed] -全新的Ext<em>Asp</em>Net.Examples(基础知识/表单控件/数据绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame页面<em>中</em>使用父页面的脚本和样式(示例在iframe/default.<em>asp</em>x和iframe/page3.<em>asp</em>x)。[fixed] -测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout<em>中</em>显示不了的BUG [feedback:zgjiang2]。[fixed] +extjs的BUG,当页面<em>中</em>含有iframe时,Ext.onReady会被调用两次(IE6/IE7)(http://www.extjs.net/forum/showthread.php?t=43246)(示例在test.<em>asp</em>x)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发页面再弹出IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种做法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference("./simpleform.<em>asp</em>x"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下会有JS错误。[fixed] -增加BorderLayout控件,示例在iframe/borderlayout.<em>asp</em>x。[fixed] +Radiobuttonlist显示有重影(示例在radio.<em>asp</em>x)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -动态向Form<em>中</em>添加FormRow,并动态的向FormRow<em>中</em>添加表单字段,以及如何取得表单字段的值。(示例在form_dynamic.<em>asp</em>x)[fixed] +IFrame弹出窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是一个重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window<em>中</em>的IFrame被添加到页面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.<em>asp</em>x) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下会有JS错误。[fixed] -Window的右上角关闭图标增加提示,优化<em>事件</em>响应。[fixed] -Window的代码重构。[fixed] +修正一个的内存泄漏。[fixed] -IE7下测试,打开iframe/default.<em>asp</em>x页面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.<em>asp</em>x页面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.<em>asp</em>x页面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE会<em>自动</em>进行垃圾回收。 +2008-08-12 v0.4 beta3 -底层的javascript框架Extjs升级为v2.2,Grid的渲染速度有很大提升。[fixed] -Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight="true"解决)。[fixed] +页面正在加载的提示尽早的显示出来。[fixed] -首先在执行js来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示出来。 -加载js脚本的script标签放置在页面的最后,放置加载js而阻塞PageLoading的显示。 +2008-08-08 v0.4 beta2 -TabStrip延时加载出错。[fixed] -Window的IFrameUrl处理的BUG,比如Pages_Ext<em>Asp</em>Net目录下的页面应该为./FE_ApplyEditor.<em>asp</em>x或~/Pages_Ext<em>Asp</em>Net/FE_ApplyEditor.<em>asp</em>x。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则会JS错误。[fixed] -<em>实现</em>网报首页下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed] -优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.<em>asp</em>x默认会加载form.<em>asp</em>x页面(Window控件的BUG)。[fixed] -Window<em>中</em>的保存并关闭按钮和<em>Asp</em>.netAjax冲突。[fixed] -优化关闭Window的js脚本,减少写到页面的js大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.<em>asp</em>x)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的<em>Asp</em>.net控件一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的js对象的名称简单化,这样可以减少生成的js内容,加快页面加载速度(一个典型页面的js由原来的33.0k降低为21.4k)。[fixed] +弹出窗口<em>中</em>,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed] -因为在页面的Page_Load<em>中</em>,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。 -一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。 -另一种办法就是在PageManager控件<em>中</em>增加RegisterPageStateChangedScript(向页面注册监视页面<em>中</em>表单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.<em>asp</em>x/simpleform.<em>asp</em>x)。 +PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.<em>asp</em>x)。[fixed] -这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报<em>中</em>遇到这种情况)。 -每个页面必须添加一个PageManager控件,否则会出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed] -TextField等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和<em>Asp</em>.net Ajax保持兼容)。[fixed] -最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.<em>asp</em>x/page2.<em>asp</em>x/simpleform.<em>asp</em>x) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加一个属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.<em>asp</em>x(A)/page2.<em>asp</em>x(B)/simpleform.<em>asp</em>x(C)),其<em>中</em>A包含B页面,当你在B<em>中</em>打开包含有页面C的窗口时,窗口不是在B<em>中</em>打开,而是在A<em>中</em>打开,这样才能保证窗口覆盖整个页面,当你从C<em>中</em>返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面<em>中</em>创建的。我会通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid<em>中</em>弹出窗口。(default.<em>asp</em>x/page3.<em>asp</em>x/simpleform.<em>asp</em>x) +示例3,TriggerBox弹出窗口。(default.<em>asp</em>x/triggerbox.<em>asp</em>x/simpleform.<em>asp</em>x) -在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。 -示例4,弹出窗口<em>中</em>的弹出窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下TabStrip在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对TabStrip/Panel/Window<em>中</em>的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到页面节点,同时第二次打开Window<em>中</em>的IFrame不会有残影出现。[fixed] -如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在tabstrip_iframe.<em>asp</em>x)。[fixed] -Tree控件,点击一个节点<em>自动</em>回发,则当前点击的那个节点的选<em>中</em>状态不会保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe<em>中</em>关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.<em>asp</em>x/simpleform.<em>asp</em>x)。[fixed] -内部<em>实现</em>上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.<em>asp</em>x,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。 -参照Yslow的评分规则,将JS文件引用由head移动到body<em>中</em>。[fixed] -Firefox下,如果页面太长会出滚动条,原来在ViewPort样式<em>中</em>有body{overflow:hidden;}。[fixed] +IFrame内的页面宽度和高度会<em>自动</em>设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.<em>asp</em>x/simpleform.<em>asp</em>x/simpleform2.<em>asp</em>x)[fixed] -增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息<em>中</em>MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image控件 [feedback:jima]。[fixed] -Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.<em>asp</em>x)。[fixed] -去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选<em>中</em>哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息<em>中</em>的换行符(转换为<br/>),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree控件。[fixed] -如何将数据库<em>中</em>的数据绑定到Tree(示例在tree2_bind_database.<em>asp</em>x)。 -ajax加载树节点,放在UpdatePanel<em>中</em>才有ajax的效果(示例在tree2_ajax.<em>asp</em>x)。 -更改TreeNode的ID为NodeId,否则两个树<em>中</em>不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同一个页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltipFormatString两个字段,以显示ToolTip(示例在grid.<em>asp</em>x)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选<em>中</em>样式,以及鼠标移上去和移开的样式不对。[fixed] -发现原来ie6不能正确解析li的高度,必须手工设置才行(style="height:20px;")。 +IE6/IE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed] -虽然最后未能解决<div style="width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;"><div style="width: 16px; height: 18px; float: left;">##</div>差旅交通费</div>在IE和Firefox下显示的不同效果。 -但是通过用<img src="##" />来代替<div style="background:url(##)" />,从而<em>实现</em>FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“<span style="margin-right: -1000px;">差旅交通费</span>”,在IE下和FF下的都不换行,:-) -LinkButton增加OnClick<em>事件</em> [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树控件(Tree)(示例在tree2.<em>asp</em>x)。[fixed] -可以在回发时维持树的状态(选<em>中</em>行,折叠/展开,CheckBox)。 -可以通过Inline的方式添加树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到页面,也可以引发PostBack<em>事件</em>,可以添加自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel<em>中</em>放置Ext<em>Asp</em>Net控件,则渲染时会出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel<em>中</em>渲染Ext<em>Asp</em>Net控件,如果容器的display='none',则会出现各种问题(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局<em>实现</em>),只要超过Grid容器就会显示滚动条。 +IE6下,在应用<em>Asp</em>.NetAjax后,Form<em>中</em>字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。 -最后发现IE6下应用<em>Asp</em>.NetAjax后不仅Form<em>中</em>列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数<em>中</em>,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面<em>中</em>所有表单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 页面。 +集成的<em>Asp</em>NetAjax有一个很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject控件。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选<em>中</em>样式微调。[fixed] -预加载Form表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(一个典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid<em>中</em>静态的CheckBoxField图片。[fixed] -TabStrip增加TabIndexChanged<em>事件</em>,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发<em>事件</em>。这在延迟加载Tab的内容非常有用。(示例在tabstrip.<em>asp</em>x)[fixed] +2008-07-12 v0.3 beta5 -页面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.<em>asp</em>x)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和TextBox比较大小需要指定CompareType。 +如果在编辑页面使用<em>Asp</em>NetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.<em>asp</em>x/ajax_editor.<em>asp</em>x)。[fixed] -这是由于ajax后执行的javascript<em>中</em>不能有return false语句。 +在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.<em>asp</em>x) [feedback:xmzhu]。[fixed] -在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。 -弹出Window默认显示的错误页面,解决方法在当前目录添加一个空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是"#"。[fixed] +弹出的窗口<em>中</em>的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例<em>中</em>alert\alert_1.<em>asp</em>x和alert\alert_2.<em>asp</em>x,总计 6 行代码),现在只需要 3 行代码就OK了。 -点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.<em>asp</em>x)[feedback:jima]。[fixed] +增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.<em>asp</em>x)。[fixed] -增加SplitButton控件。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.<em>asp</em>x。 +TabStrip<em>中</em>放置IFrame会出现渲染错误 (示例在tabstrip_iframe.<em>asp</em>x)[feedback:jima]。[fixed] -特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.<em>asp</em>x) [feedback:xmzhu]。[fixed] -FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.<em>asp</em>x)[feedback:jima]。[fixed] +表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有数据,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField控件。[fixed] -其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.<em>asp</em>x)。 -模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed] +控制下拉列表某些项不可以选择(示例在dropdownlist2.<em>asp</em>x)。[fixed] -增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。 -LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.<em>asp</em>x和grid.<em>asp</em>x)。[fixed] +2008-07-07 v0.3 beta2 +增加UpdatePanelConnector控件,支持在布局构建的页面使用<em>Asp</em>.net Ajax。[fixed] -使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。 -示例在ajax3.<em>asp</em>x/content_page4.<em>asp</em>x。 -示例content_page3.<em>asp</em>x<em>中</em>,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器控件的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工添加AutoHeight="true"属性。 +增加UserControlConnector,可以在其<em>中</em>放置用户控件(示例在page_usercontrol.<em>asp</em>x)。[fixed] -也可以在ContentPanel<em>中</em>放置用户控件,注意两者的区别。 +增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed] +支持<em>Asp</em>.net ajax异步加载。[fixed] -有很大局限性,只能在ContentPanel<em>中</em>使用,示例在ajax1.<em>asp</em>x/content_ajax2.<em>asp</em>x<em>中</em>。 -对于使用布局构建的页面(比如content_page1.<em>asp</em>x)还不能使用<em>Asp</em>.net ajax,因为页面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前页面已经被修改(示例在content_page1.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe<em>中</em>做法一致)。 +iframe<em>中</em>的alert/confirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed] -在Firefox下还有问题。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.<em>asp</em>x)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.<em>asp</em>x)。[fixed] -TabStrip的Tab<em>中</em>如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel<em>中</em>放置用户控件(示例在page_usercontrol.<em>asp</em>x)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox控件(示例在twintriggerbox.<em>asp</em>x)。[fixed] -Grid的数据库分页需要增加属性IsDatabasePaging=true,以便普通分页和数据库分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack<em>事件</em>OnClose可以指定参数,来区分是哪些操作引发的PostBack<em>事件</em> [feedback:zgjiang2](示例在window_postback.<em>asp</em>x)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的tab)。[fixed] +页面<em>中</em>任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容页<em>中</em>Grid的Sort<em>事件</em>不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid<em>中</em>的LinkButtonField设置ConfirmText会出错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.<em>asp</em>x示例)。 -Grid<em>中</em>模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.<em>asp</em>x)。 -切换分页时清空选<em>中</em>的值 [feedback:jqpeng]。 -增加PreRowDataBound<em>事件</em>,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.<em>asp</em>x)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.<em>asp</em>x)。 +2008-06-25 v0.2 beta9 +Window窗体<em>中</em>的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -在simpleform.<em>asp</em>x<em>中</em>:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其<em>中</em>26是Toolbar的高度,32是窗口的标题栏和下边框的高度。 +关闭Iframe的LoadMask,所以需要Iframe页面添加PageLoading控件,这样效果统一。[fixed] +Grid完善。 -去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在<em>ASP</em>.NET应用<em>中</em>会有很多问题(主要是状态保持的问题)。 +EnableServerSort改名AllowSorting。(示例在grid_sorting.<em>asp</em>x) -使用非常简单:设置AllowSorting=true,注册OnSort<em>事件</em>,在<em>事件</em>处理函数<em>中</em>重新绑定数据。 +增加AllowPaging属性。(示例在grid_paging.<em>asp</em>x) -使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange<em>事件</em>,在<em>事件</em>处理函数<em>中</em>Grid1.PageIndex = e.NewPageIndex;OK。 +数据库分页支持。(示例在grid_database_paging.<em>asp</em>x) -使用也非常简单:设置AllowPaging=true,PageSize=3,在绑<em>定时</em>设置RecordCount为总的记录数,在OnPageIndexChange<em>事件</em>处理函数<em>中</em>Grid1.PageIn</a></div></div></div></div> <div class="public_pc_right_footer2020" style="display:none;" data-v-4a5a7f56></div></div> <div id="right-floor-user-content_562" data-editor="{"type":"floor","pageId":143,"floorId":562}" class="user-right-floor right-box main-box detail-user-right" data-v-229a00b0><div class="__vuescroll" style="height:100%;width:100%;padding:0;position:relative;overflow:hidden;"><div class="__panel __hidebar" style="position:relative;box-sizing:border-box;height:100%;overflow-y:hidden;overflow-x:hidden;transform-origin:;transform:;"><div class="__view" style="position:relative;box-sizing:border-box;min-width:100%;min-height:100%;"><!----><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="introduce" data-v-4722a3ae><div class="introduce-title" data-v-4722a3ae><div class="img-info" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/ASP" class="community-img" data-v-4722a3ae><img src="https://img-community.csdnimg.cn/avatar/ad08cc95e8b74fc1b22d8708cf8764f6.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt data-v-4722a3ae> <div title="ASP" class="community-name" data-v-4722a3ae> ASP </div></a></div></div> <div class="content" data-v-4722a3ae><div class="detail" data-v-4722a3ae><div title="28391" class="item" data-v-4722a3ae><p class="num" data-v-4722a3ae> 28,391 </p> <p class="desc" data-v-4722a3ae> 社区成员 </p></div> <div title="357060" class="item" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/ASP" target="_blank" data-v-4722a3ae><p class="num" data-v-4722a3ae> 357,060 </p> <p class="desc" data-v-4722a3ae> 社区内容 </p></a></div></div> <div class="detail-btns" data-v-4722a3ae><div class="community-ctrl-btns_wrapper" data-v-0ebf603c data-v-4722a3ae><div class="community-ctrl-btns" data-v-0ebf603c><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-160be461 data-v-0ebf603c><div data-report-click="{"spm":"3001.5975"}" data-v-160be461><img src="https://csdnimg.cn/release/cmsfe/public/img/topic.427195d5.png" alt="" class="img sendTopic" data-v-160be461 data-v-0ebf603c> <span data-v-160be461 data-v-0ebf603c>发帖</span></div> <!----> <!----></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/me.40a70ab0.png" alt="" class="img me" data-v-0ebf603c> <span data-v-0ebf603c>与我相关</span></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/task.87b52881.png" alt="" class="img task" data-v-0ebf603c> <span data-v-0ebf603c>我的任务</span></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div class="community-share" data-v-4ca34db9 data-v-0ebf603c><div class="handle-item share" data-v-ca030a68 data-v-4ca34db9><span height="384" data-v-ca030a68><div role="tooltip" id="el-popover-3095" aria-hidden="true" class="el-popover el-popper popo share-popover" style="width:265px;display:none;"><!----><div id="tool-QRcode" class="QRcode" data-v-ca030a68><img src="https://csdnimg.cn/release/cmsfe/public/img/shareBg2.05330abf.png" alt="" class="share-bg" data-v-ca030a68> <div class="share-bg-box" data-v-ca030a68><div class="share-content" data-v-ca030a68><img src="https://img-community.csdnimg.cn/avatar/ad08cc95e8b74fc1b22d8708cf8764f6.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt="" class="share-avatar" data-v-ca030a68> <div class="share-tit" data-v-ca030a68>ASP</div> <div class="share-dec" data-v-ca030a68>ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。</div> <span class="copy-share-url" data-v-ca030a68>复制链接</span> <div class="shareText" data-v-ca030a68> </div></div> <div class="share-code" data-v-ca030a68><div class="qrcode" data-v-ca030a68></div> <div class="share-code-text" data-v-ca030a68>扫一扫</div></div></div></div> </div><span class="el-popover__reference-wrapper"><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/share-circle.3e0b7822.png" alt="" class="img share" data-v-0ebf603c> <span data-v-0ebf603c>分享</span></div></span></span></div> <!----></div></div></div> <!----> <div data-v-4fb59baf data-v-0ebf603c><div class="el-dialog__wrapper ccloud-pop-outer2" style="display:none;" data-v-4fb59baf><div role="dialog" aria-modal="true" aria-label="dialog" class="el-dialog el-dialog--center" style="margin-top:15vh;width:70%;"><div class="el-dialog__header"><span class="el-dialog__title"></span><!----></div><!----><div class="el-dialog__footer"><span class="dialog-footer clearfix" data-v-4fb59baf><div class="confirm-btm fr" data-v-4fb59baf>确定</div></span></div></div></div></div></div></div></div> <div style="display:none;" data-v-4722a3ae data-v-4722a3ae><!----> <div class="introduce-desc" data-v-4722a3ae><div class="introduce-desc-title" data-v-4722a3ae>社区描述</div> <span data-v-4722a3ae> ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。 </span></div></div> <div class="introduce-text" data-v-4722a3ae><div class="label-box" data-v-4722a3ae><!----> <!----> <!----></div></div> <!----> <div class="manage" data-v-4722a3ae><div class="manage-inner" data-v-4722a3ae><span data-v-4722a3ae>社区管理员</span> <ul data-v-4722a3ae><li data-v-4722a3ae><a href="https://blog.csdn.net/community_24" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/default.jpg!1" alt="ASP" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li><li data-v-4722a3ae><a href="https://blog.csdn.net/sysdzw" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/45dcec50fd694b578374e7167ff7914a_sysdzw.jpg!1" alt="无·法" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li></ul></div></div> <div class="actions" data-v-4722a3ae><!----> <div style="flex:1;" data-v-4722a3ae><div class="join-btn" data-v-4722a3ae> 加入社区 </div></div> <!----> <!----></div> <div class="el-dialog__wrapper" style="display:none;" data-v-38c57799 data-v-4722a3ae><div role="dialog" aria-modal="true" aria-label="获取链接或二维码" class="el-dialog join-qrcode-dialog" style="margin-top:15vh;width:600px;"><div class="el-dialog__header"><span class="el-dialog__title">获取链接或二维码</span><button type="button" aria-label="Close" class="el-dialog__headerbtn"><i class="el-dialog__close el-icon el-icon-close"></i></button></div><!----><div class="el-dialog__footer"><span class="dialog-footer" data-v-38c57799></span></div></div></div> <div class="collapse-btn" data-v-4722a3ae><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAgCAYAAACFM/9sAAAAAXNSR0IArs4c6QAAAi1JREFUaEPtl01u01AUhc+N8wMSO4AxzJAqwQpKQsdtbMOICmKnwCKQ2ACDIgotrYKiduIiVZ10B0CBAjtAbICfooomJr3IcUoTiVLb15GNuG/67nm65/M5AxP0iAiQSK1iKEBhCBSgAhQSEMo1gQpQSEAo1wQqQCEBoVwT+K8CnLnWvER8cOHMaf95q9Xaj+vDtp3LPeD83u6p9a2t+U5cfVrzmSTQNOfOgg4+ATDAeNHp/Jza3Fz5HtWUZbl3GXjYn2e+53lL96Nq057LBOD0dOOcUSx8BFAcGHpZLlWmVlfnd08yaJrubRAe/Z77HwEG5kdS1E8StgFc9bzFb8dBrNtukxgLwOAXNEF6T/pAce8zSeDhknXbuUNMQRUHe/BrMNX+BNGyHIdBT45m6VVn36/FqX5cOFHmMwUYJrE5x+CgkuEujLe+361ubLS+HhowzeYtEC8NzWyXy5ValMpHgSCZyRxgsLxpui4Ij4/ShZ1S0aiurS18sSznJoOeDt29AaP6t6pLgMTV5gJgsHTddhvEWBwC9Y6AZww8AFA4Lp1xDac9nxuAYZ37aQuqGgIbPTt+t3tluNppw0jyXq4AhnV2ZkG0PAKR8b5UMiaDSicxOU5N7gCGSXRvMLAygPgB3Jv0vOXP4wSR9O1cAgzMzFxvXDR6hYlK5cd6u93eS2pw3LrcAhy38bTeV4BCkgpQAQoJCOWaQAUoJCCUawIVoJCAUK4JVIBCAkL5L1yapyGdIBwvAAAAAElFTkSuQmCC" alt data-v-4722a3ae></div></div><!----><!----><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="floor-user-right-rank" data-v-3d3affee><div class="el-tabs el-tabs--top" data-v-3d3affee><div class="el-tabs__header is-top"><div class="el-tabs__nav-wrap is-top"><div class="el-tabs__nav-scroll"><div role="tablist" class="el-tabs__nav is-top" style="transform:translateX(-0px);"><div class="el-tabs__active-bar is-top" style="width:0px;transform:translateX(0px);ms-transform:translateX(0px);webkit-transform:translateX(0px);"></div></div></div></div></div><div class="el-tabs__content"><div role="tabpanel" id="pane-integral" aria-labelledby="tab-integral" class="el-tab-pane" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-3" aria-labelledby="tab-3" class="el-tab-pane" style="display:none;" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-5" aria-labelledby="tab-5" class="el-tab-pane" style="display:none;" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-6" aria-labelledby="tab-6" class="el-tab-pane" style="display:none;" data-v-3d3affee></div></div></div> <div class="floor-user-right-rank-score" data-v-608528ce data-v-3d3affee><div class="floor-user-right-rank-score-tabs" data-v-608528ce><ul data-v-608528ce><li data-v-608528ce> 近7日 </li><li data-v-608528ce> 近30日 </li><li class="active" data-v-608528ce> 至今 </li></ul></div> <div class="floor-user-right-rank-common" data-v-46cf600d data-v-608528ce><div class="rank-list" data-v-46cf600d><!----> <div class="no-data loading" data-v-46cf600d><i class="el-icon-loading" data-v-46cf600d></i> <p data-v-46cf600d>加载中</p></div> <!----> <a href="https:///ASP/rank/list/total" target="_blank" class="show-more" data-v-46cf600d> 查看更多榜单 </a></div></div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="floor comunity-rule" data-v-3cfa4dbd><div class="title" data-v-3cfa4dbd> 社区公告 </div> <div class="contain" data-v-3cfa4dbd><div class="inner-content" data-v-3cfa4dbd>暂无公告</div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="user-right-adimg empty-arr" data-v-15c6aa4f><div class="adImgs" data-v-2a6389b9 data-v-15c6aa4f><!----> <div data-v-2a6389b9><div data-v-2a6389b9></div></div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="content-right-recommend" data-v-0f781e88><div data-v-3798762e data-v-0f781e88><!----> <!----></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="ai-entrance" data-v-eb1c454c><p data-v-eb1c454c>试试用AI创作助手写篇文章吧</p> <div class="entrance-btn-line" data-v-eb1c454c><a href="https://mp.csdn.net/edit?guide=1" target="_blank" data-report-click="{"spm":"3001.9712"}" data-report-query="spm=3001.9712" class="entrance-btn" data-v-eb1c454c>+ 用AI写文章</a></div></div></div></div></div></div></div></div></div></div></div></div></div> <div> <script type="text/javascript" src="https://g.csdnimg.cn/common/csdn-footer/csdn-footer.js" data-isfootertrack="false" defer></script> </div></div></div><script> window.__INITIAL_STATE__= {"csrf":"qhu4ny54-9_BvmFvZnZI_IByXVhmFupARRJc","origin":"http:\u002F\u002Fbbs.csdn.net","isMobile":false,"cookie":"uuid_tt_dd=10_587713620-1714124400989-874908;","ip":"3.128.199.162","pageData":{"page":{"pageId":143,"title":"社区详情","keywords":"社区详情","description":"社区详情","ext":{"isMd":"true","armsfe1":"{pid:\"dyiaei5ihw@1a348e4d05c2c78\",appType:\"web\",imgUrl:\"https:\u002F\u002Farms-retcode.aliyuncs.com\u002Fr.png?\",sendResource:true,enableLinkTrace:true,behavior:true}","redPacketCfg":"{\"presetTitle\":[\"成就一亿技术人!\",\"大吉大利\",\"节日快乐\",\"Bug Free\",\"Hello World\",\"Be Greater Than Average!!\"],\"defaultTitle\":\"成就一亿技术人!\",\"preOpenSty\":{},\"redCardSty\":{}}","blogStar":"[{\"year\":\"2021\",\"enable\":true,\"communityIds\":[3859],\"url\":\"https:\u002F\u002Fbbs.csdn.net\u002Fsummary2021\"},{\"year\":\"2022\",\"enable\":true,\"communityIds\":[3860],\"url\":\"https:\u002F\u002Fbbs.csdn.net\u002Fsummary2022\"}]","mdVersion":"https:\u002F\u002Fcsdnimg.cn\u002Frelease\u002Fmarkdown-editor\u002F1.1.0\u002Fmarkdown-editor.js","componentSortCfg":"{ \"right\":[\"ratesInfo\",\"cty-profile\",\"pub-comp\",\"user-right-introduce\",\"post-event\",\"my-mission\",\"user-recommend\",\"user-right-rank\",\"user-right-rule\",\"user-right-adimg\"] }","show_1024":"{\"enable\":false,\"useWhitelist\":false,\"whitelist\":[76215],\"home\":\"https:\u002F\u002F1111.csdn.net\u002F\",\"logo\":\"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221104102741.png\",\"hideLive\":true}","iframes":"[\"3859\"]","pageCfg":"{\"disableDownloadPDF\": false,\"hideSponsor\":false}"}},"template":{"templateId":71,"templateComponentName":"ccloud-detail","title":"ccloud-detail","floorList":[{"floorId":562,"floorComponentName":"floor-user-content","title":"社区详情页","description":"社区详情页","indexOrder":3,"componentList":[{"componentName":"baseInfo","componentDataId":"cloud-detail1","componentConfigData":{},"relationType":3},{"componentName":"user-right-introduce","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-recommend","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-rank","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-rule","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-adimg","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"default2014LiveRoom","componentDataId":"20221024DefaultLiveRoom","componentConfigData":{},"relationType":3}]}]},"data":{"baseInfo":{"customDomain":"","uriName":"ASP","communityHomePage":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP","owner":{"userName":"community_24","nickName":"ASP","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","position":"","companyName":""},"user":{"userRole":3,"userName":null,"nickName":null,"avatarUrl":null,"rank":null,"follow":2,"communityBase":null,"joinCollege":null,"isVIP":null},"community":{"name":"ASP","description":"ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。","avatarUrl":"https:\u002F\u002Fimg-community.csdnimg.cn\u002Favatar\u002Fad08cc95e8b74fc1b22d8708cf8764f6.png?x-oss-process=image\u002Fresize,m_fixed,h_88,w_88","qrCode":"","createTime":"2007-09-28","communityAvatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","communityNotice":null,"userCount":28391,"contentCount":357060,"followersCount":19106,"communityRule":"","communityId":143,"bgImage":"","hashId":"o3noovng","domain":"","uriName":"ASP","externalDisplay":1,"adBanner":{"img":"","url":"","adType":0,"adCon":null},"rightBanner":{"img":"","url":"","adType":0,"adCon":null},"tagId":null,"tagName":null,"communityType":1,"communityApplyUrl":"https:\u002F\u002Fmarketing.csdn.net\u002Fquestions\u002FQ2106040308026533763","joinType":0,"visibleType":0,"collapse":0,"topicMoveAble":0,"allowActions":{},"communityOwner":"community_24","tagNameInfo":{"provinceTag":null,"areaTag":null,"technologyTags":null,"customTags":null}},"tabList":[{"tabId":1302,"tabName":"全部","tabUrl":"","tabSwitch":1,"tabType":4,"tabContribute":0,"cardType":0,"indexOrder":-1,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP?typeId=1302","iframe":false,"sortType":1},{"tabId":4057698,"tabName":"博文收录","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":19,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP?typeId=4057698","iframe":false,"sortType":1},{"tabId":1617830,"tabName":"Ada助手","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":20,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP?typeId=1617830","iframe":false,"sortType":1}],"dataResource":{"mediaType":"c_cloud","subResourceType":"8_c_cloud_long_text","showType":"long_text","tabId":0,"communityName":"ASP","communityHomePageUrl":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP","communityType":1,"content":{"id":"26590","contentId":26590,"cateId":0,"cateName":null,"url":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F26590","shareUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F26590","createTime":"2000-10-29 09:48:00","updateTime":"2021-05-28 09:39:48","resourceUsername":"310cdt","best":0,"top":0,"text":null,"publishDate":"2000-10-29","lastReplyDate":"2000-10-29","type":"13","nickname":"310cdt","avatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","username":"310cdt","commentCount":3,"diggNum":0,"digg":false,"viewCount":100,"hit":false,"resourceSource":6,"status":10,"taskStatus":null,"expired":false,"taskCate":0,"taskAward":0,"taskExpired":null,"checkRedPacket":null,"avgScore":0,"totalScore":0,"topicTitle":"在asp中怎样实现像timer似的定时自动触发的事件? ","insertFirst":false,"likeInfo":null,"description":"这么说吧,怎样做一个按时间走的进度条? 我想可以做一个定时自动更新的frame,不过,不用frame最好,而且一直更新frame是不是很费资源? 请高手指点。谢了 ","coverImg":"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221026061911.png","content":"这么说吧,怎样做一个按时间走的进度条? \u003Cbr \u002F\u003E\n 我想可以做一个定时自动更新的frame,不过,不用frame最好,而且一直更新frame是不是很费资源?\u003Cbr \u002F\u003E\n请高手指点。谢了\u003Cbr \u002F\u003E\n","mdContent":null,"pictures":null,"videoInfo":null,"linkInfo":null,"student":{"isCertification":false,"org":"","bala":""},"employee":{"isCertification":false,"org":"","bala":""},"userCertification":[],"dependId":"0","dependSubType":null,"videoUrl":null,"favoriteCount":0,"favoriteStatus":false,"taskType":null,"defaultScore":null,"syncAsk":false,"videoPlayLength":null},"communityUser":null,"allowPost":false,"submitHistory":[{"user":{"registerurl":"https:\u002F\u002Fg.csdnimg.cn\u002Fstatic\u002Fuser-reg-year\u002F1x\u002F23.png","avatarurl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","nickname":"310cdt","selfdesc":"","createdate":"2000-10-29 09:36:00","days":"8581","years":"23","username":"310cdt","school":null,"company":null,"job":null},"userName":"310cdt","event":"创建了帖子","body":"2000-10-29 09:48","editId":null}],"resourceExt":{}},"contentReply":{"pageNo":1,"pageSize":20,"totalPages":1,"totalCount":3,"total":0,"list":[{"hit":null,"hitMsg":null,"content":"上面的程序是可以的\u003Cbr \u002F\u003E\n关键就是setTimeout()函数\u003Cbr \u002F\u003E\n上面的程序的意思是每隔200(毫秒?)就执行timerFun函数。","topicTitle":null,"description":"上面的程序是可以的 关键就是setTimeout()函数 上面的程序的意思是每隔200(毫秒?)就执行timerFun函数。","id":598482,"contentResourceId":26590,"bindContentResourceId":0,"communityId":143,"username":"ciml","userNickName":"ciml","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":0,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2000-10-29 10:39:00","updateTime":"2000-10-29 10:39:00","formatTime":"2000-10-29","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"我也试试","topicTitle":null,"description":"我也试试","id":598442,"contentResourceId":26590,"bindContentResourceId":0,"communityId":143,"username":"monday","userNickName":"monday","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":0,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2000-10-29 09:11:00","updateTime":"2000-10-29 09:11:00","formatTime":"2000-10-29","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"改进版:\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n<!doctype html public "-\u002F\u002FW3C\u002F\u002FDTD HTML 4.0 Transitional\u002F\u002FEN">\u003Cbr \u002F\u003E\n<html>\u003Cbr \u002F\u003E\n<head>\u003Cbr \u002F\u003E\n<title> New Document <\u002Ftitle>\u003Cbr \u002F\u003E\n<script type="text\u002Fjavascript">\u003Cbr \u002F\u003E\nvar g_var;\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\ng_var = 0;\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nfunction timerFun()\u003Cbr \u002F\u003E\n{\u003C!-- --\u003E\u003Cbr \u002F\u003E\n\tvar s;\u003Cbr \u002F\u003E\n\tvar i;\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n\tif(g_var <= 20)\u003Cbr \u002F\u003E\n\t{\u003C!-- --\u003E\u003Cbr \u002F\u003E\n\t\ts = "";\u003Cbr \u002F\u003E\n\t\tfor(i = 0; i < g_var; i++)\u003Cbr \u002F\u003E\n\t\t\ts += ".";\u003Cbr \u002F\u003E\n\t\twindow.status = g_var++;\u003Cbr \u002F\u003E\n\t\twindow.setTimeout(timerFun, 200);\u003Cbr \u002F\u003E\n\t}\u003Cbr \u002F\u003E\n\telse\u003Cbr \u002F\u003E\n\t\twindow.status = "Complete!";\u003Cbr \u002F\u003E\n}\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nfunction init()\u003Cbr \u002F\u003E\n{\u003C!-- --\u003E\u003Cbr \u002F\u003E\n\twindow.setTimeout(timerFun, 200);\u003Cbr \u002F\u003E\n}\u003Cbr \u002F\u003E\n<\u002Fscript>\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n<\u002Fhead>\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n<body bgcolor="#FFFFFF" onload="init()">\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n<\u002Fbody>\u003Cbr \u002F\u003E\n<\u002Fhtml>\u003Cbr \u002F\u003E\n","topicTitle":null,"description":"改进版: \u003C!doctype html public \"-\u002F\u002FW3C\u002F\u002FDTD HTML 4.0 Transitional\u002F\u002FEN\"\u003E \u003Chtml\u003E \u003Chead\u003E \u003Ctitle\u003E New Document \u003C\u002Ftitle\u003E \u003Cscript type=\"text\u002Fjavascript\"\u003E var g_var; g_var = 0; function timerFun() { var s; var i; if(g_var \u003C= 20) { s = \"\"; for(i = 0; i \u003C g_var; ","id":598408,"contentResourceId":26590,"bindContentResourceId":0,"communityId":143,"username":"edyang","userNickName":"Edward","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F48b6109255224b8695400a93ff57eb39_edyang.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":0,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2000-10-29 07:12:00","updateTime":"2000-10-29 07:12:00","formatTime":"2000-10-29","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null}],"maxPageSize":3000},"defaultActiveTab":1302,"recommends":[{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fmail2u\u002F5972237","title":"\u003Cem\u003EASP\u003C\u002Fem\u003E.NET4高级程序设计第4版 带目录PDF 分卷压缩包 part1","desc":"手动优化了PDF的书签,书签可折叠,书签链接以目录方式保存,多达1000多页,每页都做了书签定位,手都累酸啦。\n==============================\n因权限只能到60MB,分卷压缩了,共3个压缩包,需下载完3个一起解压,\n==============================\n\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4高级程序设计(第4版)》【原版书为:Pro \u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4 in C# 2010】是\u003Cem\u003EASP\u003C\u002Fem\u003E.NET领域的鸿篇巨制,全面讲解了\u003Cem\u003EASP\u003C\u002Fem\u003E.NET4的各种特性及其背后的工作原理,并给出了许多针对如何构建复杂、可扩展的网站从实践\u003Cem\u003E中\u003C\u002Fem\u003E得出的建议。书\u003Cem\u003E中\u003C\u002Fem\u003E还深入讲述了其他\u003Cem\u003EASP\u003C\u002Fem\u003E.NET图书遗漏的高级主题,如自定义控件的创建、图像处理、加密等。此外,《\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4高级程序设计(第4版)》专门提供了两章的内容来教你如何用Ajax 技术制作快速响应的页面,以及如何使用微软的\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX平台。另外,还专门介绍了\u003Cem\u003EASP\u003C\u002Fem\u003E.NET4 新增的功能,如MVC 和动态数据等。\n  《\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4高级程序设计(第4版)》适合各层次的\u003Cem\u003EASP\u003C\u002Fem\u003E.NET程序员阅读。\n===================\n第一部分 核心概念\n 第1章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET简介\n 1.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET的7大要点\n 1.1.1 要点1:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET是同.NETFramework集成在一起的\n 1.1.2 要点2:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET是编译执行的,而不是解释执行的\n 1.1.3 要点3:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET支持多语言\n 1.1.4 要点4:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET运行在公共语言运行库内\n 1.1.5 要点5:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET是面向对象的\n 1.1.6 要点6:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET支持所有的浏览器\n 1.1.7 要点7:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET易于部署和配置\n 1.2 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET的演变\n 1.2.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET1.0和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET1.1\n 1.2.2  \u003Cem\u003EASP\u003C\u002Fem\u003E.NET2.0\n 1.2.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET3.5\n 1.2.4 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET4\n 1.2.5 Silverlight\n 1.3 总结\n 第2章 Visual Studio\n 2.1 Visual Studio\n 2.1.1 网站和Web项目\n 2.1.2 创建无项目文件的网站\n 2.1.3 设计网页\n 2.2 Visual StudioIDE\n 2.2.1 解决方案资源管理器\n 2.2.2 文档窗口\n 2.2.3 工具箱\n 2.2.4 错误列表和任务列表\n 2.2.5 服务器资源管理器\n 2.3 代码编辑器\n 2.3.1 添加程序集引用\n 2.3.2 智能感知和大纲显示\n 2.3.3 Visual Studio 2010改进\n 2.4 编码模型\n 2.4.1 代码隐藏文件如何与页面连接\n 2.4.2 控件标签如何与页面变量连接\n 2.4.3 \u003Cem\u003E事件\u003C\u002Fem\u003E如何与\u003Cem\u003E事件\u003C\u002Fem\u003E处理程序连接\n 2.5 Web项目\n 2.5.1 基于项目的开发\n 2.5.2 创建Web项目\n 2.5.3 迁移旧版Visual Studio创建的网站\n 2.6 Visual Studio调试\n 2.6.1 单步调试\n 2.6.2 变量监视\n 2.6.3 高级断点\n 2.7 WebDevelopment Helper\n 2.8 总结\n 第3章 Web窗体\n 3.1 页面处理\n 3.1.1 HTML表单\n 3.1.2 动态用户界面\n 3.1.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET\u003Cem\u003E事件\u003C\u002Fem\u003E模型\n 3.1.4 \u003Cem\u003E自动\u003C\u002Fem\u003E回送\n 3.1.5 视图状态\n 3.1.6 XHTML兼容性\n 3.1.7 客户端控件ID\n 3.2 Web窗体处理阶段\n 3.2.1 页面框架初始化\n 3.2.2 用户代码初始化\n 3.2.3 验证\n 3.2.4 \u003Cem\u003E事件\u003C\u002Fem\u003E处理\n 3.2.5 \u003Cem\u003E自动\u003C\u002Fem\u003E数据绑定\n 3.2.6 清除\n 3.2.7 页面流示例\n 3.3 作为控件容器的页面\n 3.3.1 显示控件树\n 3.3.2 页头\n 3.3.3 动态控件的创建\n 3.4 Page类\n 3.4.1 Session、Application和Cache\n 3.4.2 Request\n 3.4.3 Response\n 3.4.4 Server\n 3.4.5 User\n 3.4.6 Trace\n 3.4.7 访问其他类\u003Cem\u003E中\u003C\u002Fem\u003E的HTTP上下文\n 3.5 总结\n 第4章 服务器控件\n 4.1 服务器控件的类型\n 4.2 HTML服务器控件\n 4.2.1 HtmlControl类\n 4.2.2 HtmlContainerControl类\n 4.2.3 HtmlInputControl类\n 4.2.4 HTML服务器控件类\n 4.2.5 设置Style特性和其他属性\n 4.2.6 通过编程创建服务器控件\n 4.2.7 处理服务器端\u003Cem\u003E事件\u003C\u002Fem\u003E\n 4.3 Web控件\n 4.3.1 WebControl基类\n 4.3.2 基本的Web控件类\n 4.3.3 单位\n 4.3.4 枚举\n 4.3.5 颜色\n 4.3.6 字体\n 4.3.7 焦点\n 4.3.8 默认按钮\n 4.3.9 可滚动面板\n 4.3.10 处理Web控件\u003Cem\u003E事件\u003C\u002Fem\u003E\n 4.4 List控件\n 4.4.1 Selectable列表控件\n 4.4.2 BulletedList控件\n 4.5 输入验证控件\n 4.5.1 验证控件\n 4.5.2 验证流程\n 4.5.3 BaseValidator类\n 4.5.4 RequiredFieldValidator控件\n 4.5.5 RangeValidator控件\n 4.5.6 CompareValidator控件\n 4.5.7 RegularExpressionValidator控件\n 4.5.8 CustomValidator控件\n 4.5.9 ValidationSummary控件\n 4.5.10 通过编程使用验证器\n 4.5.11 验证组\n 4.6 富控件\n 4.6.1 AdRotator控件\n 4.6.2 Calendar控件\n 4.7 总结\n 第5章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用程序\n 5.1 剖析\u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用程序\n 5.1.1 应用程序域\n 5.1.2 应用程序生命周期\n 5.1.3 应用程序更新\n 5.1.4 应用程序目录结构\n 5.2 global.asax应用程序文件\n 5.2.1 应用程序\u003Cem\u003E事件\u003C\u002Fem\u003E\n 5.2.2 演示应用程序\u003Cem\u003E事件\u003C\u002Fem\u003E\n 5.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET配置\n 5.3.1 machine.config文件\n 5.3.2 web.config文件\n 5.3.3 设置\n 5.3.4\n 5.3.5\n 5.3.6\n 5.3.7 通过编程读写配置节\n 5.3.8 网站管理工具(WAT)\n 5.3.9 扩展配置文件结构\n 5.3.10 加密配置节\n 5.4 .NET组件\n 5.4.1 创建组件\n 5.4.2 通过App_Code目录使用组件\n 5.4.3 通过Bin目录使用组件\n 5.5 扩展HTTP管道\n 5.5.1 HTTP处理程序\n 5.5.2 创建自定义的HTTP处理程序\n 5.5.3 配置自定义的HTTP处理程序\n 5.5.4 使用无须配置的HTTP处理程序\n 5.5.5 创建高级的HTTP处理程序\n 5.5.6 为非HTML内容创建HTTP处理程序\n 5.5.7 HTTP模块\n 5.5.8 创建自定义HTTP模块\n 5.6 总结\n 第6章 状态管理\n 6.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET状态管理\n 6.2 视图状态\n 6.2.1 视图状态示例\n 6.2.2 在视图状态\u003Cem\u003E中\u003C\u002Fem\u003E保存对象\n 6.2.3 视图状态评估\n 6.2.4 有选择地禁用视图状态\n 6.2.5 视图状态安全\n 6.3 在页面间传送信息\n 6.3.1 查询字符串\n 6.3.2 跨页回发\n 6.4 cookie\n 6.5 会话状态\n 6.5.1 会话架构\n 6.5.2 使用会话状态\n 6.5.3 配置会话状态\n 6.5.4 会话状态安全\n 6.6 应用程序状态\n 6.7 总结\n 第二部分 数据访问\n 第7章 基础\n 7.1 ADO.NET架构\n 7.1.1 ADO.NET数据提供程序\n 7.1.2 ADO.NET的标准化\n 7.1.3 基本ADO.NET类\n 7.2 Connection类\n 7.2.1 连接字符串\n 7.2.2 测试连接\n 7.2.3 连接池\n 7.3 Command类和DataReader类\n 7.3.1 Command基础\n 7.3.2 DataReader类\n 7.3.3  ExecuteReader()方法和DataReader\n 7.3.4 ExecuteScalar()方法\n 7.3.5 ExecuteNonQuery()方法\n 7.3.6 SQL注入攻击\n 7.3.7 使用参数化命令\n 7.3.8 调用存储过程\n 7.4 事务\n 7.4.1 事务和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用程序\n 7.4.2 隔离级别\n 7.4.3 保存点\n 7.5 提供程序无关的代码\n 7.5.1 创建工厂\n 7.5.2 用工厂创建对象\n 7.5.3 使用提供程序无关的代码的查询\n 7.6 总结\n 第8章 数据组件和DataSet\n 8.1 构建数据访问组件\n 8.1.1 数据包\n 8.1.2 存储过程\n 8.1.3 数据应用类\n 8.1.4 测试数据库组件\n 8.2 非连接的数据\n 8.2.1 Web应用程序和DataSet\n 8.2.2 XML集成\n 8.3 DataSet类\n 8.4  DataAdapter类\n 8.4.1 填充DataSet\n 8.4.2 使用多个表和关系\n 8.4.3 查找特定行\n 8.4.4 在数据访问类里使用DataSet\n 8.4.5 数据绑定\n 8.5 DataView类\n 8.5.1 使用DataView排序\n 8.5.2 使用DataView过滤\n 8.5.3 使用关系的高级过滤\n 8.5.4 计算列\n 8.6 总结\n 第9章 数据绑定\n 9.1 基本的数据绑定\n 9.1.1 单值绑定\n 9.1.2 其他类型的表达式\n 9.1.3 重复值绑定\n 9.2 数据源控件\n 9.3 SqlDataSource\n 9.3.1 选择记录\n 9.3.2 参数化命令\n 9.3.3 错误处理\n 9.3.4 更新记录\n 9.3.5 删除记录\n 9.3.6 插入记录\n 9.3.7 SqlDataSource的不足\n 9.4 ObjectDataSource\n 9.4.1 选择记录\n 9.4.2 更新记录\n 9.4.3 使用数据对象执行更新\n 9.5 数据源控件的限制\n 9.5.1 问题\n 9.5.2 添加其他项\n 9.5.3 使用SqlDataSource处理其他选项\n 9.5.4 使用ObjectDataSource处理其他选项\n 9.6 总结\n 第10章 富数据控件\n 10.1 GridView\n 10.2 格式化GridView\n 10.2.1 格式化字段\n 10.2.2 样式\n 10.2.3 格式化特定值\n 10.3 GridView行选择\n 10.3.1 使用选择来创建主-从表单\n 10.3.2 SelectedIndexChanged\u003Cem\u003E事件\u003C\u002Fem\u003E\n 10.3.3 将数据字段用作选择按钮\n 10.4 对GridView排序\n 10.4.1 使用SqlDataSource排序\n 10.4.2 使用ObjectDataSource排序\n 10.4.3 排序和选择\n 10.4.4 高级排序\n 10.5 GridView分页\n 10.5.1 \u003Cem\u003E自动\u003C\u002Fem\u003E分页\n 10.5.2 分页和选择\n 10.5.3 ObjectDataSource的自定义分页\n 10.5.4 定制分页栏\n 10.6 GridView模板\n 10.6.1 使用多个模板\n 10.6.2 在Visual Studio\u003Cem\u003E中\u003C\u002Fem\u003E编辑模板\n 10.6.3 绑定到方法\n 10.6.4 处理模板\u003Cem\u003E中\u003C\u002Fem\u003E的\u003Cem\u003E事件\u003C\u002Fem\u003E\n 10.6.5 使用模板编辑\n 10.6.6 模板\u003Cem\u003E中\u003C\u002Fem\u003E的客户端ID\n 10.7 ListView\n 10.7.1 分组\n 10.7.2 分页\n 10.8 DetailsView和FormView\n 10.8.1 DetailsView\n 10.8.2 FormView\n 10.9 高级网格\n 10.9.1 GridView\u003Cem\u003E中\u003C\u002Fem\u003E的汇总\n 10.9.2 单个表\u003Cem\u003E中\u003C\u002Fem\u003E的父\u002F子视图\n 10.9.3 使用查找表编辑字段\n 10.9.4 处理来自数据库的图片\n 10.9.5 探测并发冲突\n 10.10 总结\n 第11章 缓存和异步页面\n 11.1 理解\u003Cem\u003EASP\u003C\u002Fem\u003E.NET缓存\n 11.2 输出缓存\n 11.2.1 声明性的输出缓存\n 11.2.2 缓存和查询字符串\n 11.2.3 使用特定查询字符串参数的缓存\n 11.2.4 自定义缓存控制\n 11.2.5 使用HttpCachePolicy类进行缓存\n 11.2.6 缓存后替换和部分页缓存\n 11.2.7 缓存用户配置\n 11.2.8 缓存配置\n 11.2.9 输出缓存扩展\n 11.3 数据缓存\n 11.3.1 向缓存添加项目\n 11.3.2 简单的缓存测试\n 11.3.3 缓存优先级\n 11.3.4 使用数据源控件的缓存\n 11.4 缓存依赖\n 11.4.1 文件和缓存项目依赖\n 11.4.2 聚合依赖\n 11.4.3 移除项目回调\n 11.4.4 理解SQL缓存通知\n 11.4.5 缓存通知的工作方式\n 11.4.6 启用通知\n 11.4.7 创建缓存依赖\n 11.5 自定义缓存依赖\n 11.5.1 基本的自定义缓存依赖\n 11.5.2 使用消息队列的自定义缓存依赖\n 11.6 异步页面\n 11.6.1 创建异步页面\n 11.6.2 在异步页面\u003Cem\u003E中\u003C\u002Fem\u003E查询数据\n 11.6.3 错误处理\n 11.6.4 在异步任务\u003Cem\u003E中\u003C\u002Fem\u003E使用缓存\n 11.6.5 多异步任务和超时\n 11.7 总结\n 第12章 文件和流\n 12.1 使用文件系统\n 12.1.1 Directory类和File类\n 12.1.2 DirectoryInfo类和FileInfo类\n 12.1.3 DriveInfo类\n 12.1.4 使用Attributes\n 12.1.5 使用通配符过滤文件\n 12.1.6 获取文件的版本信息\n 12.1.7 Path类\n 12.1.8 文件浏览器\n 12.2 使用流读写文件\n 12.2.1 文本文件\n 12.2.2 二进制文件\n 12.2.3 上传文件\n 12.2.4 使文件对多用户安全\n 12.2.5 压缩\n 12.3 序列化\n 12.4 总结\n 第13章 LINQ\n 13.1 LINQ基础\n 13.1.1 延迟执行\n 13.1.2 LINQ是如何工作的\n 13.1.3 LINQ表达式\n 13.1.4 揭秘LINQ表达式\n 13.2 LINQ to DataSet\n 13.2.1 强类型的DataSet\n 13.2.2 空值\n 13.3 LINQ to Entities\n 13.3.1 生成数据模型\n 13.3.2 数据模型类\n 13.3.3 实体关系\n 13.3.4 查询存储过程\n 13.3.5 LINQ to Entities查询揭秘\n 13.4 数据库操作\n 13.4.1 插入\n 13.4.2 更新\n 13.4.3 删除\n 13.4.4 管理并发\n 13.4.5 处理并发冲突\n 13.5 EntityDataSource控件\n 13.5.1 显示数据\n 13.5.2 获取关联数据\n 13.5.3 编辑数据\n 13.5.4 验证\n 13.6 使用QueryExtender控件\n 13.6.1 使用SearchExperssion\n 13.6.2 使用RangeExpression\n 13.6.3 使用PropertyExpression\n 13.6.4 使用MethodExpression\n 13.7 总结\n 第14章 XML\n 14.1 什么时候使用XML\n 14.2 XML简介\n 14.2.1 XML的优点\n 14.2.2 格式良好的XML\n 14.2.3 XML命名空间\n 14.2.4 XML架构\n 14.3 基于流的XML处理\n 14.3.1 写XML文件\n 14.3.2 读取XML文件\n 14.4 内存\u003Cem\u003E中\u003C\u002Fem\u003E的XML处理\n 14.4.1 XmlDocument\n 14.4.2 XPathNavigator\n 14.4.3 XDocument\n 14.5 搜索XML内容\n 14.5.1 搜索XmlDocument\n 14.5.2 使用XPath搜索XmlDocument\n 14.5.3 使用LINQ搜索XDocument\n 14.6 验证XML内容\n 14.6.1 基本架构\n 14.6.2 验证XmlDocument\n 14.6.3 使用XDocument进行验证\n 14.7 转换XML内容\n 14.7.1 基本的样式表\n 14.7.2 使用XslCompiledTransform\n 14.7.3 使用Xml控件\n 14.7.4 使用LINQ to XML转换XML\n 14.8 XML数据绑定\n 14.8.1 非层次化绑定\n 14.8.2 使用XPath\n 14.8.3 嵌套的网格\n 14.8.4 使用TreeView的层次化绑定\n 14.8.5 使用XSLT\n 14.8.6 绑定到来自其他源的XML内容\n 14.8.7 通过XmlDataSource更新XML\n 14.9 XML和ADO.NET数据集\n 14.9.1 把DataSet转换为XML\n 14.9.2 把DataSet作为XML访问\n 14.10 总结\n 第三部分 构建\u003Cem\u003EASP\u003C\u002Fem\u003E.NET网站\n 第15章 用户控件\n 15.1 用户控件基础\n 15.1.1 创建简单的用户控件\n 15.1.2 把页面转换成用户控件\n 15.2 为用户控件添加代码\n 15.2.1 处理\u003Cem\u003E事件\u003C\u002Fem\u003E\n 15.2.2 添加属性\n 15.2.3 使用自定义对象\n 15.2.4 添加\u003Cem\u003E事件\u003C\u002Fem\u003E\n 15.2.5 公开内部Web控件\n 15.3 动态加载用户控件\n 15.4 局部页面缓存\n 15.4.1 VaryByControl\n 15.4.2 共享缓存控件\n 15.5 总结\n 第16章 主题和母版页\n 16.1 层叠样式表\n 16.1.1 创建样式表\n 16.1.2 应用样式表规则\n 16.2 主题\n 16.2.1 主题文件夹和外观\n 16.2.2 应用简单主题\n 16.2.3 处理主题冲突\n 16.2.4 为同一控件创建多个外观\n 16.2.5 含有模板和图片的外观\n 16.2.6 在主题里使用CSS\n 16.2.7 通过配置文件来应用主题\n 16.2.8 动态应用主题\n 16.3 标准化网站布局\n 16.4 母版页基础\n 16.4.1 简单的母版页\n 16.4.2 简单的内容页\n 16.4.3 默认内容\n 16.4.4 具有表格和CSS布局的母版页\n 16.4.5 母版页和相对路径\n 16.4.6 通过配置文件应用母版页\n 16.5 高级母版页\n 16.5.1 和母版页类交互\n 16.5.2 动态设置母版页\n 16.5.3 嵌套母版页\n 16.6 总结\n 第17章 网站导航\n 17.1 多视图页面\n 17.1.1 MultiView控件\n 17.1.2 Wizard控件\n 17.2 站点地图\n 17.2.1 定义站点地图\n 17.2.2 绑定站点地图\n 17.2.3 导航路径\n 17.2.4 显示站点地图的一部分\n 17.2.5 站点地图对象\n 17.2.6 加入自定义站点地图信息\n 17.2.7 创建自定义的SiteMapProvider\n 17.2.8 安全调整\n 17.3 URL映射和路由\n 17.3.1 URL映射\n 17.3.2 URL路由\n 17.4 TreeView控件\n 17.4.1 TreeNode\n 17.4.2 按需填充节点\n 17.4.3 TreeView样式\n 17.5 Menu控件\n 17.5.1 Menu样式\n 17.5.2 Menu模板\n 17.6 总结\n 第18章 网站部署\n 18.1 安装和配置IIS\n 18.1.1 安装IIS 7\n 18.1.2 管理IIS 7\n 18.2 部署网站\n 18.2.1 通过复制文件进行部署\n 18.2.2 使用Web部署\n 18.2.3 通过FTP部署\n 18.3 管理网站\n 18.3.1 创建新站点\n 18.3.2 创建虚拟目录\n 18.3.3 使用VirtualPathProvider\n 18.3.4 使用应用程序池\n 18.3.5 使用应用程序预热\n 18.4 扩展集成管道\n 18.4.1 创建处理程序\n 18.4.2 部署处理程序\n 18.4.3 配置处理程序\n 18.4.4 测试处理程序\n 18.5 总结\n 第四部分 安全\n 第19章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET安全模型\n 19.1 为何创建安全软件\n 19.1.1 理解潜在的威胁\n 19.1.2 安全编程原则\n 19.1.3 理解Gatekeeper\n 19.2 理解安全级别\n 19.2.1 验证\n 19.2.2 授权\n 19.2.3 机密性和完整性\n 19.2.4 互相协作\n 19.3 理解SSL\n 19.3.1 理解证书\n 19.3.2 理解SSL\n 19.3.3 在IIS 7.x\u003Cem\u003E中\u003C\u002Fem\u003E配置SSL\n 19.4 总结\n 第20章 表单验证\n 20.1 表单验证介绍\n 20.1.1 为什么使用表单验证\n 20.1.2 为什么不使用表单验证\n 20.1.3 为什么不自己\u003Cem\u003E实现\u003C\u002Fem\u003Ecookie验证\n 20.1.4 表单验证类\n 20.2 \u003Cem\u003E实现\u003C\u002Fem\u003E表单验证\n 20.2.1 配置表单验证\n 20.2.2 禁止匿名用户访问\n 20.2.3 创建自定义登录页面\n 20.2.4 自定义凭证存储\n 20.2.5 表单验证\u003Cem\u003E中\u003C\u002Fem\u003E的持久化cookie\n 20.3 IIS 7.x和表单验证\n 20.4 总结\n 第21章 成员资格\n 21.1 介绍\u003Cem\u003EASP\u003C\u002Fem\u003E.NET的成员资格API\n 21.2 使用成员资格API\n 21.2.1 配置表单验证\n 21.2.2 创建数据存储\n 21.2.3 配置连接字符串和成员资格提供程序\n 21.2.4 创建并验证用户\n 21.3 使用安全控件\n 21.3.1 Login控件\n 21.3.2 LoginStatus控件\n 21.3.3 LoginView控件\n 21.3.4 PasswordRecovery控件\n 21.3.5 ChangePassword控件\n 21.3.6 CreateUserWizard控件\n 21.4 在IIS 7.x里配置成员资格\n 21.4.1 配置提供程序和用户\n 21.4.2 在其他应用程序里使用成员资格API\n 21.5 使用Membership类\n 21.5.1 从存储\u003Cem\u003E中\u003C\u002Fem\u003E获得用户\n 21.5.2 更新存储\u003Cem\u003E中\u003C\u002Fem\u003E的用户\n 21.5.3 创建和删除用户\n 21.5.4 检验用户\n 21.6 总结\n 第22章 Windows验证\n 22.1 介绍Windows验证\n 22.1.1 为什么使用Windows验证\n 22.1.2 为什么不使用Windows验证\n 22.1.3 Windows验证机制\n 22.2 \u003Cem\u003E实现\u003C\u002Fem\u003EWindows验证\n 22.2.1 配置IIS 7.x\n 22.2.2 配置\u003Cem\u003EASP\u003C\u002Fem\u003E.NET\n 22.2.3 IIS 7.x管道\n 22.2.4 禁止匿名用户访问\n 22.2.5 访问Windows用户信息\n 22.3 身份模拟\n 22.3.1 Windows\u003Cem\u003E中\u003C\u002Fem\u003E的身份模拟和委托\n 22.3.2 经过配置的身份模拟\n 22.3.3 可编程的身份模拟\n 22.4 总结\n 第23章 授权和角色\n 23.1 URL 授权\n 23.2 文件授权\n 23.3 在代码\u003Cem\u003E中\u003C\u002Fem\u003E检查授权\n 23.3.1 使用IsInRole()方法\n 23.3.2 使用PrincipalPermission类\n 23.4 为基于角色的授权使用角色API\n 23.4.1 和角色一起使用LoginView控件\n 23.4.2 通过编程访问角色\n 23.4.3 在Windows验证\u003Cem\u003E中\u003C\u002Fem\u003E使用角色API\n 23.5 IIS 7.x里的授权和角色\n 23.5.1 在IIS 7.x里使用\u003Cem\u003EASP\u003C\u002Fem\u003E.NET角色授权\n 23.5.2 在IIS 7.x\u003Cem\u003E中\u003C\u002Fem\u003E管理\u003Cem\u003EASP\u003C\u002Fem\u003E.NET角色\n 23.6 总结\n 第24章 用户配置\n 24.1 理解用户配置\n 24.1.1 用户配置的性能\n 24.1.2 用户配置如何存储数据\n 24.1.3 用户配置和验证\n 24.1.4 用户配置与自定义的数据组件\n 24.2 使用SqlProfileProvider\n 24.2.1 创建用户配置表\n 24.2.2 配置提供程序\n 24.2.3 定义用户配置属性\n 24.2.4 使用用户配置属性\n 24.2.5 用户配置序列化\n 24.2.6 用户配置组\n 24.2.7 用户配置和自定义的数据类型\n 24.2.8 用户配置API\n 24.2.9 匿名用户配置\n 24.3 自定义的用户配置提供程序\n 24.3.1 自定义的用户配置提供程序类\n 24.3.2 设计FactoredProfileProvider\n 24.3.3 通过编码\u003Cem\u003E实现\u003C\u002Fem\u003EFactoredProfileProvider\n 24.3.4 测试FactoredProfileProvider\n 24.4 总结\n 第25章 加密\n 25.1 加密数据:机密性问题\n 25.2 .NET加密命名空间\n 25.3 理解.NET加密类\n 25.3.1 对称加密算法\n 25.3.2 非对称加密\n 25.3.3 抽象加密类\n 25.3.4 ICryptoTransform接口\n 25.3.5 CryptoStream类\n 25.4 加密敏感数据\n 25.4.1 管理秘密信息\n 25.4.2 使用对称算法\n 25.4.3 使用非对称算法\n 25.4.4 加密数据库\u003Cem\u003E中\u003C\u002Fem\u003E的敏感数据\n 25.5 加密查询字符串\n 25.5.1 包装查询字符串\n 25.5.2 创建一个测试页面\n 25.6 总结\n 第26章 自定义成员资格提供程序\n 26.1 自定义提供程序的架构\n 26.2 创建自定义提供程序的基本步骤\n 26.2.1 自定义提供程序的总体设计\n 26.2.2 设计并\u003Cem\u003E实现\u003C\u002Fem\u003E自定义存储\n 26.2.3 \u003Cem\u003E实现\u003C\u002Fem\u003E提供程序类\n 26.2.4 使用自定义提供程序类\n 26.3 总结\n 第五部分 高级用户界面\n 第27章 自定义服务器控件\n 27.1 自定义服务器控件入门\n 27.1.1 创建简单的自定义控件\n 27.1.2 使用自定义控件\n 27.1.3 工具箱\u003Cem\u003E中\u003C\u002Fem\u003E的自定义控件\n 27.1.4 创建支持样式属性的Web控件\n 27.1.5 呈现过程\n 27.2 处理不同的浏览器\n 27.2.1 HtmlTextWriter\n 27.2.2 浏览器检测\n 27.2.3 浏览器属性\n 27.2.4 覆盖浏览器类型侦测\n 27.2.5 自适应呈现\n 27.3 控件状态和\u003Cem\u003E事件\u003C\u002Fem\u003E\n 27.3.1 视图状态\n 27.3.2 控件状态\n 27.3.3 回传数据和change\u003Cem\u003E事件\u003C\u002Fem\u003E\n 27.3.4 \u003Cem\u003E触发\u003C\u002Fem\u003E回传\n 27.4 扩展现有的Web控件\n 27.4.1 组合控件\n 27.4.2 派生控件\n 27.5 总结\n 第28章 图形、GDI+和图表\n 28.1 ImageMap控件\n 28.1.1 创建热点\n 28.1.2 处理热点单击\n 28.1.3 自定义热点\n 28.2 使用GDI+画图\n 28.2.1 简单绘制\n 28.2.2 图像格式和质量\n 28.2.3 Graphics类\n 28.2.4 使用GraphicsPath\n 28.2.5 画笔\n 28.2.6 画刷\n 28.3 在网页上嵌入动态图形\n 28.3.1 使用PNG格式\n 28.3.2 传递信息给动态图像\n 28.3.3 使用GDI+的自定义控件\n 28.4 使用Chart控件\n 28.4.1 创建基本的图表\n 28.4.2 用数据填充图表\n 28.5 总结\n 第29章 JavaScript和Ajax技术\n 29.1 JavaScript本质\n 29.1.1 HTML DOM\n 29.1.2 客户端\u003Cem\u003E事件\u003C\u002Fem\u003E\n 29.1.3 脚本块\n 29.1.4 操纵HTML元素\n 29.1.5 调试JavaScript\n 29.2 基本的JavaScript示例\n 29.2.1 创建JavaScript页面处理器\n 29.2.2 使用JavaScript异步下载图片\n 29.2.3 呈现脚本块\n 29.3 脚本注入攻击\n 29.3.1 请求验证\n 29.3.2 禁用请求验证\n 29.3.3 扩展请求验证\n 29.4 带有JavaScript的自定义控件\n 29.4.1 弹出窗口\n 29.4.2 滚动按钮\n 29.5 框架\n 29.5.1 框架导航\n 29.5.2 内联框架\n 29.6 理解Ajax\n 29.6.1 XMLHttpRequest对象\n 29.6.2 Ajax示例\n 29.7 在客户端回调\u003Cem\u003E中\u003C\u002Fem\u003E使用Ajax\n 29.7.1 创建客户端回调\n 29.7.2 深入了解客户端回调\n 29.7.3 自定义控件里的客户端回调\n 29.8 总结\n 第30章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX\n 30.1 介绍\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX\n 30.1.1 客户端的\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX:脚本库\n 30.1.2 服务器端的\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX:ScriptManager\n 30.2 服务器回调\n 30.2.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX\u003Cem\u003E中\u003C\u002Fem\u003E的Web服务\n 30.2.2 在页面里放置Web方法\n 30.2.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX应用程序服务\n 30.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX服务器控件\n 30.3.1 使用UpdatePanel的局部呈现\n 30.3.2 使用\u003Cem\u003ETimer\u003C\u002Fem\u003E的\u003Cem\u003E定时\u003C\u002Fem\u003E刷新\n 30.3.3 使用UpdateProgress的耗时更新\n 30.3.4 管理浏览器历史\n 30.4 深入客户端库\n 30.4.1 理解客户端模型\n 30.4.2 JavaScript的面向对象编程\n 30.4.3 网页框架\n 30.5 控件扩展器\n 30.5.1 安装\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX控件工具包\n 30.5.2 AutoCompleteExtender\n 30.5.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX控件工具包\n 30.6 总结\n 第31章 使用Web部件页面的门户网站\n 31.1 典型门户页面\n 31.2 基本Web部件页面\n 31.2.1 创建页面设计\n 31.2.2 WebPartManager和WebPartZone\n 31.2.3 向页面添加Web部件\n 31.2.4 定制页面\n 31.3 创建Web部件\n 31.3.1 简单的Web部件任务\n 31.3.2 开发高级Web部件\n 31.3.3 Web部件编辑器\n 31.3.4 连接Web部件\n 31.3.5 自定义动词和Web部件\n 31.3.6 用户控件和高级Web部件\n 31.3.7 动态上传Web部件\n 31.3.8 对Web部件的授权\n 31.3.9 个性化的最后任务\n 31.4 总结\n 第32章 MVC\n 32.1 MVC和Web表单的选择\n 32.2 创建基本的MVC应用程序\n 32.2.1 创建模型\n 32.2.2 创建控制器\n 32.2.3 创建Index视图\n 32.2.4 测试(未完成的)应用程序\n 32.2.5 完成控制器和视图\n 32.2.6 修改Site.Master文件\n 32.3 扩展基础的MVC应用程序\n 32.3.1 配置路由\n 32.3.2 增加错误处理\n 32.3.3 增加验证\n 32.3.4 增强数据存储访问\n 32.3.5 增加对外键约束的支持\n 32.4 自定义视图\n 32.4.1 修改视图\n 32.4.2 增加视图数据\n 32.5 强化模型\n 32.6 验证数据\n 32.6.1 执行基本的验证\n 32.6.2 增加验证标注\n 32.7 使用动作结果\n 32.7.1 返回JSON数据\n 32.7.2 调用其他控制器方法\n 32.8 总结\n 第33章 动态数据\n 33.1 创建动态数据应用程序\n 33.1.1 创建动态数据网站\n 33.1.2 检验动态数据网站\n 33.2 深入理解动态数据项目\n 33.3 自定义动态数据网站\n 33.3.1 使用模板进行自定义\n 33.3.2 使用路由进行自定义\n 33.3.3 使用元数据进行自定义\n 33.3.4 自定义验证\n 33.4 总结\n 第34章 Silverlight\n 34.1 理解Silverlight\n 34.1.1 Silverlight与Flash对比\n 34.1.2 Silverlight系统需求\n 34.2 创建Silverlight解决方案\n 34.2. 1 Silverlight编译\n 34.2.2 入口页面\n 34.3 创建Silverlight项目\n 34.3.1 设计Silverlight页面\n 34.3.2 理解XAML\n 34.3.3 设置属性\n 34.3.4 XAML 代码隐藏\n 34.3.5 处理\u003Cem\u003E事件\u003C\u002Fem\u003E\n 34.3.6 了解Silverlight类库\n 34.4 布局\n 34.4.1 Canvas\n 34.4.2 网格\n 34.5 动画\n 34.5.1 动画基础知识\n 34.5.2 定义动画\n 34.5.3 StoryBoard类\n 34.5.4 交互式动画实例\n 34.5.5 变换\n 34.6 Silverlight使用Web服务\n 34.6.1 创建Web服务\n 34.6.2 添加Web引用\n 34.6.3 调用Web服务\n 34.6.4 配置Web服务URL\n 34.6.5 跨域Web服务调用\n 34.7 总结","createTime":"2013-08-19 05:43:51","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-5972237-bbs-26590.264^v3^pc_relevant_bbs_down_cate&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-5972237-bbs-26590.264^v3^pc_relevant_bbs_down_cate","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fmail2u\u002F5972237\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-5972237-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fmail2u\u002F5972237\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-5972237-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fedu.csdn.net\u002Fcourse\u002Fdetail\u002F4065","title":"\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 第八季 ajax技术","desc":"主讲内容:第一讲 \u003Cem\u003Easp\u003C\u002Fem\u003E.net ajax简介第二讲 ScriptManager脚本管理控件第三讲 ScriptManager脚本管理控件 (2)第四讲 UpdatePanel局部更新控件第五讲 \u003Cem\u003ETimer\u003C\u002Fem\u003E\u003Cem\u003E定时\u003C\u002Fem\u003E器控件实例","createTime":"2017-02-17 14:44:44","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-2-4065-bbs-26590.264^v3^pc_relevant_bbs_down_cate&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-2-4065-bbs-26590.264^v3^pc_relevant_bbs_down_cate","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fedu.csdn.net\u002Fcourse\u002Fdetail\u002F4065\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-2-4065-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fedu.csdn.net\u002Fcourse\u002Fdetail\u002F4065\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-2-4065-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"course"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fpanyong001\u002F4697033","title":"\u003Cem\u003EASP\u003C\u002Fem\u003E.NET4高级程序设计(第4版) 3\u002F3","desc":"内容简介\n  《\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4高级程序设计(第4版)》是\u003Cem\u003EASP\u003C\u002Fem\u003E.NET领域的鸿篇巨制,全面讲解了\u003Cem\u003EASP\u003C\u002Fem\u003E.NET4的各种特性及其背后的工作原理,并给出了许多针对如何构建复杂、可扩展的网站从实践\u003Cem\u003E中\u003C\u002Fem\u003E得出的建议。书\u003Cem\u003E中\u003C\u002Fem\u003E还深入讲述了其他\u003Cem\u003EASP\u003C\u002Fem\u003E.NET图书遗漏的高级主题,如自定义控件的创建、图像处理、加密等。此外,《\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4高级程序设计(第4版)》专门提供了两章的内容来教你如何用Ajax 技术制作快速响应的页面,以及如何使用微软的\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX平台。另外,还专门介绍了\u003Cem\u003EASP\u003C\u002Fem\u003E.NET4 新增的功能,如MVC 和动态数据等。\n\n  《\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 4高级程序设计(第4版)》适合各层次的\u003Cem\u003EASP\u003C\u002Fem\u003E.NET程序员阅读。\n\n作者简介\n作者:(美)麦克唐纳\n目录\n第一部分 核心概念\n\n第1章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET简介 2\n1.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET的7大要点 2\n1.1.1 要点1:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET是同.NETFramework集成在一起的 2\n1.1.2 要点2:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET是编译执行的,而不是解释执行的 3\n1.1.3 要点3:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET支持多语言 4\n1.1.4 要点4:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET运行在公共语言运行库内 6\n1.1.5 要点5:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET是面向对象的 7\n1.1.6 要点6:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET支持所有的浏览器 8\n1.1.7 要点7:\u003Cem\u003EASP\u003C\u002Fem\u003E.NET易于部署和配置 8\n1.2 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET的演变 9\n1.2.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET1.0和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET1.1 9\n1.2.2  \u003Cem\u003EASP\u003C\u002Fem\u003E.NET2.0 9\n1.2.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET3.5 10\n1.2.4 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET4 12\n1.2.5 Silverlight 14\n1.3 总结 15\n\n第2章 Visual Studio 16\n2.1 Visual Studio 16\n2.1.1 网站和Web项目 17\n2.1.2 创建无项目文件的网站 18\n2.1.3 设计网页 21\n2.2 Visual StudioIDE 26\n2.2.1 解决方案资源管理器 28\n2.2.2 文档窗口 29\n2.2.3 工具箱 29\n2.2.4 错误列表和任务列表 30\n2.2.5 服务器资源管理器 31\n2.3 代码编辑器 32\n2.3.1 添加程序集引用 33\n2.3.2 智能感知和大纲显示 35\n2.3.3 Visual Studio 2010改进 37\n2.4 编码模型 42\n2.4.1 代码隐藏文件如何与页面连接 44\n2.4.2 控件标签如何与页面变量连接 44\n2.4.3 \u003Cem\u003E事件\u003C\u002Fem\u003E如何与\u003Cem\u003E事件\u003C\u002Fem\u003E处理程序连接 46\n2.5 Web项目 47\n2.5.1 基于项目的开发 47\n2.5.2 创建Web项目 48\n2.5.3 迁移旧版Visual Studio创建的网站 49\n2.6 Visual Studio调试 51\n2.6.1 单步调试 52\n2.6.2 变量监视 54\n2.6.3 高级断点 55\n2.7 WebDevelopment Helper 56\n2.8 总结 57\n\n第3章 Web窗体 58\n3.1 页面处理 58\n3.1.1 HTML表单 59\n3.1.2 动态用户界面 60\n3.1.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET\u003Cem\u003E事件\u003C\u002Fem\u003E模型 61\n3.1.4 \u003Cem\u003E自动\u003C\u002Fem\u003E回送 62\n3.1.5 视图状态 63\n3.1.6 XHTML兼容性 66\n3.1.7 客户端控件ID 71\n3.2 Web窗体处理阶段 73\n3.2.1 页面框架初始化 74\n3.2.2 用户代码初始化 74\n3.2.3 验证 74\n3.2.4 \u003Cem\u003E事件\u003C\u002Fem\u003E处理 75\n3.2.5 \u003Cem\u003E自动\u003C\u002Fem\u003E数据绑定 75\n3.2.6 清除 76\n3.2.7 页面流示例 76\n3.3 作为控件容器的页面 78\n3.3.1 显示控件树 78\n3.3.2 页头 82\n3.3.3 动态控件的创建 82\n3.4 Page类 84\n3.4.1 Session、Application和Cache 84\n3.4.2 Request 85\n3.4.3 Response 86\n3.4.4 Server 88\n3.4.5 User 90\n3.4.6 Trace 91\n3.4.7 访问其他类\u003Cem\u003E中\u003C\u002Fem\u003E的HTTP上下文 96\n3.5 总结 96\n\n第4章 服务器控件 97\n4.1 服务器控件的类型 97\n4.2 HTML服务器控件 99\n4.2.1 HtmlControl类 100\n4.2.2 HtmlContainerControl类 100\n4.2.3 HtmlInputControl类 100\n4.2.4 HTML服务器控件类 101\n4.2.5 设置Style特性和其他属性 102\n4.2.6 通过编程创建服务器控件 103\n4.2.7 处理服务器端\u003Cem\u003E事件\u003C\u002Fem\u003E 104\n4.3 Web控件 107\n4.3.1 WebControl基类 107\n4.3.2 基本的Web控件类 108\n4.3.3 单位 109\n4.3.4 枚举 110\n4.3.5 颜色 110\n4.3.6 字体 111\n4.3.7 焦点 12\n4.3.8 默认按钮 113\n4.3.9 可滚动面板 114\n4.3.10 处理Web控件\u003Cem\u003E事件\u003C\u002Fem\u003E 114\n4.4 List控件 116\n4.4.1 Selectable列表控件 117\n4.4.2 BulletedList控件 120\n4.5 输入验证控件 121\n4.5.1 验证控件 121\n4.5.2 验证流程 122\n4.5.3 BaseValidator类 122\n4.5.4 RequiredFieldValidator控件 124\n4.5.5 RangeValidator控件 124\n4.5.6 CompareValidator控件 125\n4.5.7 RegularExpressionValidator控件 125\n4.5.8 CustomValidator控件 127\n4.5.9 ValidationSummary控件 128\n4.5.10 通过编程使用验证器 129\n4.5.11 验证组 130\n4.6 富控件 132\n4.6.1 AdRotator控件 132\n4.6.2 Calendar控件 134\n4.7 总结 136\n\n第5章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用程序 137\n5.1 剖析\u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用程序 137\n5.1.1 应用程序域 137\n5.1.2 应用程序生命周期 138\n5.1.3 应用程序更新 139\n5.1.4 应用程序目录结构 139\n5.2 global.asax应用程序文件 140\n5.2.1 应用程序\u003Cem\u003E事件\u003C\u002Fem\u003E 141\n5.2.2 演示应用程序\u003Cem\u003E事件\u003C\u002Fem\u003E 143\n5.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET配置 144\n5.3.1 machine.config文件 144\n5.3.2 web.config文件 147\n5.3.3 设置 150\n5.3.4  150\n5.3.5  150\n5.3.6  152\n5.3.7 通过编程读写配置节 152\n5.3.8 网站管理工具(WAT) 155\n5.3.9 扩展配置文件结构 156\n5.3.10 加密配置节 159\n5.4 .NET组件 161\n5.4.1 创建组件 161\n5.4.2 通过App_Code目录使用组件 162\n5.4.3 通过Bin目录使用组件 163\n5.5 扩展HTTP管道 165\n5.5.1 HTTP处理程序 165\n5.5.2 创建自定义的HTTP处理程序 167\n5.5.3 配置自定义的HTTP处理程序 168\n5.5.4 使用无须配置的HTTP处理程序 169\n5.5.5 创建高级的HTTP处理程序 169\n5.5.6 为非HTML内容创建HTTP处理程序 171\n5.5.7 HTTP模块 173\n5.5.8 创建自定义HTTP模块 174\n5.6 总结 176\n\n第6章 状态管理 177\n6.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET状态管理 177\n6.2 视图状态 179\n6.2.1 视图状态示例 180\n6.2.2 在视图状态\u003Cem\u003E中\u003C\u002Fem\u003E保存对象 181\n6.2.3 视图状态评估 183\n6.2.4 有选择地禁用视图状态 184\n6.2.5 视图状态安全 185\n6.3 在页面间传送信息 186\n6.3.1 查询字符串 187\n6.3.2 跨页回发 188\n6.4 cookie 193\n6.5 会话状态 194\n6.5.1 会话架构 194\n6.5.2 使用会话状态 196\n6.5.3 配置会话状态 197\n6.5.4 会话状态安全 202\n6.6 应用程序状态 203\n6.7 总结 206\n\n第二部分 数据访问\n\n第7章 基础 208\n7.1 ADO.NET架构 209\n7.1.1 ADO.NET数据提供程序 209\n7.1.2 ADO.NET的标准化 210\n7.1.3 基本ADO.NET类 211\n7.2 Connection类 212\n7.2.1 连接字符串 212\n7.2.2 测试连接 214\n7.2.3 连接池 215\n7.3 Command类和DataReader类 217\n7.3.1 Command基础 217\n7.3.2 DataReader类 218\n7.3.3  ExecuteReader()方法和DataReader 218\n7.3.4 ExecuteScalar()方法 223\n7.3.5 ExecuteNonQuery()方法 223\n7.3.6 SQL注入攻击 224\n7.3.7 使用参数化命令 226\n7.3.8 调用存储过程 227\n7.4 事务 229\n7.4.1 事务和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用程序 230\n7.4.2 隔离级别 234\n7.4.3 保存点 235\n7.5 提供程序无关的代码 235\n7.5.1 创建工厂 236\n7.5.2 用工厂创建对象 237\n7.5.3 使用提供程序无关的代码的查询 237\n7.6 总结 239\n\n第8章 数据组件和DataSet 240\n8.1 构建数据访问组件 240\n8.1.1 数据包 241\n8.1.2 存储过程 242\n8.1.3 数据应用类 243\n8.1.4 测试数据库组件 248\n8.2 非连接的数据 249\n8.2.1 Web应用程序和DataSet 250\n8.2.2 XML集成 251\n8.3 DataSet类 251\n8.4  DataAdapter类 252\n8.4.1 填充DataSet 253\n8.4.2 使用多个表和关系 254\n8.4.3 查找特定行 257\n8.4.4 在数据访问类里使用DataSet 257\n8.4.5 数据绑定 258\n8.5 DataView类 259\n8.5.1 使用DataView排序 259\n8.5.2 使用DataView过滤 261\n8.5.3 使用关系的高级过滤 262\n8.5.4 计算列 263\n8.6 总结 264\n\n第9章 数据绑定 265\n9.1 基本的数据绑定 265\n9.1.1 单值绑定 266\n9.1.2 其他类型的表达式 268\n9.1.3 重复值绑定 271\n9.2 数据源控件 277\n9.3 SqlDataSource 278\n9.3.1 选择记录 279\n9.3.2 参数化命令 281\n9.3.3 错误处理 285\n9.3.4 更新记录 286\n9.3.5 删除记录 289\n9.3.6 插入记录 289\n9.3.7 SqlDataSource的不足 290\n9.4 ObjectDataSource 291\n9.4.1 选择记录 291\n9.4.2 更新记录 295\n9.4.3 使用数据对象执行更新 296\n9.5 数据源控件的限制 299\n9.5.1 问题 299\n9.5.2 添加其他项 300\n9.5.3 使用SqlDataSource处理其他选项 301\n9.5.4 使用ObjectDataSource处理其他选项 301\n9.6 总结 302\n\n第10章 富数据控件 303\n10.1 GridView 303\n10.2 格式化GridView 307\n10.2.1 格式化字段 307\n10.2.2 样式 308\n10.2.3 格式化特定值 311\n10.3 GridView行选择 313\n10.3.1 使用选择来创建主-从表单 314\n10.3.2 SelectedIndexChanged\u003Cem\u003E事件\u003C\u002Fem\u003E 315\n10.3.3 将数据字段用作选择按钮 315\n10.4 对GridView排序 316\n10.4.1 使用SqlDataSource排序 317\n10.4.2 使用ObjectDataSource排序 318\n10.4.3 排序和选择 319\n10.4.4 高级排序 319\n10.5 GridView分页 320\n10.5.1 \u003Cem\u003E自动\u003C\u002Fem\u003E分页 320\n10.5.2 分页和选择 322\n10.5.3 ObjectDataSource的自定义分页 322\n10.5.4 定制分页栏 324\n10.6 GridView模板 325\n10.6.1 使用多个模板 327\n10.6.2 在Visual Studio\u003Cem\u003E中\u003C\u002Fem\u003E编辑模板 328\n10.6.3 绑定到方法 328\n10.6.4 处理模板\u003Cem\u003E中\u003C\u002Fem\u003E的\u003Cem\u003E事件\u003C\u002Fem\u003E 330\n10.6.5 使用模板编辑 330\n10.6.6 模板\u003Cem\u003E中\u003C\u002Fem\u003E的客户端ID 335\n10.7 ListView 336\n10.7.1 分组 338\n10.7.2 分页 340\n10.8 DetailsView和FormView 341\n10.8.1 DetailsView 341\n10.8.2 FormView 344\n10.9 高级网格 345\n10.9.1 GridView\u003Cem\u003E中\u003C\u002Fem\u003E的汇总 345\n10.9.2 单个表\u003Cem\u003E中\u003C\u002Fem\u003E的父\u002F子视图 347\n10.9.3 使用查找表编辑字段 349\n10.9.4 处理来自数据库的图片 351\n10.9.5 探测并发冲突 355\n10.10 总结 359\n\n第11章 缓存和异步页面 360\n11.1 理解\u003Cem\u003EASP\u003C\u002Fem\u003E.NET缓存 360\n11.2 输出缓存 361\n11.2.1 声明性的输出缓存 361\n11.2.2 缓存和查询字符串 362\n11.2.3 使用特定查询字符串参数的缓存 363\n11.2.4 自定义缓存控制 364\n11.2.5 使用HttpCachePolicy类进行缓存 365\n11.2.6 缓存后替换和部分页缓存 365\n11.2.7 缓存用户配置 367\n11.2.8 缓存配置 368\n11.2.9 输出缓存扩展 369\n11.3 数据缓存 373\n11.3.1 向缓存添加项目 373\n11.3.2 简单的缓存测试 375\n11.3.3 缓存优先级 376\n11.3.4 使用数据源控件的缓存 376\n11.4 缓存依赖 379\n11.4.1 文件和缓存项目依赖 379\n11.4.2 聚合依赖 380\n11.4.3 移除项目回调 381\n11.4.4 理解SQL缓存通知 383\n11.4.5 缓存通知的工作方式 384\n11.4.6 启用通知 384\n11.4.7 创建缓存依赖 385\n11.5 自定义缓存依赖 386\n11.5.1 基本的自定义缓存依赖 386\n11.5.2 使用消息队列的自定义缓存依赖 387\n11.6 异步页面 389\n11.6.1 创建异步页面 390\n11.6.2 在异步页面\u003Cem\u003E中\u003C\u002Fem\u003E查询数据 392\n11.6.3 错误处理 393\n11.6.4 在异步任务\u003Cem\u003E中\u003C\u002Fem\u003E使用缓存 395\n11.6.5 多异步任务和超时 397\n11.7 总结 399\n\n第12章 文件和流 400\n12.1 使用文件系统 400\n12.1.1 Directory类和File类 400\n12.1.2 DirectoryInfo类和FileInfo类 402\n12.1.3 DriveInfo类 404\n12.1.4 使用Attributes 405\n12.1.5 使用通配符过滤文件 407\n12.1.6 获取文件的版本信息 407\n12.1.7 Path类 408\n12.1.8 文件浏览器 410\n12.2 使用流读写文件 414\n12.2.1 文本文件 415\n12.2.2 二进制文件 416\n12.2.3 上传文件 417\n12.2.4 使文件对多用户安全 419\n12.2.5 压缩 423\n12.3 序列化 423\n12.4 总结 426\n\n第13章 LINQ 427\n13.1 LINQ基础 427\n13.1.1 延迟执行 429\n13.1.2 LINQ是如何工作的 429\n13.1.3 LINQ表达式 430\n13.1.4 揭秘LINQ表达式 436\n13.2 LINQ to DataSet 439\n13.2.1 强类型的DataSet 441\n13.2.2 空值 441\n13.3 LINQ to Entities 441\n13.3.1 生成数据模型 442\n13.3.2 数据模型类 442\n13.3.3 实体关系 444\n13.3.4 查询存储过程 446\n13.3.5 LINQ to Entities查询揭秘 447\n13.4 数据库操作 452\n13.4.1 插入 452\n13.4.2 更新 454\n13.4.3 删除 454\n13.4.4 管理并发 455\n13.4.5 处理并发冲突 455\n13.5 EntityDataSource控件 459\n13.5.1 显示数据 459\n13.5.2 获取关联数据 463\n13.5.3 编辑数据 464\n13.5.4 验证 464\n13.6 使用QueryExtender控件 465\n13.6.1 使用SearchExperssion 466\n13.6.2 使用RangeExpression 467\n13.6.3 使用PropertyExpression 467\n13.6.4 使用MethodExpression 468\n13.7 总结 468\n\n第14章 XML 470\n14.1 什么时候使用XML 470\n14.2 XML简介 471\n14.2.1 XML的优点 472\n14.2.2 格式良好的XML 472\n14.2.3 XML命名空间 473\n14.2.4 XML架构 474\n14.3 基于流的XML处理 475\n14.3.1 写XML文件 476\n14.3.2 读取XML文件 478\n14.4 内存\u003Cem\u003E中\u003C\u002Fem\u003E的XML处理 481\n14.4.1 XmlDocument 482\n14.4.2 XPathNavigator 485\n14.4.3 XDocument 486\n14.5 搜索XML内容 491\n14.5.1 搜索XmlDocument 491\n14.5.2 使用XPath搜索XmlDocument 493\n14.5.3 使用LINQ搜索XDocument 494\n14.6 验证XML内容 496\n14.6.1 基本架构 496\n14.6.2 验证XmlDocument 497\n14.6.3 使用XDocument进行验证 498\n14.7 转换XML内容 499\n14.7.1 基本的样式表 499\n14.7.2 使用XslCompiledTransform 500\n14.7.3 使用Xml控件 501\n14.7.4 使用LINQ to XML转换XML 502\n14.8 XML数据绑定 504\n14.8.1 非层次化绑定 504\n14.8.2 使用XPath 506\n14.8.3 嵌套的网格 508\n14.8.4 使用TreeView的层次化绑定 509\n14.8.5 使用XSLT 511\n14.8.6 绑定到来自其他源的XML内容 512\n14.8.7 通过XmlDataSource更新XML 513\n14.9 XML和ADO.NET数据集 513\n14.9.1 把DataSet转换为XML 514\n14.9.2 把DataSet作为XML访问 515\n14.10 总结 517\n\n第三部分 构建\u003Cem\u003EASP\u003C\u002Fem\u003E.NET网站\n\n第15章 用户控件 520\n15.1 用户控件基础 520\n15.1.1 创建简单的用户控件 521\n15.1.2 把页面转换成用户控件 522\n15.2 为用户控件添加代码 523\n15.2.1 处理\u003Cem\u003E事件\u003C\u002Fem\u003E 523\n15.2.2 添加属性 524\n15.2.3 使用自定义对象 525\n15.2.4 添加\u003Cem\u003E事件\u003C\u002Fem\u003E 528\n15.2.5 公开内部Web控件 530\n15.3 动态加载用户控件 531\n15.4 局部页面缓存 534\n15.4.1 VaryByControl 535\n15.4.2 共享缓存控件 536\n15.5 总结 537\n\n第16章 主题和母版页 538\n16.1 层叠样式表 538\n16.1.1 创建样式表 538\n16.1.2 应用样式表规则 540\n16.2 主题 542\n16.2.1 主题文件夹和外观 543\n16.2.2 应用简单主题 544\n16.2.3 处理主题冲突 545\n16.2.4 为同一控件创建多个外观 546\n16.2.5 含有模板和图片的外观 547\n16.2.6 在主题里使用CSS 549\n16.2.7 通过配置文件来应用主题 549\n16.2.8 动态应用主题 550\n16.3 标准化网站布局 551\n16.4 母版页基础 552\n16.4.1 简单的母版页 552\n16.4.2 简单的内容页 554\n16.4.3 默认内容 556\n16.4.4 具有表格和CSS布局的母版页 556\n16.4.5 母版页和相对路径 559\n16.4.6 通过配置文件应用母版页 559\n16.5 高级母版页 560\n16.5.1 和母版页类交互 560\n16.5.2 动态设置母版页 561\n16.5.3 嵌套母版页 561\n16.6 总结 563\n\n第17章 网站导航 564\n17.1 多视图页面 564\n17.1.1 MultiView控件 565\n17.1.2 Wizard控件 568\n17.2 站点地图 575\n17.2.1 定义站点地图 576\n17.2.2 绑定站点地图 577\n17.2.3 导航路径 578\n17.2.4 显示站点地图的一部分 580\n17.2.5 站点地图对象 583\n17.2.6 加入自定义站点地图信息 584\n17.2.7 创建自定义的SiteMapProvider 584\n17.2.8 安全调整 590\n17.3 URL映射和路由 592\n17.3.1 URL映射 592\n17.3.2 URL路由 593\n17.4 TreeView控件 594\n17.4.1 TreeNode 595\n17.4.2 按需填充节点 597\n17.4.3 TreeView样式 598\n17.5 Menu控件 601\n17.5.1 Menu样式 603\n17.5.2 Menu模板 605\n17.6 总结 606\n\n第18章 网站部署 607\n18.1 安装和配置IIS 607\n18.1.1 安装IIS 7 607\n18.1.2 管理IIS 7 608\n18.2 部署网站 610\n18.2.1 通过复制文件进行部署 611\n18.2.2 使用Web部署 614\n18.2.3 通过FTP部署 621\n18.3 管理网站 626\n18.3.1 创建新站点 626\n18.3.2 创建虚拟目录 627\n18.3.3 使用VirtualPathProvider 628\n18.3.4 使用应用程序池 631\n18.3.5 使用应用程序预热 633\n18.4 扩展集成管道 634\n18.4.1 创建处理程序 634\n18.4.2 部署处理程序 635\n18.4.3 配置处理程序 635\n18.4.4 测试处理程序 636\n18.5 总结 636\n\n第四部分 安全\n\n第19章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NET安全模型 638\n19.1 为何创建安全软件 638\n19.1.1 理解潜在的威胁 638\n19.1.2 安全编程原则 639\n19.1.3 理解Gatekeeper 640\n19.2 理解安全级别 641\n19.2.1 验证 641\n19.2.2 授权 642\n19.2.3 机密性和完整性 643\n19.2.4 互相协作 643\n19.3 理解SSL 644\n19.3.1 理解证书 645\n19.3.2 理解SSL 645\n19.3.3 在IIS 7.x\u003Cem\u003E中\u003C\u002Fem\u003E配置SSL 646\n19.4 总结 649\n\n第20章 表单验证 650\n20.1 表单验证介绍 650\n20.1.1 为什么使用表单验证 650\n20.1.2 为什么不使用表单验证 652\n20.1.3 为什么不自己\u003Cem\u003E实现\u003C\u002Fem\u003Ecookie验证 653\n20.1.4 表单验证类 654\n20.2 \u003Cem\u003E实现\u003C\u002Fem\u003E表单验证 655\n20.2.1 配置表单验证 655\n20.2.2 禁止匿名用户访问 657\n20.2.3 创建自定义登录页面 658\n20.2.4 自定义凭证存储 662\n20.2.5 表单验证\u003Cem\u003E中\u003C\u002Fem\u003E的持久化cookie 663\n20.3 IIS 7.x和表单验证 665\n20.4 总结 669\n\n第21章 成员资格 670\n21.1 介绍\u003Cem\u003EASP\u003C\u002Fem\u003E.NET的成员资格API 670\n21.2 使用成员资格API 672\n21.2.1 配置表单验证 673\n21.2.2 创建数据存储 674\n21.2.3 配置连接字符串和成员资格提供程序 679\n21.2.4 创建并验证用户 681\n21.3 使用安全控件 683\n21.3.1 Login控件 684\n21.3.2 LoginStatus控件 693\n21.3.3 LoginView控件 693\n21.3.4 PasswordRecovery控件 694\n21.3.5 ChangePassword控件 697\n21.3.6 CreateUserWizard控件 698\n21.4 在IIS 7.x里配置成员资格 702\n21.4.1 配置提供程序和用户 702\n21.4.2 在其他应用程序里使用成员资格API 703\n21.5 使用Membership类 705\n21.5.1 从存储\u003Cem\u003E中\u003C\u002Fem\u003E获得用户 706\n21.5.2 更新存储\u003Cem\u003E中\u003C\u002Fem\u003E的用户 708\n21.5.3 创建和删除用户 708\n21.5.4 检验用户 709\n21.6 总结 709\n\n第22章 Windows验证 710\n22.1 介绍Windows验证 710\n22.1.1 为什么使用Windows验证 710\n22.1.2 为什么不使用Windows验证 711\n22.1.3 Windows验证机制 712\n22.2 \u003Cem\u003E实现\u003C\u002Fem\u003EWindows验证 717\n22.2.1 配置IIS 7.x 717\n22.2.2 配置\u003Cem\u003EASP\u003C\u002Fem\u003E.NET 718\n22.2.3 IIS 7.x管道 719\n22.2.4 禁止匿名用户访问 722\n22.2.5 访问Windows用户信息 723\n22.3 身份模拟 727\n22.3.1 Windows\u003Cem\u003E中\u003C\u002Fem\u003E的身份模拟和委托 728\n22.3.2 经过配置的身份模拟 729\n22.3.3 可编程的身份模拟 729\n22.4 总结 732\n\n第23章 授权和角色 733\n23.1 URL 授权 733\n23.2 文件授权 738\n23.3 在代码\u003Cem\u003E中\u003C\u002Fem\u003E检查授权 739\n23.3.1 使用IsInRole()方法 739\n23.3.2 使用PrincipalPermission类 740\n23.4 为基于角色的授权使用角色API 742\n23.4.1 和角色一起使用LoginView控件 747\n23.4.2 通过编程访问角色 748\n23.4.3 在Windows验证\u003Cem\u003E中\u003C\u002Fem\u003E使用角色API 750\n23.5 IIS 7.x里的授权和角色 752\n23.5.1 在IIS 7.x里使用\u003Cem\u003EASP\u003C\u002Fem\u003E.NET角色授权 754\n23.5.2 在IIS 7.x\u003Cem\u003E中\u003C\u002Fem\u003E管理\u003Cem\u003EASP\u003C\u002Fem\u003E.NET角色 756\n23.6 总结 757\n\n第24章 用户配置 758\n24.1 理解用户配置 758\n24.1.1 用户配置的性能 758\n24.1.2 用户配置如何存储数据 759\n24.1.3 用户配置和验证 760\n24.1.4 用户配置与自定义的数据组件 760\n24.2 使用SqlProfileProvider 761\n24.2.1 创建用户配置表 761\n24.2.2 配置提供程序 763\n24.2.3 定义用户配置属性 764\n24.2.4 使用用户配置属性 764\n24.2.5 用户配置序列化 766\n24.2.6 用户配置组 767\n24.2.7 用户配置和自定义的数据类型 768\n24.2.8 用户配置API 771\n24.2.9 匿名用户配置 773\n24.3 自定义的用户配置提供程序 775\n24.3.1 自定义的用户配置提供程序类 775\n24.3.2 设计FactoredProfileProvider 777\n24.3.3 通过编码\u003Cem\u003E实现\u003C\u002Fem\u003EFactoredProfileProvider 778\n24.3.4 测试FactoredProfileProvider 781\n24.4 总结 784\n\n第25章 加密 785\n25.1 加密数据:机密性问题 785\n25.2 .NET加密命名空间 786\n25.3 理解.NET加密类 789\n25.3.1 对称加密算法 790\n25.3.2 非对称加密 791\n25.3.3 抽象加密类 791\n25.3.4 ICryptoTransform接口 792\n25.3.5 CryptoStream类 793\n25.4 加密敏感数据 793\n25.4.1 管理秘密信息 794\n25.4.2 使用对称算法 795\n25.4.3 使用非对称算法 799\n25.4.4 加密数据库\u003Cem\u003E中\u003C\u002Fem\u003E的敏感数据 801\n25.5 加密查询字符串 806\n25.5.1 包装查询字符串 806\n25.5.2 创建一个测试页面 808\n25.6 总结 810\n\n第26章 自定义成员资格提供程序 811\n26.1 自定义提供程序的架构 811\n26.2 创建自定义提供程序的基本步骤 812\n26.2.1 自定义提供程序的总体设计 813\n26.2.2 设计并\u003Cem\u003E实现\u003C\u002Fem\u003E自定义存储 813\n26.2.3 \u003Cem\u003E实现\u003C\u002Fem\u003E提供程序类 820\n26.2.4 使用自定义提供程序类 837\n26.3 总结 840\n\n第五部分 高级用户界面\n\n第27章 自定义服务器控件 842\n27.1 自定义服务器控件入门 842\n27.1.1 创建简单的自定义控件 842\n27.1.2 使用自定义控件 844\n27.1.3 工具箱\u003Cem\u003E中\u003C\u002Fem\u003E的自定义控件 845\n27.1.4 创建支持样式属性的Web控件 847\n27.1.5 呈现过程 850\n27.2 处理不同的浏览器 852\n27.2.1 HtmlTextWriter 852\n27.2.2 浏览器检测 852\n27.2.3 浏览器属性 853\n27.2.4 覆盖浏览器类型侦测 854\n27.2.5 自适应呈现 855\n27.3 控件状态和\u003Cem\u003E事件\u003C\u002Fem\u003E 856\n27.3.1 视图状态 856\n27.3.2 控件状态 858\n27.3.3 回传数据和change\u003Cem\u003E事件\u003C\u002Fem\u003E 860\n27.3.4 \u003Cem\u003E触发\u003C\u002Fem\u003E回传 862\n27.4 扩展现有的Web控件 863\n27.4.1 组合控件 864\n27.4.2 派生控件 866\n27.5 总结 869\n\n第28章 图形、GDI+和图表 870\n28.1 ImageMap控件 870\n28.1.1 创建热点 871\n28.1.2 处理热点单击 872\n28.1.3 自定义热点 873\n28.2 使用GDI+画图 875\n28.2.1 简单绘制 875\n28.2.2 图像格式和质量 877\n28.2.3 Graphics类 878\n28.2.4 使用GraphicsPath 880\n28.2.5 画笔 881\n28.2.6 画刷 883\n28.3 在网页上嵌入动态图形 885\n28.3.1 使用PNG格式 885\n28.3.2 传递信息给动态图像 886\n28.3.3 使用GDI+的自定义控件 888\n28.4 使用Chart控件 892\n28.4.1 创建基本的图表 892\n28.4.2 用数据填充图表 897\n28.5 总结 904\n\n第29章 JavaScript和Ajax技术 905\n29.1 JavaScript本质 905\n29.1.1 HTML DOM 906\n29.1.2 客户端\u003Cem\u003E事件\u003C\u002Fem\u003E 906\n29.1.3 脚本块 908\n29.1.4 操纵HTML元素 910\n29.1.5 调试JavaScript 910\n29.2 基本的JavaScript示例 912\n29.2.1 创建JavaScript页面处理器 912\n29.2.2 使用JavaScript异步下载图片 915\n29.2.3 呈现脚本块 919\n29.3 脚本注入攻击 920\n29.3.1 请求验证 921\n29.3.2 禁用请求验证 922\n29.3.3 扩展请求验证 923\n29.4 带有JavaScript的自定义控件 925\n29.4.1 弹出窗口 925\n29.4.2 滚动按钮 928\n29.5 框架 931\n29.5.1 框架导航 932\n29.5.2 内联框架 933\n29.6 理解Ajax 934\n29.6.1 XMLHttpRequest对象 935\n29.6.2 Ajax示例 936\n29.7 在客户端回调\u003Cem\u003E中\u003C\u002Fem\u003E使用Ajax 939\n29.7.1 创建客户端回调 940\n29.7.2 深入了解客户端回调 945\n29.7.3 自定义控件里的客户端回调 946\n29.8 总结 949\n\n第30章 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX 950\n30.1 介绍\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX 950\n30.1.1 客户端的\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX:脚本库 951\n30.1.2 服务器端的\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX:ScriptManager 952\n30.2 服务器回调 952\n30.2.1 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX\u003Cem\u003E中\u003C\u002Fem\u003E的Web服务 953\n30.2.2 在页面里放置Web方法 959\n30.2.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX应用程序服务 960\n30.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX服务器控件 966\n30.3.1 使用UpdatePanel的局部呈现 966\n30.3.2 使用\u003Cem\u003ETimer\u003C\u002Fem\u003E的\u003Cem\u003E定时\u003C\u002Fem\u003E刷新 973\n30.3.3 使用UpdateProgress的耗时更新 974\n30.3.4 管理浏览器历史 976\n30.4 深入客户端库 979\n30.4.1 理解客户端模型 980\n30.4.2 JavaScript的面向对象编程 981\n30.4.3 网页框架 987\n30.5 控件扩展器 991\n30.5.1 安装\u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX控件工具包 992\n30.5.2 AutoCompleteExtender 993\n30.5.3 \u003Cem\u003EASP\u003C\u002Fem\u003E.NETAJAX控件工具包 996\n30.6 总结 999\n\n第31章 使用Web部件页面的门户网站 1000\n31.1 典型门户页面 1000\n31.2 基本Web部件页面 1002\n31.2.1 创建页面设计 1002\n31.2.2 WebPartManager和WebPartZone 1003\n31.2.3 向页面添加Web部件 1004\n31.2.4 定制页面 1008\n31.3 创建Web部件 1010\n31.3.1 简单的Web部件任务 1010\n31.3.2 开发高级Web部件 1017\n31.3.3 Web部件编辑器 1024\n31.3.4 连接Web部件 1029\n31.3.5 自定义动词和Web部件 1036\n31.3.6 用户控件和高级Web部件 1037\n31.3.7 动态上传Web部件 1040\n31.3.8 对Web部件的授权 1044\n31.3.9 个性化的最后任务 1045\n31.4 总结 1046\n\n第32章 MVC 1047\n32.1 MVC和Web表单的选择 1047\n32.2 创建基本的MVC应用程序 1047\n32.2.1 创建模型 1048\n32.2.2 创建控制器 1049\n32.2.3 创建Index视图 1050\n32.2.4 测试(未完成的)应用程序 1050\n32.2.5 完成控制器和视图 1051\n32.2.6 修改Site.Master文件 1053\n32.3 扩展基础的MVC应用程序 1053\n32.3.1 配置路由 1054\n32.3.2 增加错误处理 1055\n32.3.3 增加验证 1056\n32.3.4 增强数据存储访问 1057\n32.3.5 增加对外键约束的支持 1059\n32.4 自定义视图 1059\n32.4.1 修改视图 1060\n32.4.2 增加视图数据 1062\n32.5 强化模型 1063\n32.6 验证数据 1066\n32.6.1 执行基本的验证 1067\n32.6.2 增加验证标注 1068\n32.7 使用动作结果 1071\n32.7.1 返回JSON数据 1072\n32.7.2 调用其他控制器方法 1072\n32.8 总结 1074\n\n第33章 动态数据 1075\n33.1 创建动态数据应用程序 1075\n33.1.1 创建动态数据网站 1075\n33.1.2 检验动态数据网站 1077\n33.2 深入理解动态数据项目 1080\n33.3 自定义动态数据网站 1080\n33.3.1 使用模板进行自定义 1081\n33.3.2 使用路由进行自定义 1087\n33.3.3 使用元数据进行自定义 1094\n33.3.4 自定义验证 1099\n33.4 总结 1103\n\n第34章 Silverlight 1104\n34.1 理解Silverlight 1105\n34.1.1 Silverlight与Flash对比 1106\n34.1.2 Silverlight系统需求 1107\n34.2 创建Silverlight解决方案 1108\n34.2. 1 Silverlight编译 1109\n34.2.2 入口页面 1110\n34.3 创建Silverlight项目 1114\n34.3.1 设计Silverlight页面 1114\n34.3.2 理解XAML 1117\n34.3.3 设置属性 1118\n34.3.4 XAML 代码隐藏 1119\n34.3.5 处理\u003Cem\u003E事件\u003C\u002Fem\u003E 1120\n34.3.6 了解Silverlight类库 1121\n34.4 布局 1122\n34.4.1 Canvas 1123\n34.4.2 网格 1127\n34.5 动画 1131\n34.5.1 动画基础知识 1132\n34.5.2 定义动画 1132\n34.5.3 StoryBoard类 1133\n34.5.4 交互式动画实例 1135\n34.5.5 变换 1138\n34.6 Silverlight使用Web服务 1141\n34.6.1 创建Web服务 1141\n34.6.2 添加Web引用 1142\n34.6.3 调用Web服务 1143\n34.6.4 配置Web服务URL 1144\n34.6.5 跨域Web服务调用 1144\n34.7 总结 1146","createTime":"2012-10-29 08:07:28","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-4697033-bbs-26590.264^v3^pc_relevant_bbs_down_cate&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-4697033-bbs-26590.264^v3^pc_relevant_bbs_down_cate","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fpanyong001\u002F4697033\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-4697033-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fpanyong001\u002F4697033\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-4697033-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657","title":"Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet v2.2.1 (2009-4-1) 值得一看","desc":"Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet v2.2.1\n\t\nExt\u003Cem\u003EAsp\u003C\u002Fem\u003ENet是一组专业的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件库,拥有原生的AJAX支持和丰富的UI效果,\n目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。\n\n支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+\n\n注:Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。\n\n示例: http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003E.net\u002F\n开源: http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003Enet.codeplex.com\u002F\n博客: http:\u002F\u002Fsanshi.cnblogs.com\u002F\n邮箱: sanshi.ustc@gmail.com\n\n\n发布历史:\n\n+2010-03-28 v2.2.1\n\t+为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首页最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成Extjs最新版本v3.1.1。\n\t\t-增加一个新的Theme - Access。\n\t\t-修正了Firefox下Zoom In\u002FOut时页面消失的BUG。\n\t\t-删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。\n\n\n\n+2010-01-31 v2.2.0\n\t-使得\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件ImageButton具有和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的Button控件类似的行为(Ajax提交)(feedback:261629698)。\n\t+TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。\n\t\t-增加示例tabstrip\u002Ftabstrip_addtab.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window控件更新。\n\t\t-关闭按钮默认直接关闭,不会弹出确认对话框。\n\t\t-GetConfirmFormModifiedHideReference的函数\u003Cem\u003E中\u003C\u002Fem\u003E的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居\u003Cem\u003E中\u003C\u002Fem\u003E,而不是黄金分割位置。\n\t+Button, Window等控件弹出位置属性的变化。\n\t\t-Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target=\"_self\" -\u003E Target=\"Self\", Target=\"_parent\" -\u003E Target=\"Parent\"。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。\n\t\t-Confirm.GetShowReference的最后一个参数target变为枚举类型。\n\t\t-Alert.GetShowReference\u003Cem\u003E中\u003C\u002Fem\u003E的showInParent参数也变为Target枚举类型。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。\n\n\n\n+2010-01-06 v2.1.9\n\t-集成Extjs最新版本v3.1.0。\n\t-修正灰色皮肤的CSS问题。\n\t-修正Grid的列名\u003Cem\u003E中\u003C\u002Fem\u003E不能包含\u003Cem\u003E中\u003C\u002Fem\u003E文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange\u003Cem\u003E事件\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button控件将不再\u003Cem\u003E自动\u003C\u002Fem\u003E拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其\u003Cem\u003E中\u003C\u002Fem\u003E的Close全部改为Hide。\n\t-增加TabStrip\u003Cem\u003E中\u003C\u002Fem\u003ETab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument\u003Cem\u003E中\u003C\u002Fem\u003EIcon属性映射错误(feedback:nopnop9)。\n\t-修正HtmlEditor不能编辑的BUG(feedback:TheBox)。\n\t-修正IE下有时会出现空白页面的情况(feedback:olivia919)。\n\t\n\t\n\n+2009-12-06 v2.1.8\n\t-修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。\n\t-修正了IE下Grid\u003Cem\u003E中\u003C\u002Fem\u003E的一个JS问题(feedback:lqm4108)。\n\t-修正Alert消息\u003Cem\u003E中\u003C\u002Fem\u003E引号未编码导致的JS错误(feedback:sun1299shine)。\n\t+集成extjs3.0.3。\n\t\t-修正弹出对话框的宽度计算错误(会保持最小的状态)。\n\t\t-增加新的皮肤Gray。\n\t-为示例工程添加改变语言和皮肤的下拉列表。\n\t-为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。\t\n\n\n\n+2009-12-01 v2.1.7\n\t-增加示例(iframe\u002Fparent_postback_run3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex),如何通过简单的Javascript代码回发父页面(feedback:eroach)。\n\t-修正一些书写错误(feedback:bmck)。\n\t-从Region控件\u003Cem\u003E中\u003C\u002Fem\u003E删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。\n\t-BorderPanel更名为RegionPanel。\n\t-DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。\n\t-增加\u003Cem\u003E中\u003C\u002Fem\u003E国的省市县三级联动示例(data\u002Fshengshixian.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的Tab在切换过程\u003Cem\u003E中\u003C\u002Fem\u003E会重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。\n\t-修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击\u003Cem\u003E事件\u003C\u002Fem\u003E(feedback:yymaoji)。\n\t\n\t\n\t\n+2009-11-26 v2.1.6\n\t+修正动态创建Grid列的BUG(feedback:gxpan)。\n\t\t-增加示例(data\u002Fgrid_dynamic_columns.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的\u003Cem\u003E实现\u003C\u002Fem\u003E,避免选\u003Cem\u003E中\u003C\u002Fem\u003E某项后的闪烁。\n\t\t\t\n\n\n+2009-11-21 v2.1.5\n\t+Tree优化。\n\t\t-修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。\n\t\t-GetNodeById更名为FindNode,保持和FindControl一致命名。\n\t\t-删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。\n\t\t-删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。\n\t\t-增加示例(data\u002Ftree_select_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex),如何选\u003Cem\u003E中\u003C\u002Fem\u003E当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet\u003Cem\u003E中\u003C\u002Fem\u003E的一个命名约定。\n\t\t\t-同时更名的还有GridColumn的ColumnId-\u003EColumnID,GetColumnId-\u003EGetColumnID。\n\t\t\t-Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。\n\t\t-为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。\n\t-为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#处理函数来响应键盘\u003Cem\u003E事件\u003C\u002Fem\u003E。\n\t-为Tree增加AutoLeafIdentification属性。\n\t\t-增加示例(tree_auto_leaf_identification.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:wdrabbit)。\n\t\n\t\n\n+2009-11-17 v2.1.4\n\t-修正Window的关闭按钮提示信息一直是\u003Cem\u003E中\u003C\u002Fem\u003E文的BUG(feedback:thebox)。\n\t-部分Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件的设计时支持(会在后续版本\u003Cem\u003E中\u003C\u002Fem\u003E逐步完善)。\n\t-v0.2beta2版本\u003Cem\u003E中\u003C\u002Fem\u003E关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。\n\t-修正CheckBox控件的CheckedChanged\u003Cem\u003E事件\u003C\u002Fem\u003E会被\u003Cem\u003E触发\u003C\u002Fem\u003E两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:form\u002Fform_validate.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的控件属性列表(\u002Fajax.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet支持原生的AJAX,也就是说控件的属性改变在AJAX过程\u003Cem\u003E中\u003C\u002Fem\u003E会反映到页面\u003Cem\u003E中\u003C\u002Fem\u003E,但并不是所有的控件属性都支持AJAX改变。\n\t-加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮控件仍然具有AJAX的特性。\n\t-更新\u002Fbasic\u002Flogin.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例,使用验证图片(feedback:kedee)。\n\t-为Grid增加AutoPostBack属性和RowClick\u003Cem\u003E事件\u003C\u002Fem\u003E,示例在\u002Fdata\u002Fgrid_autopostback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(feedback:chenguizhu2006)。\n\t-为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003ETemplateField生成到页面\u003Cem\u003E中\u003C\u002Fem\u003E控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其\u003Cem\u003E中\u003C\u002Fem\u003E包含1700多个小图标。\n\t\t-如果Panel具有IconUrl属性,则IconUrl优先于Icon。\n\t\t-所有Icon的列表在icon.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。\n\t\n\t\n\n+2009-09-15 v2.1.1\n\t-修正不能动态修改AccordionPane属性Items的BUG。\n\t+为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。\n\t\t-如果需要在父页面弹出确认对话框,需要设置ConfirmTarget=\"_parent\"(类似Window控件的Target=\"_parent\")。\n\t+为Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-一个典型应用,在Window控件\u003Cem\u003E中\u003C\u002Fem\u003E打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert.Show(\"参数错误!\", String.Empty, Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以\u003Cem\u003E自动\u003C\u002Fem\u003E回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加\u003Cem\u003E事件\u003C\u002Fem\u003E数据类TreeCheckEventArgs,为Tree增加\u003Cem\u003E事件\u003C\u002Fem\u003ENodeCheck。\n\t\t-示例在:http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003E.net\u002Fdata\u002Ftree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选\u003Cem\u003E中\u003C\u002Fem\u003E任何一项时在父页面弹出对话框的JS代码。\n\t-修正IE7下不能以下划线作为CSS\u003Cem\u003E中\u003C\u002Fem\u003E类名的前缀的BUG(feedback:Steve.Wei)。\n\t-添加\u003Cem\u003E定时\u003C\u002Fem\u003E器控件\u003Cem\u003ETimer\u003C\u002Fem\u003E,用来\u003Cem\u003E定时\u003C\u002Fem\u003E发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree控件的AJAX\u003Cem\u003E实现\u003C\u002Fem\u003E。\n\t+为页面的Form添加autocomplete=\"off\"属性。\n\t\t-参考http:\u002F\u002Fwww.cnblogs.com\u002Fsanshi\u002Farchive\u002F2009\u002F09\u002F04\u002F1560146.html#1635830\n\t+添加对extjs3.0\u003Cem\u003E中\u003C\u002Fem\u003E所有语言的支持。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet扩展的多语言包在js\\languages\\ext\u003Cem\u003Easp\u003C\u002Fem\u003Enet目录下,目前只有en,zh_CN,zh_TW三种\u003Cem\u003E实现\u003C\u002Fem\u003E\n\t\t-你可以向其\u003Cem\u003E中\u003C\u002Fem\u003E添加自己的语言版本,并执行js\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。\n\t+在\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面\u003Cem\u003E中\u003C\u002Fem\u003E必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将会影响所有的\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在\u003Cem\u003EAsp\u003C\u002Fem\u003E.net AJAX\u003Cem\u003E中\u003C\u002Fem\u003E使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将会影响所有的\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet支持多语言(en,zh_CN,zh_TW),可以在Web.config\u003Cem\u003E中\u003C\u002Fem\u003E修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree控件的一个BUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。\n\t -这个BUG导致\u003Cem\u003EAsp\u003C\u002Fem\u003E.net compatibility\u003Cem\u003E中\u003C\u002Fem\u003E的示例无法完成,现在已经修正。\n\t+去除PageManager\u003Cem\u003E中\u003C\u002Fem\u003E方法AddAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls,增加属性Ajax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls。\n\t -这个属性和Button得ValidateForms属性类似,可以查看\u003Cem\u003EAsp\u003C\u002Fem\u003E.net compatibility\u003Cem\u003E中\u003C\u002Fem\u003E的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid\u003Cem\u003E中\u003C\u002Fem\u003E每个单元格的值了。\n -增加示例-如何将Grid控件导出为Excel(data\\grid_excel_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不会被选\u003Cem\u003E中\u003C\u002Fem\u003E(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n -修正Panel图标不能显示的BUG(CSS\u003Cem\u003E中\u003C\u002Fem\u003Eclass名不能有$字符)。\n +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。\n\t\t-简单方便,示例可以参考 default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex 或者 other\\accordion_tree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n \n \n\n+2009-08-14 v2.0.6\n\t-动态生成菜单实例(other\\menu_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和other\\menu_dynamic2_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:shguo)。\n\t-优化AJAX的内部\u003Cem\u003E实现\u003C\u002Fem\u003E,每个页面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId\u003Cem\u003E自动\u003C\u002Fem\u003E生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的提交按钮兼容问题(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮AJAX提交,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们做了优化,现在要使一个\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls,现在可以在Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E设置需要在AJAX\u003Cem\u003E中\u003C\u002Fem\u003E需要更新的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件了。\n\t\t-在Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E设置了哪些需要在AJAX\u003Cem\u003E中\u003C\u002Fem\u003E更新的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件会在回发时保持状态,可以通过RemoveAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls来去除不需要更新的控件。\n\t\t-示例在\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\fckeditor_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\\u003Cem\u003Easp\u003C\u002Fem\u003Enet_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t\t-FCKEditor和上传控件兼容。示例在\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\fileupload_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-修正ToolbarText的文本在AJAX下更新的BUG。\n\t-Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。\n\t-更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。\n\t\n\n\n+2009-08-02 v2.0 beta4\n\t+和\u003Cem\u003EAsp\u003C\u002Fem\u003E.Net的Forms Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和\u003Cem\u003EAsp\u003C\u002Fem\u003E.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.PageContext.Redirect重定向页面,两者效果一样。\n\t\t-支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。\n\t-Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。\n\t-修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。\n\t-修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。\n\t-增加Menu和Accordion的示例。\n\t-修正Window控件的IconUrl有时不显示(Target=\"_parent\")的BUG[feedback:xmq&mgzhenhong]。\n\t\n\n\n+2009-07-22 v2.0 beta3\n\t-兼容FCKEditor。\n\t-在IE8.0,Firefox3.5下测试通过。以后Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet将不会对IE6.0提供支持。\n\t\n\n\n+2009-07-13 v2.0 beta2\n\t-集成extjs最新版本v3.0。\n\t+兼容IE6.0-7.0-8.0。\n\t\t-这应该是Extjs3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click\u003Cem\u003E事件\u003C\u002Fem\u003E无法响应(IE8下无此问题)。\n\t\t-目前先禁用IE6.0-7.0的QuickTips。\n\t-优化底层JavaScript。\n\t\n\t\n\t\n+2009-07-05 v2.0 beta1\n\t-更新extjs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet自身的CSS会紧挨着页面\u003Ctitle\u003E标签引入,这样在\u003Chead\u003E\u003Cem\u003E中\u003C\u002Fem\u003E自定义的样式可以覆盖Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet缺省样式。\n\t+Alert对话框会遮挡所有的Window窗口。\n\t\t-使用一个变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。\t\n\t-为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。\n\t-因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选\u003Cem\u003E中\u003C\u002Fem\u003E第一项。\n\t-重新绑定模拟树的下拉列表后,选\u003Cem\u003E中\u003C\u002Fem\u003E项的前面有图片的HTML标签的BUG。\n\t-更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。\n\t-更新示例工程。\n\t\n\t\n\n+2009-03-25 v1.3.1\n\t-Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed]\n\t-Window\u003Cem\u003E中\u003C\u002Fem\u003E的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed]\n\t-页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例\u003Cem\u003Easp\u003C\u002Fem\u003Enet\u002Ffileupload.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t-HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed]\n\t\n\t\n\n+2009-03-03 v1.3.0\n\t-如果弹出的窗口(Ext-Window)含有\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件FileUpload,则此弹出窗口在关闭时出现JS错误(http:\u002F\u002Fextjs.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果页面\u003Cem\u003E中\u003C\u002Fem\u003E存在\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed]\n\t-页面上放置Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet-Button和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET-Button,则点击Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet-Button时激发的是\u003Cem\u003EASP\u003C\u002Fem\u003E.NET-Button的\u003Cem\u003E事件\u003C\u002Fem\u003E,这个BUG和Extjs2.2.1\u003Cem\u003E中\u003C\u002Fem\u003EExt.Ajax.serializeForm的\u003Cem\u003E实现\u003C\u002Fem\u003E有关。[fixed]\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet工程\u003Cem\u003E中\u003C\u002Fem\u003E使用\u003Cem\u003EASP\u003C\u002Fem\u003E.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET标准控件和平共处了。[fixed]\n\t\t-如果一个\u003Cem\u003EASP\u003C\u002Fem\u003E.NET按钮控件要使用Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的原生AJAX回发时更新\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:\u003Cem\u003Easp\u003C\u002Fem\u003Enet\u002F\u003Cem\u003Easp\u003C\u002Fem\u003Enet.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed]\n\t-\u003Cem\u003E自动\u003C\u002Fem\u003E测试功能会在以后版本\u003Cem\u003E中\u003C\u002Fem\u003E逐步完善。这个版本完成测试框架,采用Extjs\u003Cem\u003E中\u003C\u002Fem\u003EJS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageContext静态类\u003Cem\u003E中\u003C\u002Fem\u003E的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面\u003Cem\u003E中\u003C\u002Fem\u003E表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageContext\u003Cem\u003E中\u003C\u002Fem\u003E的GetConfirmFormModifiedReference,使用CurrentActiveWindow\u003Cem\u003E中\u003C\u002Fem\u003E的GetConfirmFormModifiedCloseReference\u002FGetConfirmFormModifiedCloseRefreshReference\u002FGetConfirmFormModifiedClosePostBackReference三个方法代替。\n\t\t-不会修改弹出页面的URL(Ext-Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame),以前为了\u003Cem\u003E实现\u003C\u002Fem\u003E功能为每个弹出页面添加box_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能\u003Cem\u003E实现\u003C\u002Fem\u003E为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的\u003Cem\u003EASP\u003C\u002Fem\u003EX页面\u003Cem\u003E中\u003C\u002Fem\u003E查找RegisterPageStateChangedScript属性,并删除,否则会运行错误!\n\t\t-A页面有Ext-Window控件弹出B页面,B页面有Ext-Window控件弹出C页面,B页面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C页面)会覆盖整个A页面,这是正确的。\n\t\t---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不会出错了。\n\t\t-Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面\u003Cem\u003E中\u003C\u002Fem\u003E表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。\n\t\t---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。\n\t\t-如果弹出窗口(Window控件)\u003Cem\u003E中\u003C\u002Fem\u003EIFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window控件的IFrameName属性是\u003Cem\u003E自动\u003C\u002Fem\u003E生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。\n\t\t-CurrentActiveWindow改名为ActiveWindow。\n\t\t-[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values)\n\t\t---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E内容不能\u003Cem\u003E自动\u003C\u002Fem\u003E扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed]\n\t-DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed]\n\t-升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed]\n\t-页面加载过程\u003Cem\u003E中\u003C\u002Fem\u003E的时间信息保存在Javascript变量window.box.timeInfo\u003Cem\u003E中\u003C\u002Fem\u003E。[added]\n\t+增加部分\u003Cem\u003E自动\u003C\u002Fem\u003E测试支持(使用WatiN和NUnit),下个版本将会提供完整的\u003Cem\u003E自动\u003C\u002Fem\u003E测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选\u003Cem\u003E中\u003C\u002Fem\u003E任何一项,回发时报错[feedback:huihuang]。[fixed]\n\t-Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed]\n\t+PageContext优化。[fixed]\n\t\t-去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。\n\t\t-去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。\n\t\t-Resirect增加重载函数Redirect(string url, string target),其\u003Cem\u003E中\u003C\u002Fem\u003Etarget可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image控件增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包\u003Cem\u003E中\u003C\u002Fem\u003E增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed]\n\t-ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed]\n\t-Row和Column布局时,修正IE下设置RowHeight=\"100%\"时显示不正确的BUG。[fixed]\n\t-AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed]\n\t+TabStrip的Tab控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed]\n\t\t-有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-\u003Cem\u003Easp\u003C\u002Fem\u003Enet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemText\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选\u003Cem\u003E中\u003C\u002Fem\u003E[feedback:jqpeng]。\n\t\t\t-和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net\u003Cem\u003E中\u003C\u002Fem\u003E的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列表项。\n\t-处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会\u003Cem\u003E自动\u003C\u002Fem\u003E设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS\u003Cem\u003E中\u003C\u002Fem\u003E的height不同,CSS\u003Cem\u003E中\u003C\u002Fem\u003E的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有控件属性增加在VS\u003Cem\u003E中\u003C\u002Fem\u003E的智能提示。[fixed]\n\t\t-需要将Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.XML和Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。\n\t+控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed]\n\t\t-TriggerIconType.Default -\u003E TriggerIconType.None\n\t\t-SystemIconType.Empty -\u003E SystemIconType.None\n\t\t-RegexPattern.USER_DEFINED -\u003E RegexPattern.None\n\t-表单验证属性名称变化(ValueToCompare-\u003ECompareValue,ControlToCompare-\u003ECompareControl)。[fixed]\n\t+注意:一个属性可以拥有多个值的情况。[fixed]\n\t\t-属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。\n\t\t-其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。\n\t+AccordionLink\u003Cem\u003E实现\u003C\u002Fem\u003E为控件。[fixed]\n\t\t-可以方便的在子页面(iframe)\u003Cem\u003E中\u003C\u002Fem\u003E通过js切换父页面\u003Cem\u003E中\u003C\u002Fem\u003E选\u003Cem\u003E中\u003C\u002Fem\u003E的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的动态添加控件,并且可以给控件添加服务器端\u003Cem\u003E事件\u003C\u002Fem\u003E(示例在form\u002Fform_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-10-15 v1.2 beta5\n\t-验证表单字段的ValueToCompare属性,为字符串时会出错的BUG。[fixed]\n\t+优化下拉列表。[fixed]\n\t\t-验证下拉列表时,应该取ListItem的Value属性进行验证,而不是Text属性。\n\t\t-DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。\n\t\t-DropDownList不支持EmptyText属性。\n\t\t-ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(\u003Cem\u003EASP\u003C\u002Fem\u003EX)\u003Cem\u003E中\u003C\u002Fem\u003E设置哪些项不可选择,以及创建模拟下拉树。\n\t\t-DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则\u003Cem\u003E自动\u003C\u002Fem\u003E将EnableSimulateTree设置为true。\n\t\n\t\n\n+2008-09-27 v1.2 beta4\n\t+EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other\u002Faccordion_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。\n\t\t-影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。\n\t-AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed]\n\t+AccordionPanel增加Links属性,可以绑定列表数据到AccordionPanel,呈现的是链接的列表(示例在other\u002Faccordion_links_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-原来放置在AccordionPanel\u003Cem\u003E中\u003C\u002Fem\u003E的容器,比如ContentPanel需要在外层加上\u003CItems\u003E标签。\n\t\t-适当增大AccordionPanel\u003Cem\u003E中\u003C\u002Fem\u003E链接的高度20px-\u003E22px,同时对链接的样式也做了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少\u003Cem\u003EASP\u003C\u002Fem\u003EX\u003Cem\u003E中\u003C\u002Fem\u003EHTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在\u003Cem\u003EASP\u003C\u002Fem\u003EX页切换到“设计时”,方便属性的更改和\u003Cem\u003E事件\u003C\u002Fem\u003E处理函数的添加)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-TabStrip\u002FToolbar\n\t-TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向Form\u003Cem\u003E中\u003C\u002Fem\u003E动态添加控件的BUG,现在form\u002Fform_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例已经能正确运行。[fixed]\n\t+大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的控件包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimpleForm\u002FWindow等。\n\t\t-保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留TabStrip的Tabs(TabCollection)属性。\n\t\t-保留PageLayout\u002FBorderLayout的Regions(RegionCollection)属性。\n\t-预祝今晚神七发射成功。\n\t\n\t\n\t\n+2008-09-22 v1.2 beta2\n\t+Grid选\u003Cem\u003E中\u003C\u002Fem\u003E项(SelectedRowIndexArray)在ajax回发过程\u003Cem\u003E中\u003C\u002Fem\u003E存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选\u003Cem\u003E中\u003C\u002Fem\u003E项\u003Cem\u003E中\u003C\u002Fem\u003E会存在当前不存在的行序号,导致服务器端遍历选\u003Cem\u003E中\u003C\u002Fem\u003E项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例\u003Cem\u003E中\u003C\u002Fem\u003E表单控件都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimpleForm\u002FButton\u002FHyperLink\u002FLabel\u002FImage\u002FLinkButton\u002FTextBox\n\t\t-TriggerBox\u002FTwinTriggerBox\u002FWindow\u002FTextArea\u002FHtmlEditor\u002FDatePicker\u002FNumberBox\n\t\t-CheckBox\u002FRadioButton\u002FRadioButtonList\u002FDropDownList\n\t\t-Grid\n\n\n\n+2008-09-19 v1.2 beta1\n\t-Image\u002FLinkButton\u002FHyperLink增加一些Ajax可更新属性。[fixed]\n\t+隐藏的方式由HideMode属性控制Visibility\u002FOffsets\u002FDisplay。[fixed]\n\t\t-修正Form\u002FSimpleForm\u003Cem\u003E中\u003C\u002Fem\u003E隐藏一个表单字段(Hidden=false)会占据页面空间的BUG。\n\t-ToolbarText\u002FToolbarFill\u002FToolbarSeparator在\u003Cem\u003EASP\u003C\u002Fem\u003EX\u003Cem\u003E中\u003C\u002Fem\u003E设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed]\n\t-Button去除MarginRight属性(可以通过CssStyle=\"margin-right:5px;\"达到相同的效果)[fixed]\n\t\n\t\n\t\n+2008-09-09 v1.1\n\t+Toolbar去除IsPageMenu属性,在网报\u003Cem\u003E中\u003C\u002Fem\u003E可以用自定义样式\u003Cem\u003E实现\u003C\u002Fem\u003E,而不应该写在控件\u003Cem\u003E中\u003C\u002Fem\u003E。[fixed]\n\t\t-网报:CssClass=\"toolbar-pagemenu\" CssStyle=\"border:0px;\",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(..\u002Fimages\u002Fpagemenu_toolbar_background.gif) repeat-x left top;}。\n\t-Region去除默认的Layout=Fit,如果希望Region使用Fit\u002FAnchor\u002FColumn\u002FRow等布局的话,需要手工指定。[fixed]\n\t-ToolbarSeparator\u002FToolbarFill在Ajax更新Hidden属性的BUG。[fixed]\n\t+布局整理。[fixed]\n\t\t-新增Column\u002FAbsolute\u002FRow三种布局,加上以前的Container\u002FFit\u002FAnchor\u002FAccordion\u002FBorder\u002FForm六种布局,总共有9\u003Cem\u003E中\u003C\u002Fem\u003E布局可供使用。\n\t\t-其\u003Cem\u003E中\u003C\u002Fem\u003E一些控件默认使用一种布局:SimpleForm(Form)\u002FForm(Form)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002FTabStrip(Card),所有布局控件默认的布局是Container。\n\t\t-经常用到的布局控件:SimpleForm\u002FForm\u002FAccordion\u002FTabStrip\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。\n\t\t-US的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报\u003Cem\u003E中\u003C\u002Fem\u003E唯一没有用到Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageContext.Redirect支持普通页面转向和Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax下页面转向。[fixed]\n\t+模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。\n\t\t-解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) \u003E= 0){ok}。\n\t-DropDownList在Ajax时应该先更新数据再设置选定项 [feedback:xmzhu]。[fixed]\n\t-Button\u002FMenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed]\n\t-Tree的Ajax支持(尚需优化)。[fixed]\n\t\n\t\n\n+2008-09-02 v1.1 beta5\n\t-DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed]\n\t-模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有数据也需要设置DataTextField\u002FDataValueField\u002FDataSimulateTreeLevelField\u002FDataEnableSelectField等属性的值,否则Ajax回发时会出错)。[fixed]\n\t-UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用\u003Cem\u003EAsp\u003C\u002Fem\u003EnetAjax,这个控件已经完成使命)。[fixed]\n\t-不要使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件HiddenField,而是使用Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的HiddenField,因为\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList\u003Cem\u003E中\u003C\u002Fem\u003E项如果存在汉字,则会换行的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前Tab\u003Cem\u003E中\u003C\u002Fem\u003E如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个问题。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm\u002FForm)的背景色一致。[fixed]\n\t-TwinTriggerBox的第一个Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config\u003Cem\u003E中\u003C\u002Fem\u003E增加配置项FormLabelWidth=\"80\"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm\u002FForm的表单字段标题的宽度。[fixed]\n\t+完善Ajax。[fixed]\n\t\t-RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue\u002FSelectedItem)。\n\t\t-DropDownList增加Ajax可更新属性Enable\u002FSelectedIndex(SelectedValue\u002FSelectedItem)\u002FDataSource。\n\t\t-Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。\n\t\t-ToolbarText增加Ajax可更新属性Text。\n\t\t\n\t\t\n\t\t\n+2008-08-31 v1.1 beta3\n\t-TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed]\n\t-重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会出错。[fixed]\n\t+安全的Ajax设计。[fixed]\n\t\t-这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。\n\t\t-基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。\n\t\t-整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。\n\t-网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed]\n\t\n\t\n\t\n+2008-08-29 v1.1 beta1\n\t+Window控件是否弹出的状态在回发时维持。[fixed]\n\t\t-控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax,Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件内置Ajax支持。[fixed]\n\t\t-这是一个值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和\u003Cem\u003EAsp\u003C\u002Fem\u003E.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager\u003Cem\u003E中\u003C\u002Fem\u003E有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击一个按钮弹出窗口,可以在Button的OnClick\u003Cem\u003E事件\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的做法是尽量用客户端\u003Cem\u003E实现\u003C\u002Fem\u003E,客户端\u003Cem\u003E实现\u003C\u002Fem\u003E复杂的直接用服务器端\u003Cem\u003E实现\u003C\u002Fem\u003E。\n\t\t+目前Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax的限制。\n\t\t\t-只对Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件起作用,对\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件不起作用。\n\t\t\t-对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。\n\t\t\t-对改变控件的Visible属性会有错误。\n\t\t\t-Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading控件。[fixed]\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E的回发\u003Cem\u003E事件\u003C\u002Fem\u003E(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选\u003Cem\u003E中\u003C\u002Fem\u003E的状态在回发后会得到保持。[fixed]\n\t-Grid选\u003Cem\u003E中\u003C\u002Fem\u003E行的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父页面加载一个比较大的css文件(~100k),则每次打开iframe页面,onload\u003Cem\u003E事件\u003C\u002Fem\u003E的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003EIFrame的显示速度。[fixed]\n\t\t-在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报\u003Cem\u003E中\u003C\u002Fem\u003E需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config\u003Cem\u003E中\u003C\u002Fem\u003E设置(推荐方法),也可以为每个页面设置。[fixed]\n\t\t-一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器\u003Cem\u003E中\u003C\u002Fem\u003ECookie设置的值)(示例在default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+TabStrip\u003Cem\u003E中\u003C\u002Fem\u003E非当前Tab会延迟渲染。[fixed]\n\t\t-这会明显加快页面的渲染速度,网报\u003Cem\u003E中\u003C\u002Fem\u003E一个典型的费用审批页面可以减少200ms的渲染时间。\n\t\t-由于非当前Tab不会在页面加载时渲染,所以那些Tab\u003Cem\u003E中\u003C\u002Fem\u003E的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render\u003Cem\u003E事件\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-TabStrip延迟加载引起的BUG(非当前Tab\u003Cem\u003E中\u003C\u002Fem\u003E的ContentPanel会占据页面空间,已修正)。[fixed]\n\t-全新的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Examples(基础知识\u002F表单控件\u002F数据绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame页面\u003Cem\u003E中\u003C\u002Fem\u003E使用父页面的脚本和样式(示例在iframe\u002Fdefault.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout\u003Cem\u003E中\u003C\u002Fem\u003E显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+extjs的BUG,当页面\u003Cem\u003E中\u003C\u002Fem\u003E含有iframe时,Ext.onReady会被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.extjs.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true;\n\t+需要先回发页面再弹出IFrame窗口。[fixed]\n\t\t-在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。\n\t\t-另一种做法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference(\".\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下会有JS错误。[fixed]\n\t-增加BorderLayout控件,示例在iframe\u002Fborderlayout.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。[fixed]\n\t+Radiobuttonlist显示有重影(示例在radio.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-全新的样式。\n\t\t-去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。\n\t\t-GetValueReference取得的值不正确的BUG。\n\t-动态向Form\u003Cem\u003E中\u003C\u002Fem\u003E添加FormRow,并动态的向FormRow\u003Cem\u003E中\u003C\u002Fem\u003E添加表单字段,以及如何取得表单字段的值。(示例在form_dynamic.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t+IFrame弹出窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是一个重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame被添加到页面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\n\t\n\t\n+2008-08-13 v0.4 beta4\n\t-点击关闭窗口的按钮,在IE下会有JS错误。[fixed]\n\t-Window的右上角关闭图标增加提示,优化\u003Cem\u003E事件\u003C\u002Fem\u003E响应。[fixed]\t\n\t-Window的代码重构。[fixed]\t\n\t+修正一个的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面8次后iexplorer占76.492M内存。\n\t\t-IE窗口最小化时,IE会\u003Cem\u003E自动\u003C\u002Fem\u003E进行垃圾回收。\n\t\n\t\n\t\n+2008-08-12 v0.4 beta3\n\t-底层的javascript框架Extjs升级为v2.2,Grid的渲染速度有很大提升。[fixed]\n\t-Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight=\"true\"解决)。[fixed]\n\t+页面正在加载的提示尽早的显示出来。[fixed]\n\t\t-首先在执行js来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示出来。\n\t\t-加载js脚本的script标签放置在页面的最后,放置加载js而阻塞PageLoading的显示。\n\t\n\t\n\t\n+2008-08-08 v0.4 beta2\n\t-TabStrip延时加载出错。[fixed]\n\t-Window的IFrameUrl处理的BUG,比如Pages_Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet目录下的页面应该为.\u002FFE_ApplyEditor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex或~\u002FPages_Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet\u002FFE_ApplyEditor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则会JS错误。[fixed]\n\t-\u003Cem\u003E实现\u003C\u002Fem\u003E网报首页下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed]\n\t-优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex默认会加载form.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面(Window控件的BUG)。[fixed]\n\t-Window\u003Cem\u003E中\u003C\u002Fem\u003E的保存并关闭按钮和\u003Cem\u003EAsp\u003C\u002Fem\u003E.netAjax冲突。[fixed]\n\t-优化关闭Window的js脚本,减少写到页面的js大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件一样不可编辑。[fixed]\n\t-DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的js对象的名称简单化,这样可以减少生成的js内容,加快页面加载速度(一个典型页面的js由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003E,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在页面的Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。\n\t\t-一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。\n\t\t-另一种办法就是在PageManager控件\u003Cem\u003E中\u003C\u002Fem\u003E增加RegisterPageStateChangedScript(向页面注册监视页面\u003Cem\u003E中\u003C\u002Fem\u003E表单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t+PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报\u003Cem\u003E中\u003C\u002Fem\u003E遇到这种情况)。\n\t-每个页面必须添加一个PageManager控件,否则会出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed]\n\t-TextField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fpage2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加一个属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(A)\u002Fpage2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(B)\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(C)),其\u003Cem\u003E中\u003C\u002Fem\u003EA包含B页面,当你在B\u003Cem\u003E中\u003C\u002Fem\u003E打开包含有页面C的窗口时,窗口不是在B\u003Cem\u003E中\u003C\u002Fem\u003E打开,而是在A\u003Cem\u003E中\u003C\u002Fem\u003E打开,这样才能保证窗口覆盖整个页面,当你从C\u003Cem\u003E中\u003C\u002Fem\u003E返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面\u003Cem\u003E中\u003C\u002Fem\u003E创建的。我会通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid\u003Cem\u003E中\u003C\u002Fem\u003E弹出窗口。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Ftriggerbox.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\t\n\t\t\t-在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003E的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下TabStrip在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed]\n\t-对TabStrip\u002FPanel\u002FWindow\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到页面节点,同时第二次打开Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame不会有残影出现。[fixed]\n\t-如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在tabstrip_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-Tree控件,点击一个节点\u003Cem\u003E自动\u003C\u002Fem\u003E回发,则当前点击的那个节点的选\u003Cem\u003E中\u003C\u002Fem\u003E状态不会保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe\u003Cem\u003E中\u003C\u002Fem\u003E关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-内部\u003Cem\u003E实现\u003C\u002Fem\u003E上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将JS文件引用由head移动到body\u003Cem\u003E中\u003C\u002Fem\u003E。[fixed]\n\t-Firefox下,如果页面太长会出滚动条,原来在ViewPort样式\u003Cem\u003E中\u003C\u002Fem\u003E有body{overflow:hidden;}。[fixed]\n\t+IFrame内的页面宽度和高度会\u003Cem\u003E自动\u003C\u002Fem\u003E设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息\u003Cem\u003E中\u003C\u002Fem\u003EMessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image控件 [feedback:jima]。[fixed]\n\t-Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选\u003Cem\u003E中\u003C\u002Fem\u003E哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息\u003Cem\u003E中\u003C\u002Fem\u003E的换行符(转换为\u003Cbr\u002F\u003E),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree控件。[fixed]\n\t\t-如何将数据库\u003Cem\u003E中\u003C\u002Fem\u003E的数据绑定到Tree(示例在tree2_bind_database.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-ajax加载树节点,放在UpdatePanel\u003Cem\u003E中\u003C\u002Fem\u003E才有ajax的效果(示例在tree2_ajax.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树\u003Cem\u003E中\u003C\u002Fem\u003E不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同一个页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltipFormatString两个字段,以显示ToolTip(示例在grid.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选\u003Cem\u003E中\u003C\u002Fem\u003E样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才行(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed]\n\t\t-虽然最后未能解决\u003Cdiv style=\"width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;\"\u003E\u003Cdiv style=\"width: 16px; height: 18px; float: left;\"\u003E##\u003C\u002Fdiv\u003E差旅交通费\u003C\u002Fdiv\u003E在IE和Firefox下显示的不同效果。\n\t\t-但是通过用\u003Cimg src=\"##\" \u002F\u003E来代替\u003Cdiv style=\"background:url(##)\" \u002F\u003E,从而\u003Cem\u003E实现\u003C\u002Fem\u003EFF和IE下样式的统一。\n\t\t-刚看到old9的解决方案:把“差旅交通费”改成“\u003Cspan style=\"margin-right: -1000px;\"\u003E差旅交通费\u003C\u002Fspan\u003E”,在IE下和FF下的都不换行,:-)\n\t-LinkButton增加OnClick\u003Cem\u003E事件\u003C\u002Fem\u003E [feedback:huihuang]。[fixed]\n\t-Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed]\n\t+增加树控件(Tree)(示例在tree2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-可以在回发时维持树的状态(选\u003Cem\u003E中\u003C\u002Fem\u003E行,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式添加树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到页面,也可以引发PostBack\u003Cem\u003E事件\u003C\u002Fem\u003E,可以添加自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E放置Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,则渲染时会出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E渲染Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,如果容器的display='none',则会出现各种问题(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局\u003Cem\u003E实现\u003C\u002Fem\u003E),只要超过Grid容器就会显示滚动条。\n\t+IE6下,在应用\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax后,Form\u003Cem\u003E中\u003C\u002Fem\u003E字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。\n\t\t-最后发现IE6下应用\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax后不仅Form\u003Cem\u003E中\u003C\u002Fem\u003E列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数\u003Cem\u003E中\u003C\u002Fem\u003E,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面\u003Cem\u003E中\u003C\u002Fem\u003E所有表单的宽度(box_fixFormWidthInIE6();):\n\t\t 示例在 Site.Master 页面。\n\t+集成的\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax有一个很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();),\n\t\t 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。\n\t\n\t\n\t\n+2008-07-14 v0.3 beta6\n\t-增加FlashObject控件。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选\u003Cem\u003E中\u003C\u002Fem\u003E样式微调。[fixed]\n\t-预加载Form表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(一个典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid\u003Cem\u003E中\u003C\u002Fem\u003E静态的CheckBoxField图片。[fixed]\n\t-TabStrip增加TabIndexChanged\u003Cem\u003E事件\u003C\u002Fem\u003E,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发\u003Cem\u003E事件\u003C\u002Fem\u003E。这在延迟加载Tab的内容非常有用。(示例在tabstrip.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-页面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和TextBox比较大小需要指定CompareType。\n\t+如果在编辑页面使用\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fajax_editor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-这是由于ajax后执行的javascript\u003Cem\u003E中\u003C\u002Fem\u003E不能有return false语句。\n\t+在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.\u003Cem\u003Easp\u003C\u002Fem\u003Ex) [feedback:xmzhu]。[fixed]\n\t\t-在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误页面,解决方法在当前目录添加一个空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是\"#\"。[fixed]\n\t+弹出的窗口\u003Cem\u003E中\u003C\u002Fem\u003E的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例\u003Cem\u003E中\u003C\u002Fem\u003Ealert\\alert_1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和alert\\alert_2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,总计 6 行代码),现在只需要 3 行代码就OK了。\n\t-点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t+增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-增加SplitButton控件。[fixed]\n\t\n\t\n\t\n+2008-07-09 v0.3 beta4\n\t-DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed]\n\t+Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed]\n\t\t-增加ControlToCompare\u002FValueToCompare\u002FCompareOperator\u002FCompareMessage四个属性,示例在form_compare.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t+TabStrip\u003Cem\u003E中\u003C\u002Fem\u003E放置IFrame会出现渲染错误 (示例在tabstrip_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t\t-特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.\u003Cem\u003Easp\u003C\u002Fem\u003Ex) [feedback:xmzhu]。[fixed]\n\t-FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t+表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed]\n\t\t-覆盖缺省样式的.x-item-disabled,设置不透明。\n\t\n\t\n\t\n+2008-07-08 v0.3 beta3\n\t-Grid没有数据,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed]\n\t+增加HiddenField控件。[fixed]\n\t\t-其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed]\n\t+控制下拉列表某些项不可以选择(示例在dropdownlist2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。\n\t-LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和grid.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-07-07 v0.3 beta2\n\t+增加UpdatePanelConnector控件,支持在布局构建的页面使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net Ajax。[fixed]\n\t\t-使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。\n\t\t-示例在ajax3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fcontent_page4.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t\t-示例content_page3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u003Cem\u003E中\u003C\u002Fem\u003E,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器控件的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工添加AutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其\u003Cem\u003E中\u003C\u002Fem\u003E放置用户控件(示例在page_usercontrol.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-也可以在ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E放置用户控件,注意两者的区别。\n\t+增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed]\n\t+支持\u003Cem\u003EAsp\u003C\u002Fem\u003E.net ajax异步加载。[fixed]\n\t\t-有很大局限性,只能在ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E使用,示例在ajax1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fcontent_ajax2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u003Cem\u003E中\u003C\u002Fem\u003E。\n\t\t-对于使用布局构建的页面(比如content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)还不能使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net ajax,因为页面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前页面已经被修改(示例在content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe\u003Cem\u003E中\u003C\u002Fem\u003E做法一致)。\n\t+iframe\u003Cem\u003E中\u003C\u002Fem\u003E的alert\u002Fconfirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed]\n\t\t-在Firefox下还有问题。[fix pending]\n\t+排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。\n\t\t-可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。\n\t+HyperLinkField\u002FWindowField的链接地址支持服务器端格式(即是~\u002Falert.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-TabStrip的Tab\u003Cem\u003E中\u003C\u002Fem\u003E如果放置ContentPanel,则内容渲染位置不正确。[fixed]\n\t-可以在ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E放置用户控件(示例在page_usercontrol.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t\n\t\n\t\n+2008-06-30 v0.2 beta11\n\t-增加TwinTriggerBox控件(示例在twintriggerbox.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-Grid的数据库分页需要增加属性IsDatabasePaging=true,以便普通分页和数据库分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack\u003Cem\u003E事件\u003C\u002Fem\u003EOnClose可以指定参数,来区分是哪些操作引发的PostBack\u003Cem\u003E事件\u003C\u002Fem\u003E [feedback:zgjiang2](示例在window_postback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的tab)。[fixed]\n\t+页面\u003Cem\u003E中\u003C\u002Fem\u003E任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容页\u003Cem\u003E中\u003C\u002Fem\u003EGrid的Sort\u003Cem\u003E事件\u003C\u002Fem\u003E不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E的LinkButtonField设置ConfirmText会出错 [feedback:huihuang]。[fixed]\n\t-增加静态类Confirm。[fixed]\n\t\n\t\n\t\n+2008-06-27 v0.2 beta10\n\t+Grid完善。[fixed]\n\t\t-CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例)。\n\t\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-切换分页时清空选\u003Cem\u003E中\u003C\u002Fem\u003E的值 [feedback:jqpeng]。\n\t\t-增加PreRowDataBound\u003Cem\u003E事件\u003C\u002Fem\u003E,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\n\t\n\t\n+2008-06-25 v0.2 beta9\n\t+Window窗体\u003Cem\u003E中\u003C\u002Fem\u003E的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-在simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u003Cem\u003E中\u003C\u002Fem\u003E:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其\u003Cem\u003E中\u003C\u002Fem\u003E26是Toolbar的高度,32是窗口的标题栏和下边框的高度。\n\t+关闭Iframe的LoadMask,所以需要Iframe页面添加PageLoading控件,这样效果统一。[fixed]\n\t+Grid完善。\n\t\t-去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在\u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用\u003Cem\u003E中\u003C\u002Fem\u003E会有很多问题(主要是状态保持的问题)。\n\t\t+EnableServerSort改名AllowSorting。(示例在grid_sorting.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-使用非常简单:设置AllowSorting=true,注册OnSort\u003Cem\u003E事件\u003C\u002Fem\u003E,在\u003Cem\u003E事件\u003C\u002Fem\u003E处理函数\u003Cem\u003E中\u003C\u002Fem\u003E重新绑定数据。\n\t\t+增加AllowPaging属性。(示例在grid_paging.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange\u003Cem\u003E事件\u003C\u002Fem\u003E,在\u003Cem\u003E事件\u003C\u002Fem\u003E处理函数\u003Cem\u003E中\u003C\u002Fem\u003EGrid1.PageIndex = e.NewPageIndex;OK。\n\t\t+数据库分页支持。(示例在grid_database_paging.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-使用也非常简单:设置AllowPaging=true,PageSize=3,在绑\u003Cem\u003E定时\u003C\u002Fem\u003E设置RecordCount为总的记录数,在OnPageIndexChange\u003Cem\u003E事件\u003C\u002Fem\u003E处理函数\u003Cem\u003E中\u003C\u002Fem\u003EGrid1.PageIn","createTime":"2010-04-01 09:41:27","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2190657-bbs-26590.264^v3^pc_relevant_bbs_down_cate&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2190657-bbs-26590.264^v3^pc_relevant_bbs_down_cate","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2190657-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2190657-bbs-26590.264^v3^pc_relevant_bbs_down_cate\\\",\\\"dist_request_id\\\":\\\"1714124401024_40718\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"}],"staffDOList":[{"id":null,"communityId":143,"username":"community_24","userNickname":"ASP","roleCode":1,"status":1,"createUsername":"","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","createTime":"2021-05-12 18:05:56","updateTime":"2021-05-12 18:05:56","lastLoginTime":"2021-05-12 18:05:56"},{"id":null,"communityId":143,"username":"sysdzw","userNickname":"无·法","roleCode":2,"status":1,"createUsername":"community_24","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F45dcec50fd694b578374e7167ff7914a_sysdzw.jpg!1","createTime":"2021-06-16 19:25:33","updateTime":"2021-06-16 19:25:33","lastLoginTime":"2021-06-16 19:25:33"}],"communityConfig":{"scoreType":0,"scoreItems":{"0":"给本帖投票","1":"锋芒小试,眼前一亮","2":"潜力巨大,未来可期","3":"持续贡献,值得关注","4":"成绩优异,大力学习","5":"贡献巨大,全力支持"}},"shouldApply":false,"subscribeAble":false,"operatorAble":false,"commentNeedJoinCommunity":false},"default2014LiveRoom":[{"itemType":"","description":"高峰论坛","title":"2022 技术英雄会","url":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fiframe\u002Fcsdnnews\u002FfsNR5NWp?chat=1&title=1&footer=1","images":["https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221016050009.png"],"ext":{"time":"9:00","liveRoomUrl":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fcsdnnews\u002FfsNR5NWp"}}]},"isGooglebot":false,"canonical":"https:\u002F\u002Fwww.csdn.net\u002Ftopics\u002F26590","openUrl":"","isApp":false,"localUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F26590","typeId":"index","hasIndex":false},"CFG":{"ALIPLAYER_VERSION":"v4","ALIPLAYER_H5_VERSION":"mobile_v1","ENV":"prod","ROOT_URL":"https:\u002F\u002Fcms-mall.csdn.net\u002F","VUE_APP_API_URL_SERVER":"http:\u002F\u002Fcms-community-api.internal.csdn.net\u002F","VUE_APP_API_URL":"https:\u002F\u002Fcms-api.csdn.net\u002F","LOGIN_URL":"https:\u002F\u002Fpassport.csdn.net\u002Faccount\u002Flogin","VUE_APP_DOMAIN_SKILL":"https:\u002F\u002Fedu.csdn.net\u002F","VUE_APP_DOMAIN_PATH":"https:\u002F\u002Fedu.csdn.net\u002F","VUE_APP_COMMUNITY_API_URL":"https:\u002F\u002Fcommunity-api.csdn.net\u002F","VUE_APP_CCLOUD_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fcommunity-cloud\u002Fv1\u002F","VUE_APP_SKILL_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fskilltree\u002Fapi\u002F","VUE_APP_SEARCH_PLUGIN_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fsearchplugin\u002F","VUE_APP_COMMUNITY_ASK_API_URL":"https:\u002F\u002Fmp-ask.csdn.net\u002F","VUE_APP_ME_URL":"https:\u002F\u002Fme.csdn.net\u002F","VUE_APP_CCLOUD_RESUME":"https:\u002F\u002Fbizapi.csdn.net\u002Fjob-api\u002F","VUE_APP_CCLOUD_MAIN":"https:\u002F\u002Fwww.csdn.net\u002F","VUE_APP_CCLOUD_UC":"https:\u002F\u002Fwww.csdn.net\u002F","VUE_APP_CCLOUD_BZP_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002F","VUE_APP_CCLOUD_START_API_URL":"https:\u002F\u002Fmp-action.csdn.net\u002F","VUE_APP_PRACTIVE":"https:\u002F\u002Fbizapi.csdn.net\u002Fdaily-practice\u002F","VUE_APP_CCLOUD_HOSTPATH":"https:\u002F\u002Fbbs.csdn.net\u002F"},"queries":{"pageId":[],"domain":["ccloud.csdn.net\u002Fccloud\u002Fdetail1"],"id":["26590"],"deviceType":"pc","isSpider":"","hostname":["bbs.csdn.net"]},"basePath":"bbs.csdn.net\u002Fccloud\u002Ftopics\u002F26590","hrefUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F26590","active":0,"navBarFixed":false,"title":"在asp中怎样实现像timer似的定时自动触发的事件? ","isLive":false,"contentType":{"text":"text","picture":"picture","link":"link","video":"video","vote":"vote","live":"live","blog":"blog","long_text":"long_text","task_text":"task_text"},"liveUrl":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fiframe\u002F","spmExtra":{"id":143,"topicId":26590},"keywords":"","description":"以下内容是CSDN社区关于在asp中怎样实现像timer似的定时自动触发的事件? 相关内容,如果想了解更多关于ASP社区其他内容,请访问CSDN社区。"};</script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/runtime.3e5c09eb.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/common.7672e502.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/tpl/ccloud-detail/index.243a94d0.js"></script></body> <!----> <script> window.csdn.sideToolbar = { options: { qr: { isShow: true, data: [ { imgSrc: 'https://csdnimg.cn/release/cmsfe/public/img/ewm.9010d6e5.png', desc: "关注公众号" }, ] }, help: { isShow: false, }, contentEl: document.getElementsByClassName("cloud-maintainer")[0] }, }; </script> <script src="https://g.csdnimg.cn/side-toolbar/2.9/side-toolbar.js" ></script> <!----> <!----> <!----> <script src="https://csdnimg.cn/release/blog_editor_html/release1.7.5/ckeditor/plugins/codesnippet/lib/highlight/highlight.pack.js"></script> <script src="https://g.csdnimg.cn/lib/editor-page-detail/v2.2.0/js/runDetail.min.js"></script> <!----> <!----> <!----> <!----> <!----> <!----> <script src="https://g.csdnimg.cn/collection-box/2.1.0/collection-box.js"></script> <!----> <!----> <!----> <!----> <script src="https://g.csdnimg.cn/common/csdn-cert/csdn-cert.js"></script> <!----></html>