送分啦!!!!一个关于TabStrip和Label控件的问题

bizshow 2006-11-15 11:37:46
一般用TabStrip做分页的时候,都是用PictureBox做每个页的容器,这样操作起来很方便.
可是我发现一个问题,当某些Windows主题的TabStrip有背景的时候,PictureBox却做不出背景来
本来我想放弃PictureBox做容器,直接将控件放到TabStrip上面,然后在切换分页的时候再隐藏/显示控件
但是我又发现一个问题,TabStrip控件是一个和Label控件一样,不能做容器的控件,
而且Label控件也不能置于TabStrip控件的上面

我仔细研究了Windows的属性页,发现没有这个问题,例如在桌面上点右键>属性,
任何一个页都可以看到背景,所以可以判断没使用PictureBox(事后我用Spy++查了,的确没有)
所有控件都是直接放到TabStrip上的,可是他是如何做到的呢?

目前我能想到的办法只有2个:
1:用一个透明背景的容器
2:用一个可以置于其他控件之上的Label控件,并且BackStyle可以=0(透明)]

可是这两个控件基本上找不到..

所以到这里来问问各位前辈们,这个问题要怎么解决呢?这个问题困扰了我很久了.....
...全文
226 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
liusiheng 2007-03-15
  • 打赏
  • 举报
回复
windows commem control 6.0 不支持透明,除非用很复杂的API,否则picturebox是不能透明的.
学习Java中 2006-11-16
  • 打赏
  • 举报
回复
mark
Alzzl 2006-11-16
  • 打赏
  • 举报
回复
form2.0 是ms在vb6sp6补丁中引入的一种新的窗体,他以及它所带的控件有许多新的特性
要使用form2.0必须先给vb打上sp6的补丁(你在部件里多出来了一个叫microsoft form 2.0 object library的控件,这个控件你不必勾选,即使你勾选了,新的控件的某些功能在旧版本的窗体上也不能很好的运作)
然后通过“工程”菜单中的Microsoft Form 2.0 form 来添加这个新的窗体
bizshow 2006-11-16
  • 打赏
  • 举报
回复
cangwu_lee(小橙子)
你说的用TTSTRIP,虽然可以做容器,可是他不支持XP的皮肤啊,
我做的是一套公共程序,界面元素都比较重要,
为此我甚至放弃了COMMEN CONTROL 6.0而改用的5.0(5.0可以支持皮肤)


Alzzl(果子林)
Form2.0 是什么意思?
bizshow 2006-11-15
  • 打赏
  • 举报
回复
proglovercn(冰雪)
TextBox背景不透明啊,照样不能显示出TabStrip的背景呀
proglovercn 2006-11-15
  • 打赏
  • 举报
回复
用TextBox代替Label试试
Alzzl 2006-11-15
  • 打赏
  • 举报
回复
TabStrip 这些属于form2.0的控件只有在form2.0中才能 正常使用
yangao 2006-11-15
  • 打赏
  • 举报
回复
用SSTab
每个页都是容器
简单的多
jam021 2006-11-15
  • 打赏
  • 举报
回复
学习
iland9876543210 2006-11-15
  • 打赏
  • 举报
回复
好久没顶了,顶一个
cangwu_lee 2006-11-15
  • 打赏
  • 举报
回复
换用 SSTab 控件

ASP的最新版本ASP.NET是Microsoft用于建立动态的数据库驱动网站的技术。内容包括:ASP.NET Web表单的使用,高级ASP.NET页面的开发,ADO.NET的使用,ASP.NET应用程序的使用, ASP.NET应用程序的保护,ASP.NET Web服务的建立,.NET框架的利用,自定义的ASP.NET控件的建立,ASP.NET的应用程序示例等。
本书内容丰富、图文并茂,适合于需要创建网站的专业程序员阅读。本书是关于使用ASP.NET建立网站的完整参考书,书中包含数百个代码示例,读者可以使用这些示例开始建立自己的网站
前言

第一部分 使用ASP.NET Web表单

第1章 建立ASP.NET页面

1.1 ASP.NET和.NET框架
1.1.1 .NET框架类库
1.1.2 理解名称空间
1.1.3 标准的ASP.NET名称空间
1.1.4 与.NET框架兼容的语言
1.2 ASP.NET控件简介
1.2.1 简单的ASP.NET页面
1.2.2 ASP.NET控件的优点
1.2.3 ASP.NET控件概述
1.3 向ASP.NET页面中添加应用逻辑
1.3.1 处理控件事件
1.3.2 处理页面事件
1.4 ASP.NET页面的结构
1.4.1 指令
1.4.2 代码声明块
1.4.3 ASP.NET控件
1.4.4 代码显示块
1.4.5 服务器端注释
1.4.6 服务器端包含指令
1.4.7 文本和HTML标记
1.5 小结

第2章 用Web服务器控件建立表单

2.1 建立智能表单
2.1.1 Label控件
2.1.2 TextBox控件
2.1.3 Button控件
2.1.4 RadioButton和RadioButtonList控件
2.1.5 CheckBox和CheckBoxList控件
2.1.6 DropDownList控件
2.1.7 ListBox控件
2.2 控制页面导航
2.2.1 将表单提交到另一个页面
2.2.2 使用Redirect( )方法
2.2.3 使用HyperLink控件
2.3 在控件上进行格式化
2.3.1 基本Web控件属性
2.3.2 在Web控件上应用样式
2.4 小结

第3章 用检验控件执行表单的检验

3.1 使用客户端检验
3.1.1 配置客户端检验
3.1.2 启用和禁用客户端检验
3.2 必填域:RequiredFieldValidator控件
3.3 检验表达式:RegularExpressionValidator控件
3.3.1 检验电子邮件地址
3.3.2 检验用户名和口令
3.3.3 检验电话号码
3.3.4 检验网址
3.3.5 检验条目长度
3.3.6 检验邮政编码
3.4 比较值:CompareValidator控件
3.4.1 比较一个控件与另一个控件的值
3.4.2 比较一个控件的值与固定值
3.4.3 执行数据类型检查
3.5 检查值的范围:RangeValidator控件
3.6 错误汇总:ValidationSummary控件
3.7 执行自定义的检验:CustomValidator控件
3.8 禁用检验
3.9 小结

第4章 高级控件编程

4.1 使用视图状态
4.1.1 禁用视图状态
4.1.2 将值添加到视图状态
4.2 显示和隐藏内容
4.2.1 使用Visible和Enabled属性
4.2.2 使用Panel控件
4.2.3 模拟多页面表单
4.2.4 通过程序添加控件
4.2.5 将控件添加到页面
4.2.6 PlaceHolder控件
4.2.7 动态产生表单
4.2.8 动态产生列表条目
4.3 使用复杂控件
4.3.1 使用Calendar控件显示交互式的日历
4.3.2 使用AdRotator控件显示广告条
4.3.3 使用HTMLInputFile控件接受文件上传
4.4 小结

第二部分 高级ASP.NET页面开发

第5章 用用户控件创建自定义控件

5.1 用用户控件包含标准内容
5.2 显露用户控件中的属性和方法
5.3 显露用户控件中的Web控件
5.4 显露用户控件中的事件
5.5 通过程序装载用户控件
5.6 小结

第6章 将代码与表示分离

6.1 创建业务组件
6.2 创建多层Web应用程序
6.3 使用code-behind
6.3.1 code-behind是如何工作的
6.3.2 编译code-behind文件
6.3.3 从一个code-behind文件派生多个页面
6.3.4 编译完整的ASP.NET页面
6.4 小结

第7章 用可移动控件为可移动设备服务

7.1 使用可移动设备软件模拟器
7.2 无线应用协议简介
7.3 建立WML页面
7.3.1 配置IIS
7.3.2 WML和XML
7.3.3 创建卡片集
7.3.4 用WML链接文件
7.4 使用ASP.NET可移动控件
7.4.1 创建可移动表单
7.4.2 动态激活可移动表单
7.4.3 显示文本
7.4.4 显示列表
7.4.5 创建文本框
7.4.6 检验用户输入
7.4.7 显示图像
7.4.8 进行电话呼叫
7.4.9 用可移动控件显示广告
7.4.10 使用可移动控件显示日历
7.5 创建跨设备兼容的可移动页面
7.5.1 探测设备功能
7.5.2 使用DeviceSpecific选择设备
7.5.3 使用表单模板集
7.6 小结

第8章 使用第三方控件

8.1 使用Microsoft Internet Explorer WebControls
8.1.1 使用TreeView控件
8.1.2 使用Toolbar控件
8.1.3 使用TabStrip控件
8.2 使用Superexpert控件
8.2.1 使用Content Rotator控件
8.2.2 使用SuperDataGrid控件
8.2.3 使用DataForm控件
8.3 小结

第三部分 使用ADO.NET

第9章 ADO.NET简介

9.1 ADO.NET概述
9.2 执行常见的数据库任务
9.2.1 打开数据库链接
9.2.2 从数据库表获取记录
9.2.3 在查询中使用参数
9.2.4 向数据库添加记录
9.2.5 更新数据库记录
9.2.6 删除数据库记录
9.3 改进数据库性能
9.3.1 使用SQL存储过程
9.3.2 获取返回值和输出参数
9.3.3 执行复杂的存储过程
9.3.4 用链接缓冲改进性能
9.4 高级的数据库主题
9.4.1 在事务中执行数据库命令
9.4.2 指定命令行为
9.4.3 获取表模式信息
9.5 小结

第10章 将数据绑定到Web控件

10.1 数据绑定概述
10.2 将服务器控件绑定到数据源
10.2.1 绑定到Repeater控件
10.2.2 使用模板
10.2.3 视图状态和Repeater控件
10.2.4 绑定到DropDownList控件
10.2.5 绑定到RadioButtonList控件
10.2.6 绑定到CheckBoxList控件
10.2.7 绑定到ListBox控件
10.2.8 绑定到其他控件
10.3 创建主/明细表单
10.3.1 创建单页面的主/明细表单
10.3.2 创建多页面的主/明细表单
10.4 小结

第11章 使用DataList和DataGrid控件

11.1 DataList和DataGrid控件概述
11.1.1 理解事件冒泡机制
11.1.2 使用模板
11.1.3 使用DataKeys集合
11.2 使用DataList控件
11.2.1 在DataList中显示数据
11.2.2 对DataList使用模板
11.2.3 对DataList使用样式
11.2.4 在DataList中创建多个列
11.2.5 捕获DataList控件中引发的事件
11.2.6 选择DataList中的条目
11.2.7 通过DataList控件使用DataKeys集合
11.2.8 用DataList控件创建主/明细表单
11.2.9 编辑DataList控件中的条目
11.3 使用DataGrid控件
11.3.1 在DataGrid控件中创建列
11.3.2 对DataGrid使用样式
11.3.3 对DataGrid控件中的列进行排序
11.3.4 对DataGrid中的记录进行分页
11.3.5 选择DataGrid控件中的行
11.3.6 编辑DataGrid控件中的条目
11.3.7 使用模板编辑DataGrid控件中的条目
11.4 小结

第12章 操作DataSet

12.1 理解DataSet
12.1.1 DataSet的元素
12.1.2 向DataSet添加DataTable
12.1.3 将控件绑定到DataSet
12.2 理解DataTable
12.2.1 通过程序创建DataTable
12.2.2 设置DataTable属性
12.2.3 在DataTable中设置列属性
12.2.4 在DataTable中计算列值
12.2.5 在DataTable之间定义关系
12.2.6 获取DataTable模式信息
12.2.7 在DataTable中更新记录
12.3 理解DataView
12.3.1 在DataView中对行进行过滤
12.3.2 在DataView中对行进行排序
12.3.3 在DataView中搜索行
12.4 通过ASP.NET页面使用DataSet
12.4.1 缓存DataSet
12.4.2 显示缓存的数据
12.4.3 过滤缓存的数据
12.4.4 在缓存的DataSet中搜索行
12.5 小结

第13章 操作XML

13.1 XML类概述
13.2 通过DataSet使用XML
13.2.1 将XML文档读入DataSet
13.2.2 通过ReadXml使用模式
13.2.3 从DataSet写XML文档
13.2.4 通过DataSet使用XMLData Documents
13.3 使用样式单转换XML
13.4 使用ASP.NET Xml控件
13.5 使用XslTransform类
13.6 使用强类型的DataSet
13.7 小结

第14章 使用ADO.NET创建搜索页面

14.1 使用SQL Server全文搜索
14.1.1 配置Full-Text Search Service
14.1.2 对数据库数据执行任意文本查询
14.1.3 对数据库数据执行布尔查询
14.1.4 上传二进制文档并且进行索引
14.2 使用Microsoft Indexing Service
14.2.1 配置Microsoft Indexing Service
14.2.2 将SQL Server配置为使用Microsoft Indexing Service
14.2.3 获取文档属性
14.2.4 对文件系统数据执行任意文本查询
14.2.5 对文件系统数据执行布尔查询
14.2.6 对文档属性执行查询
14.3 小结

第四部分 使用ASP.NET应用程序

第15章 创建ASP.NET应用程序

15.1 ASP.NET应用程序概述
15.2 使用应用程序状态
15.2.1 理解应用程序状态和同步
15.2.2 使用Global.asax文件
15.2.3 理解Context和使用Global.asax文件
15.2.4 处理应用程序Start和Init事件
15.2.5 处理Application_BeginRequest事件
15.3 使用Web.Config文件
15.3.1 研究配置部分
15.3.2 修改配置设置
15.3.3 设置配置位置
15.3.4 锁定配置设置
15.3.5 添加自定义的配置信息
15.4 使用HTTP处理器和模块
15.4.1 使用HTTP处理器
15.4.2 使用HTTP模块
15.4.3 创建WhosOn应用程序
15.5 小结

第16章 跟踪用户会话

16.1 使用浏览器cookie
16.1.1 cookie如何工作
16.1.2 创建和读取会话cookie
16.1.3 创建和读取持久性cookie
16.1.4 设置cookie属性
16.1.5 cookie的限制
16.2 使用会话状态
16.2.1 向会话状态中添加条目
16.2.2 从会话状态中删除条目
16.2.3 启动用户会话
16.2.4 结束用户会话
16.2.5 处理会话事件
16.2.6 在进程内存储会话状态
16.2.7 在Windows服务中存储会话状态
16.2.8 在数据库表中存储会话状态
16.2.9 禁止会话状态
16.3 使用无cookie会话
16.3.1 启用无cookie会话
16.3.2 无cookie会话的限制
16.4 小结

第17章 缓存ASP.NET应用程序

17.1 使用页面输出缓存
17.1.1 按参数改变缓存内容
17.1.2 按头改变缓存内容
17.1.3 按自定义的字符串改变缓存内容
17.1.4 设置缓存位置
17.1.5 使用HttpCachePolicy类
17.2 使用页面分段缓存
17.2.1 按参数改变页面分段缓存
17.2.2 页面分段缓存的限制
17.3 使用页面数据缓存
17.3.1 在缓存中添加条目
17.3.2 添加缓存文件依赖性
17.3.3 添加缓存触发器依赖性
17.3.4 添加缓存键依赖性
17.3.5 建立绝对的过期策略
17.3.6 建立变化的过期策略
17.3.7 设置缓存条目优先级
17.3.8 创建缓存回调方法
17.4 小结

第18章 应用程序跟踪和错误处理

18.1 响应错误
18.1.1 查看错误信息
18.1.2 页面级错误处理
18.1.3 应用程序级错误处理
18.2 跟踪和监视应用程序
18.2.1 跟踪页面的执行
18.2.2 监视ASP.NET进程
18.2.3 获取进程信息
18.3 记录事件
18.4 使用调试器
18.4.1 连接调试器
18.4.2 建立断点
18.4.3 建立观察
18.4.4 逐步执行ASP.NET页面
18.5 小结

第五部分 保护ASP.NET应用程序

第19章 使用基于表单的身份验证

19.1 使用表单身份验证
19.1.1 启用表单身份验证
19.1.2 配置表单身份验证
19.1.3 配置表单授权
19.1.4 获取用户信息
19.1.5 创建注销页面
19.1.6 用Web.Config文件进行用户身份验证
19.1.7 用XML文件进行用户身份验证
19.1.8 用数据库表进行用户身份验证
19.1.9 实现基于角色的身份验证
19.1.10 创建自定义的身份验证票据
19.1.11 表单身份验证和Web阵
19.2 使用Passport身份验证
19.2.1 启用Passport身份验证
19.2.2 允许用户登录和注销
19.2.3 获取用户信息
19.3 小结

第20章 基于Windows的身份验证

20.1 使用基于Windows的身份验证
20.1.1 配置Internet Information Server安全
20.1.2 配置Microsoft Windows安全
20.1.3 配置Windows身份验证
20.1.4 配置Windows授权
20.1.5 配置自定义角色
20.1.6 获取用户信息
20.2 模拟用户账号
20.3 设置安全策略
20.4 小结

第21章 加密网上发送的数据

21.1 使用Secure Sockets Layer
21.1.1 加密
21.1.2 身份验证
21.1.3 数据完整性
21.1.4 SSL有多安全
21.2 将服务器配置为使用SSL
21.2.1 产生证书请求文件
21.2.2 申请服务器证书
21.2.3 安装服务器证书
21.3 在ASP.NET页面中使用SSL
21.4 使用.NET加密类
21.4.1 使用散列算法
21.4.2 使用对称加密算法
21.4.3 使用不对称加密
21.5 小结

第六部分 建立ASP.NET Web服务

第22章 创建XML Web服务

22.1 XML Web服务概述
22.1.1 XML Web服务促进通信
22.1.2 XML Web服务允许聚集
22.2 创建简单的XML Web服务
22.2.1 设置WebMethod属性
22.2.2 设置WebService属性
22.2.3 预编译XML Web服务
22.3 从浏览器测试XML Web服务
22.3.1 用HTTP-Get调用XML Web服务
22.3.2 用HTTP-Post调用XML Web服务
22.3.3 用SOAP调用XML Web服务
22.4 通过代理类访问XML Web服务
22.4.1 产生XML Web服务代理类
22.4.2 使用XML Web服务代理类
22.4.3 使用Web服务描述语言工具
22.4.4 设置代理类属性
22.5 在XML Web服务中传送复杂数据
22.5.1 XML Web服务和数组
22.5.2 XML Web服务和类
22.5.3 Web服务和DataSet
22.5.4 Web服务和二进制文件
22.6 XML Web服务和网站的交互
22.6.1 XML Web服务和应用程序状态
22.6.2 XML Web服务和会话状态
22.7 小结

第23章 高级的XML Web服务

23.1 使用WebService行为
23.1.1 WebService行为的限制
23.1.2 用WebService行为创建简单的页面
23.1.3 使用WebService行为回调函数
23.1.4 缓存WebService行为中的错误
23.1.5 使用WebService行为执行部分更新
23.1.6 使用WebService行为获取数据库数据
23.2 保护XML Web服务
23.2.1 安全的XML Web服务
23.2.2 创建数据库表
23.2.3 创建Login( )方法
23.2.4 获取自定义的SOAP头
23.2.5 验证会话键
23.2.6 缓存会话键
23.2.7 建立安全的XML Web服务
23.2.8 访问安全的Web服务
23.3 使用HTML模式匹配
23.3.1 创建WSDL文档
23.3.2 指定正则表达式模式
23.3.3 创建简单的HTML模式匹配服务
23.3.4 在HTML模式匹配中使用输入参数
23.3.5 建立一个Six Degrees Web服务
23.4 小结

第七部分 利用.NET框架

第24章 操作集合和字符串

24.1 使用集合
24.1.1 使用ArrayList集合
24.1.2 使用HashTable集合
24.1.3 使用SortedList集合
24.2 使用字符串
24.2.1 对字符串进行格式化
24.2.2 使用String方法和属性
24.2.3 使用StringBuilder类
24.3 使用正则表达式
24.3.1 使用正则表达式类
24.3.2 研究正则表达式的元素
24.3.3 匹配单一字符
24.3.4 匹配特殊字符
24.3.5 匹配字符的替代序列
24.3.6 使用数量词进行匹配
24.3.7 正则表达式的超范围问题
24.3.8 捕获和反向引用
24.3.9 使用替换模式
24.3.10 设置正则表达式选项
24.4 小结

第25章 操作文件系统

25.1 使用文件和目录
25.1.1 创建和读取文本文件
25.1.2 创建和读取二进制文件
25.1.3 显示目录的内容
25.1.4 获取路径信息
25.2 使用串行化
25.2.1 使用二进制串行化
25.2.2 使用XML串行化
25.3 小结

第26章 发送电子邮件和访问网络

26.1 从ASP.NET页面发送电子邮件
26.1.1 Microsoft SMTP Service
26.1.2 发送简单的电子邮件
26.1.3 使用MailMessage类
26.1.4 向电子邮件消息添加附件
26.1.5 发送HTML电子邮件
26.2 使用Message Queuing
26.2.1 配置Microsoft Message Queuing
26.2.2 使用消息队列
26.2.3 向队列发送消息
26.2.4 从队列获取消息
26.2.5 显示消息体
26.2.6 发送和接收复杂的消息
26.3 使用HTTP协议访问其他网站
26.3.1 使用WebClient类
26.3.2 使用HttpWebRequest类
26.3.3 解析域名
26.4 小结

第27章 用GDI+动态创建图形

27.1 建立简单的图像
27.2 使用GDI+绘制对象
27.2.1 创建位图
27.2.2 使用Graphics对象
27.2.3 设置图形质量
27.2.4 使用颜色
27.2.5 使用画刷
27.2.6 使用画笔
27.2.7 绘制矩形
27.2.8 绘制直线
27.2.9 绘制椭圆
27.2.10 绘制曲线
27.3 绘制文本字符串
27.4 建立GDI+应用程序
27.4.1 创建ASP.NET绘图应用程序
27.4.2 创建简单的图表应用程序
27.5 小结

第八部分 建立自定义的ASP.NET控件

第28章 开发自定义的控件

28.1 创建简单的控件
28.2 使用HtmlTextWriter
28.3 向控件添加属性和方法
28.3.1 使用属性访问函数
28.3.2 使用控件方法
28.4 解析内部内容
28.5 向控件添加子控件
28.6 自定义控件和事件
28.7 参与postback
28.8 创建组合控件
28.9 派生现有的控件
28.10 访问当前上下文
28.11 调试控件
28.12 小结

第29章 高级控件开发

29.1 向控件添加模板
29.1.1 创建一个模板的多个实例
29.1.2 向一个控件添加多个模板
29.2 创建DataBound控件
29.2.1 实现不同的数据源
29.2.2 实现简单的DataBound控件
29.2.3 使用DataBound控件和模板
29.2.4 使用DataBound控件和状态
29.2.5 将自定义控件绑定到DataSet
29.3 使用自定义控件和Web服务
29.3.1 创建特色产品Web服务
29.3.2 创建特色产品自定义控件
29.3.3 显示特色产品控件
29.4 小结

第九部分 ASP.NET应用程序示例

第30章 创建职业介绍网站

30.1 安装职业介绍网站
30.2 创建主页
30.3 对用户进行身份验证
30.4 创建虚拟URL
30.5 列出和更新职位
30.6 创建职业介绍XML Web服务
30.7 小结

第31章 创建网上商店

31.1 ASP.NET Unleashed示例商店概述
31.2 安装ASP.NET Unleashed示例商店
31.3 建立导航系统
31.4 缓存产品数据
31.5 建立购物车
31.6 动态装载产品模板
31.6.1 使用LoadControl方法
31.6.2 code-behind产品模板
31.7 小结

第十部分 附录

附录A 从ASP迁移到ASP.NET
附录B HTML控件参考
附录C Web控件参考
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。 -增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocument中Icon属性映射错误(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)。 -Grid中TemplateField生成到页面中控件具有唯一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(CSS中class名不能有$字符)。 +去除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>中自定义的样式可以覆盖ExtAspNet缺省样式。 +Alert对话框会遮挡所有的Window窗口。 -使用<em>一个</em>变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。 -重新绑定模拟树的下拉列表后,选中项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed] -Window中的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed] -页面包含FileUpload<em>控件</em>,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet/fileupload.aspx)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(Ext-Window)含有ASP.NET<em>控件</em>FileUpload,则此弹出窗口在关闭时出现JS错误(http://extjs.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果页面中存在ASP.NET<em>控件</em>(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的<em>问题</em>)。[fixed] -页面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed] -ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added] +如果以前你听过不要在ExtAspNet工程中使用ASP.NET标准<em>控件</em>的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet<em>控件</em>和ASP.NET标准<em>控件</em>和平共处了。[fixed] -如果<em>一个</em>ASP.NET按钮<em>控件</em>要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET<em>控件</em>的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet/aspnet.aspx)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed] -自动测试功能会在以后版本中逐步完善。这个版本完成测试框架,采用Extjs中JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建<em>一个</em>Window<em>控件</em>的代码由原来的2000字符减少为500个字符。 -PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。 ---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference/GetConfirmFormModifiedCloseRefreshReference/GetConfirmFormModifiedClosePostBackReference三个方法代替。 -不会修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面添加box_parent_client_id查询字符串 -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的ASPX页面中查找RegisterPageStateChangedScript属性,并删除,否则会运行错误! -A页面有Ext-Window<em>控件</em>弹出B页面,B页面有Ext-Window<em>控件</em>弹出C页面,B页面的Ext-Window<em>控件</em>设置Target='_parent',则弹出的Ext-Window(C页面)会覆盖整个A页面,这是正确的。 ---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不会出错了。 -Window<em>控件</em>的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window<em>控件</em>增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。 ---Window<em>控件</em>的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window<em>控件</em>的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。 -如果弹出窗口(Window<em>控件</em>)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。 ---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window<em>控件</em>的IFrameName属性是自动生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第<em>一个</em>参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel中内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed] -DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed] -升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏<em>问题</em>的修正)。[fixed] -页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added] +增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageContext优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image<em>控件</em>增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包中增加<em>一个</em>Web.config.txt,这是<em>一个</em>空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +<em>TabS</em><em>trip</em>的Tab<em>控件</em>的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed] -有这样<em>一个</em>效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用<em>控件</em>的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的<em>问题</em>。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-aspnet-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemText/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new ExtAspNet.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。 -和Asp.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列表项。 -处于布局内的容器<em>控件</em>(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed] -注意,<em>控件</em>的高度指的是整个<em>控件</em>的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有<em>控件</em>属性增加在VS中的智能提示。[fixed] -需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。 +<em>控件</em>的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:<em>一个</em>属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为<em>控件</em>。[fixed] -可以方便的在子页面(iframe)中通过js切换父页面中选中的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.aspx,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的动态添加<em>控件</em>,并且可以给<em>控件</em>添加服务器端事件(示例在form/form_dynamic_run.aspx)。[fixed] +2008-10-15 v1.2 beta5 -验证表单字段的ValueToCompare属性,为字符串时会出错的BUG。[fixed] +优化下拉列表。[fixed] -验证下拉列表时,应该取ListItem的Value属性进行验证,而不是Text属性。 -DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。 -DropDownList不支持EmptyText属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)中设置哪些项不可选择,以及创建模拟下拉树。 -DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则自动将EnableSimulateTree设置为true。 +2008-09-27 v1.2 beta4 +EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other/accordion_run.aspx)。[fixed] -Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。 -影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。 -AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed] +AccordionPanel增加Links属性,可以绑定列表数据到AccordionPanel,呈现的是链接的列表(示例在other/accordion_links_run.aspx)。[fixed] -原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上<Items>标签。 -适当增大AccordionPanel中链接的高度20px->22px,同时对链接的样式也做了微调。 -通过BodyPadding控制链接列表的边距。 -这样能大大减少ASPX中HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在ASPX页切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -<em>TabS</em><em>trip</em>/Toolbar -<em>TabS</em><em>trip</em>去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form中动态添加<em>控件</em>的BUG,现在form/form_dynamic_run.aspx示例已经能正确运行。[fixed] +大部分容器的子<em>控件</em>集合更正为Items(以前有些是Rows)。[fixed] -影响的<em>控件</em>包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留<em>TabS</em><em>trip</em>的<em>Tabs</em>(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选中项中会存在当前不存在的行序号,导致服务器端遍历选中项时数组越界。所有使用box<em>控件</em>的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例中表单<em>控件</em>都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/<em>Label</em>/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在ASPX中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在<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>默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/<em>TabS</em><em>trip</em>(Card),所有布局<em>控件</em>默认的布局是Container。 -经常用到的布局<em>控件</em>:SimpleForm/Form/Accordion/<em>TabS</em><em>trip</em>/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果<em>一个</em>菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的ExtAspNet<em>控件</em>增加Hidden属性(少数几个<em>控件</em>没有此属性:Menu),这样在Ajax时可以显示隐藏<em>控件</em>。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的<em>控件</em>渲染到客户端但是隐藏。 -US的ExtAspNet改造强烈依赖于此属性,这个版本发布后可以继续。 -网报中唯一没有用到ExtAspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageContext.Redirect支持普通页面转向和ExtAspNetAjax下页面转向。[fixed] +模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多<em>控件</em>(Grid,DropDownList,<em>TabS</em><em>trip</em>)。 -解决方法: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>控件</em>(以后不会用AspnetAjax,这个<em>控件</em>已经完成使命)。[fixed] -不要使用Asp.net的<em>控件</em>HiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的<em>控件</em>在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList中项如果存在汉字,则会换行的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab中如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个<em>问题</em>。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父<em>控件</em>(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第<em>一个</em>Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config中增加配置项Form<em>Label</em>Width="80"(默认为80),同时PageManager增加Form<em>Label</em>Width属性用来控制页面上所有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 -<em>TabS</em><em>trip</em>增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。 -基本思想:安全的Ajax交互,明确Ajax回发时支持<em>控件</em>哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供<em>控件</em>级别的EnableAjax属性。 -整理支持Ajax的<em>控件</em>属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。 -网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window<em>控件</em>是否弹出的状态在回发时维持。[fixed] -<em>控件</em>设计的<em>一个</em>原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃Asp.NetAjax,ExtAspNet<em>控件</em>内置Ajax支持。[fixed] -这是<em>一个</em>值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击<em>一个</em>按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前ExtAspNetAjax的限制。 -只对ExtAspNet<em>控件</em>起作用,对Asp.net<em>控件</em>不起作用。 -对容器<em>控件</em>(有子<em>控件</em>的<em>控件</em>)不起作用,只对最底层的<em>控件</em>起作用。 -对改变<em>控件</em>的Visible属性会有错误。 -Window<em>控件</em>的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading<em>控件</em>。[fixed] -Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选中的状态在回发后会得到保持。[fixed] -Grid选中行的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知<em>问题</em>:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。 -主要是父页面加载<em>一个</em>比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹出窗口中IFrame的显示速度。[fixed] -在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed] -<em>一个</em>典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.aspx)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +<em>TabS</em><em>trip</em>中非当前Tab会延迟渲染。[fixed] -这会明显加快页面的渲染速度,网报中<em>一个</em>典型的费用审批页面可以减少200ms的渲染时间。 -由于非当前Tab不会在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到<em>控件</em>的render事件中。 -不能比较两个DataPicker大小的BUG。[fixed] -<em>TabS</em><em>trip</em>延迟加载引起的BUG(非当前Tab中的ContentPanel会占据页面空间,已修正)。[fixed] -全新的ExtAspNet.Examples(基础知识/表单<em>控件</em>/数据绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe/default.aspx和iframe/page3.aspx)。[fixed] -测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed] +extjs的BUG,当页面中含有iframe时,Ext.onReady会被调用两次(IE6/IE7)(http://www.extjs.net/forum/showthread.php?t=43246)(示例在test.aspx)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发页面再弹出IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种做法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference("./simpleform.aspx"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下会有JS错误。[fixed] -增加BorderLayout<em>控件</em>,示例在iframe/borderlayout.aspx。[fixed] +Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -动态向Form中添加FormRow,并动态的向FormRow中添加表单字段,以及如何取得表单字段的值。(示例在form_dynamic.aspx)[fixed] +IFrame弹出窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是<em>一个</em>重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window中的IFrame被添加到页面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此<em>问题</em>解决。(示例在button_iframe.aspx) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下会有JS错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正<em>一个</em>的内存泄漏。[fixed] -IE7下测试,打开iframe/default.aspx页面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.aspx页面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.aspx页面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE会自动进行垃圾回收。 +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 -<em>TabS</em><em>trip</em>延时加载出错。[fixed] -Window的IFrameUrl处理的BUG,比如Pages_ExtAspNet目录下的页面应该为./FE_ApplyEditor.aspx或~/Pages_ExtAspNet/FE_ApplyEditor.aspx。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则会JS错误。[fixed] -实现网报首页下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed] -优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.aspx默认会加载form.aspx页面(Window<em>控件</em>的BUG)。[fixed] -Window中的保存并关闭按钮和Asp.netAjax冲突。[fixed] -优化关闭Window的js脚本,减少写到页面的js大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.aspx)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的Asp.net<em>控件</em>一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的js对象的名称简单化,这样可以减少生成的js内容,加快页面加载速度(<em>一个</em>典型页面的js由原来的33.0k降低为21.4k)。[fixed] +弹出窗口中,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed] -因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。 -一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。 -另一种办法就是在PageManager<em>控件</em>中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx/simpleform.aspx)。 +PageManager<em>控件</em>增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed] -这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报中遇到这种情况)。 -每个页面必须添加<em>一个</em>PageManager<em>控件</em>,否则会出错,同时去除DesignTimeStyle<em>控件</em>(作为PageManager的属性出现)。[fixed] -TextField等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed] -最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.aspx/page2.aspx/simpleform.aspx) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window<em>控件</em>增加<em>一个</em>属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,<em>控件</em>本身封装了大量的代码,简单来看现在有三个页面(default.aspx(A)/page2.aspx(B)/simpleform.aspx(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我会通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid中弹出窗口。(default.aspx/page3.aspx/simpleform.aspx) +示例3,TriggerBox弹出窗口。(default.aspx/triggerbox.aspx/simpleform.aspx) -在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。 -示例4,弹出窗口中的弹出窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下<em>TabS</em><em>trip</em>在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对<em>TabS</em><em>trip</em>/Panel/Window中的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不会有残影出现。[fixed] -如果<em>TabS</em><em>trip</em>的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在<em>tabs</em><em>trip</em>_iframe.aspx)。[fixed] -Tree<em>控件</em>,点击<em>一个</em>节点自动回发,则当前点击的那个节点的选中状态不会保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx/simpleform.aspx)。[fixed] -内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.aspx,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。 -参照Yslow的评分规则,将JS文件引用由head移动到body中。[fixed] -Firefox下,如果页面太长会出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed] +IFrame内的页面宽度和高度会自动设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx/simpleform.aspx/simpleform2.aspx)[fixed] -增加PageManager<em>控件</em>(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image<em>控件</em> [feedback:jima]。[fixed] -Tree<em>控件</em>,如果<em>一个</em>节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed] -去掉DropDownList<em>控件</em>的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息中的换行符(转换为<br/>),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree<em>控件</em>。[fixed] -如何将数据库中的数据绑定到Tree(示例在tree2_bind_database.aspx)。 -ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.aspx)。 -更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同<em>一个</em>页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltipFormatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[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(##)" />,从而实现FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“<span style="margin-right: -1000px;">差旅交通费</span>”,在IE下和FF下的都不换行,:-) -LinkButton增加OnClick事件 [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树<em>控件</em>(Tree)(示例在tree2.aspx)。[fixed] -可以在回发时维持树的状态(选中行,折叠/展开,CheckBox)。 -可以通过Inline的方式添加树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到页面,也可以引发PostBack事件,可以添加自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel中放置ExtAspNet<em>控件</em>,则渲染时会出现各种<em>问题</em>,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel中渲染ExtAspNet<em>控件</em>,如果容器的display='none',则会出现各种<em>问题</em>(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。 +IE6下,在应用Asp.NetAjax后,Form中字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现<em>问题</em>的经历,你就能明白。 -最后发现IE6下应用Asp.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 页面。 +集成的AspNetAjax有<em>一个</em>很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过<em>一个</em>下午的不断尝试,终于用<em>一个</em>怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject<em>控件</em>。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选中样式微调。[fixed] -预加载Form表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(<em>一个</em>典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid中静态的CheckBoxField图片。[fixed] -<em>TabS</em><em>trip</em>增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击<em>一个</em>Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在<em>tabs</em><em>trip</em>.aspx)[fixed] +2008-07-12 v0.3 beta5 -页面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和<em>Label</em>比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而<em>一个</em>NumberBox和TextBox比较大小需要指定CompareType。 +如果在编辑页面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx/ajax_editor.aspx)。[fixed] -这是由于ajax后执行的javascript中不能有return false语句。 +在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.aspx) [feedback:xmzhu]。[fixed] -在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。 -弹出Window默认显示的错误页面,解决方法在当前目录添加<em>一个</em>空的html页面,然后把Window<em>控件</em>的IFrameUrl指向这个页面而不是"#"。[fixed] +弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例中alert\alert_1.aspx和alert\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。 -点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed] +增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink<em>控件</em>,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed] -增加SplitButton<em>控件</em>。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.aspx。 +<em>TabS</em><em>trip</em>中放置IFrame会出现渲染错误 (示例在<em>tabs</em><em>trip</em>_iframe.aspx)[feedback:jima]。[fixed] -特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed] -FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.aspx)[feedback:jima]。[fixed] +表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有数据,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField<em>控件</em>。[fixed] -其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.aspx)。 -模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed] +控制下拉列表某些项不可以选择(示例在dropdownlist2.aspx)。[fixed] -增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。 -LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.aspx和grid.aspx)。[fixed] +2008-07-07 v0.3 beta2 +增加UpdatePanelConnector<em>控件</em>,支持在布局构建的页面使用Asp.net Ajax。[fixed] -使用UpdatePanelConnector有<em>一个</em>要求:ContentTemplate下只能有<em>一个</em>子节点,比如box:Panel。 -示例在ajax3.aspx/content_page4.aspx。 -示例content_page3.aspx中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器<em>控件</em>的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工添加AutoHeight="true"属性。 +增加UserControlConnector,可以在其中放置用户<em>控件</em>(示例在page_usercontrol.aspx)。[fixed] -也可以在ContentPanel中放置用户<em>控件</em>,注意两者的区别。 +增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed] +支持Asp.net ajax异步加载。[fixed] -有很大局限性,只能在ContentPanel中使用,示例在ajax1.aspx/content_ajax2.aspx中。 -对于使用布局构建的页面(比如content_page1.aspx)还不能使用Asp.net ajax,因为页面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前页面已经被修改(示例在content_page1.aspx/simpleform.aspx)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中做法一致)。 +iframe中的alert/confirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed] -在Firefox下还有<em>问题</em>。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.aspx)。[fixed] -<em>TabS</em><em>trip</em>的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel中放置用户<em>控件</em>(示例在page_usercontrol.aspx)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox<em>控件</em>(示例在twintriggerbox.aspx)。[fixed] -Grid的数据库分页需要增加属性IsDatabasePaging=true,以便普通分页和数据库分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第<em>一个</em>没通过验证的字段)(目前还不能切换到相应的tab)。[fixed] +页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx/simpleform.aspx)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid中的LinkButtonField设置ConfirmText会出错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.aspx示例)。 -Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(<em>一个</em>Grid只能有<em>一个</em>Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。 -切换分页时清空选中的值 [feedback:jqpeng]。 -增加PreRowDataBound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.aspx)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。 +2008-06-25 v0.2 beta9 +Window窗体中的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.aspx/simpleform.aspx)[fixed] -在simpleform.aspx中:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其中26是Toolbar的高度,32是窗口的标题栏和下边框的高度。 +关闭Iframe的LoadMask,所以需要Iframe页面添加PageLoading<em>控件</em>,这样效果统一。[fixed] +Grid完善。 -去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在ASP.NET应用中会有很多<em>问题</em>(主要是状态保持的<em>问题</em>)。 +EnableServerSort改名AllowSorting。(示例在grid_sorting.aspx) -使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件处理函数中重新绑定数据。 +增加AllowPaging属性。(示例在grid_paging.aspx) -使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件处理函数中Grid1.PageIndex = e.NewPageIndex;OK。 +数据库分页支持。(示例在grid_database_paging.aspx) -使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件处理函数中Grid1.PageIn</a></div><div data-report-view="{"mod":"popu_645","index":"3","dest":"https://edu.csdn.net/course/detail/26597","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="" alt data-v-ca2d15ac> <a target="_blank" href="https://edu.csdn.net/course/detail/26597" data-report-click="{"mod":"popu_645","index":"3","dest":"https://edu.csdn.net/course/detail/26597","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew" class="title" data-v-ca2d15ac>VBA从入门到精通(<em>控件</em>+类模块+ADO+SQL数据库)</a></div> <a target="_blank" href="https://edu.csdn.net/course/detail/26597" data-report-click="{"mod":"popu_645","index":"3","dest":"https://edu.csdn.net/course/detail/26597","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew" class="desc" data-v-ca2d15ac>VBA中比较高阶的课程,主要讲解关于各种事件的应用,各种<em>控件</em>的应用,如果使用类模块,如果在VBA用调用SQL语句去处理数据库中的数据等操作。学习完成本课后,你可以在Excel中开发各种小型应用系统。以下是课程主要...</a></div><div data-report-view="{"mod":"popu_645","index":"4","dest":"https://download.csdn.net/download/wode2600/2726130","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="" alt data-v-ca2d15ac> <a target="_blank" href="https://download.csdn.net/download/wode2600/2726130" data-report-click="{"mod":"popu_645","index":"4","dest":"https://download.csdn.net/download/wode2600/2726130","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew" class="title" data-v-ca2d15ac>ExtAspNet_v2.3.2_dll</a></div> <a target="_blank" href="https://download.csdn.net/download/wode2600/2726130" data-report-click="{"mod":"popu_645","index":"4","dest":"https://download.csdn.net/download/wode2600/2726130","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew" class="desc" data-v-ca2d15ac>ExtAspNet - ExtJS based ASP.NET Controls with Full AJAX Support ExtAspNet是一组专业的Asp.net<em>控件</em>库,拥有原生的AJAX支持和丰富的UI效果, 目标是创建没有ViewState,没有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-09-29 v2.3.2 -不绑定任何数据到Grid时,确保页面不会出错。 -修正了Grid列属性DataFormatString的<em>一个</em>bug,比如设置{0:yy-MM-dd HH:mm}时没有效果。 -修正下拉列表<em>控件</em>不能绑定DataTable的BUG(feedback:RedOcean)。 -增加土耳其语言资料文件(feedback:abdullaharslan)。 -Grid的BoundField增加NullDisplayText属性,用于处理数据库中的null值,如果没有设置则默认为空字符串。 -修正DatePicker中的<em>一个</em>bug(31/01/2010将会返回NULL)使用DateFormatString来生成SelectedDate属性(feedback:OktaEndy)。 -修正extjs最新版本(v3.2.2)中的<em>一个</em>bug,如果下拉列表中存在两个相同的Text,则SelectedValue返回值永远是第<em>一个</em>Text的值(feedback:ben.zhou)。 -应用补丁#6593, #6621(feedback:vbelyaev)。 +修正IE7下Grid分页速度慢(feedback:youwei, StevenGuan, hazardvn, gavindou, ttjacky)。 -实际上IE7下所以的回发都慢,原因是客户端的Base64编码速度慢,已经使用encodeURIComponent来代替Base64编码。 -俄语翻译(feedback:vbelyaev)。 +2010-06-30 v2.3.1 -ExtAspNet<em>控件</em>将不在依赖ViewState,减少1/4左右的HTTP数据传输量。 -<em>控件</em>和示例的增强。 +2010-03-28 v2.2.1 +为<em>TabS</em><em>trip</em>的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。 -隐藏示例首页最外层RegionPanel的边框ShowBorder="false"。 +集成Extjs最新版本v3.1.1。 -增加<em>一个</em>新的Theme - Access。 -修正了Firefox下Zoom In/Out时页面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得Asp.net的<em>控件</em>ImageButton具有和Asp.net的Button<em>控件</em>类似的行为(Ajax提交)(feedback:261629698)。 +<em>TabS</em><em>trip</em>增加GetAddTabReference和GetRemoveTabReference两个函数,用来向<em>TabS</em><em>trip</em><em>控件</em>动态增加删除Tab。 -增加示例<em>tabs</em><em>trip</em>/<em>tabs</em><em>trip</em>_addtab.aspx。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为<em>TabS</em><em>trip</em>增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window<em>控件</em>更新。 -关闭按钮默认直接关闭,不会弹出确认对话框。 -GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button<em>控件</em>的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居中,而不是黄金分割位置。 +Button, Window等<em>控件</em>弹出位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后<em>一个</em>参数target变为枚举类型。 -Alert.GetShowReference中的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Extjs最新版本v3.1.0。 -修正灰色皮肤的CSS<em>问题</em>。 -修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button<em>控件</em>将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第<em>一个</em>按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏ExtAspNet<em>控件</em>,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window<em>控件</em>的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。 -增加<em>TabS</em><em>trip</em>中Tab<em>控件</em>可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时会出现空白页面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid中的<em>一个</em>JS<em>问题</em>(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<em>控件</em>中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加中国的省市县三级联动示例(data/shengshixian.aspx)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程中会重复加载的<em>问题</em>,这是<em>一个</em>在v2.1.6引入的<em>问题</em>(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)。 -为容器<em>控件</em>(比如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中的<em>一个</em>命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有<em>控件</em>增加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<em>控件</em>的设计时支持(会在后续版本中逐步完善)。 -v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。 -修正CheckBox<em>控件</em>的CheckedChanged事件会被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等<em>控件</em>增加AutoPostBack属性(feedback:dk3214)。 +为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.aspx +2009-10-19 v2.1.3 +增加支持在AJAX时改变的<em>控件</em>属性列表(/ajax.aspx)。 -ExtAspNet支持原生的AJAX,也就是说<em>控件</em>的属性改变在AJAX过程中会反映到页面中,但并不是所有的<em>控件</em>属性都支持AJAX改变。 -加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保Asp.net的按钮<em>控件</em>仍然具有AJAX的特性。 -更新/basic/login.aspx示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.aspx(feedback:chenguizhu2006)。 -为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。 -Grid中TemplateField生成到页面中<em>控件</em>具有唯一ID,例如Grid1_ct5_<em>Label</em>2,Grid1_ct6_<em>Label</em>2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree<em>控件</em>增加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<em>控件</em>的Target="_parent")。 +为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。 -<em>一个</em>典型应用,在Window<em>控件</em>中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。 -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)。 -添加定时器<em>控件</em>Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree<em>控件</em>的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页面中必须显示的声明<em>控件</em>的集合属性(比如<em>Tabs</em>(<em>TabS</em><em>trip</em>), Items(PanelBase), Nodes(TreeNode))。 -这将会影响所有的aspx页面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX中使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管<em>TabS</em><em>trip</em>, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将会影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。 -将所有的示例转化为英语版本。 -修正Tree<em>控件</em>的<em>一个</em>BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是<em>一个</em>全局变量。 -这个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<em>控件</em>导出为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(CSS中class名不能有$字符)。 +去除PageLayout<em>控件</em>,此<em>控件</em>可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,<em>TabS</em><em>trip</em>)都可以通过这种方式全屏。 -简单方便,示例可以参考 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的提交按钮兼容<em>问题</em>(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容<em>问题</em>,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们做了优化,现在要使<em>一个</em>Asp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的Asp.net<em>控件</em>了。 -在Page_Load中设置了哪些需要在AJAX中更新的Asp.net<em>控件</em>会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的<em>控件</em>。 -示例在aspnet\fckeditor_run.aspx和aspnet\aspnet_run.aspx。 -FCKEditor和上传<em>控件</em>兼容。示例在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增加<em>一个</em>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<em>控件</em>的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的<em>一个</em>BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此<em>问题</em>)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新extjs库到最新版本v3.0 RC2; 目前只有<em>一个</em>缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个页面只包含<em>一个</em>JavaScript文件(语言文件除外)和<em>一个</em>CSS文件。 -ExtAspNet自身的CSS会紧挨着页面标签引入,这样在中自定义的样式可以覆盖ExtAspNet缺省样式。 +Alert对话框会遮挡所有的Window窗口。 -使用<em>一个</em>变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。 -重新绑定模拟树的下拉列表后,选中项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed] -Window中的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed] -页面包含FileUpload<em>控件</em>,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet/fileupload.aspx)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(Ext-Window)含有ASP.NET<em>控件</em>FileUpload,则此弹出窗口在关闭时出现JS错误(http://extjs.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果页面中存在ASP.NET<em>控件</em>(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的<em>问题</em>)。[fixed] -页面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed] -ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added] +如果以前你听过不要在ExtAspNet工程中使用ASP.NET标准<em>控件</em>的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet<em>控件</em>和ASP.NET标准<em>控件</em>和平共处了。[fixed] -如果<em>一个</em>ASP.NET按钮<em>控件</em>要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET<em>控件</em>的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet/aspnet.aspx)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed] -自动测试功能会在以后版本中逐步完善。这个版本完成测试框架,采用Extjs中JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建<em>一个</em>Window<em>控件</em>的代码由原来的2000字符减少为500个字符。 -PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。 ---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference/GetConfirmFormModifiedCloseRefreshReference/GetConfirmFormModifiedClosePostBackReference三个方法代替。 -不会修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面添加box_parent_client_id查询字符串 -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的ASPX页面中查找RegisterPageStateChangedScript属性,并删除,否则会运行错误! -A页面有Ext-Window<em>控件</em>弹出B页面,B页面有Ext-Window<em>控件</em>弹出C页面,B页面的Ext-Window<em>控件</em>设置Target='_parent',则弹出的Ext-Window(C页面)会覆盖整个A页面,这是正确的。 ---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不会出错了。 -Window<em>控件</em>的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window<em>控件</em>增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。 ---Window<em>控件</em>的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window<em>控件</em>的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。 -如果弹出窗口(Window<em>控件</em>)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。 ---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window<em>控件</em>的IFrameName属性是自动生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第<em>一个</em>参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel中内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed] -DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed] -升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏<em>问题</em>的修正)。[fixed] -页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added] +增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageContext优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image<em>控件</em>增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包中增加<em>一个</em>Web.config.txt,这是<em>一个</em>空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +<em>TabS</em><em>trip</em>的Tab<em>控件</em>的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed] -有这样<em>一个</em>效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用<em>控件</em>的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的<em>问题</em>。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-aspnet-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemText/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new ExtAspNet.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。 -和Asp.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列表项。 -处于布局内的容器<em>控件</em>(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed] -注意,<em>控件</em>的高度指的是整个<em>控件</em>的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有<em>控件</em>属性增加在VS中的智能提示。[fixed] -需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。 +<em>控件</em>的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:<em>一个</em>属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为<em>控件</em>。[fixed] -可以方便的在子页面(iframe)中通过js切换父页面中选中的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.aspx,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的动态添加<em>控件</em>,并且可以给<em>控件</em>添加服务器端事件(示例在form/form_dynamic_run.aspx)。[fixed] +2008-10-15 v1.2 beta5 -验证表单字段的ValueToCompare属性,为字符串时会出错的BUG。[fixed] +优化下拉列表。[fixed] -验证下拉列表时,应该取ListItem的Value属性进行验证,而不是Text属性。 -DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。 -DropDownList不支持EmptyText属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)中设置哪些项不可选择,以及创建模拟下拉树。 -DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则自动将EnableSimulateTree设置为true。 +2008-09-27 v1.2 beta4 +EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other/accordion_run.aspx)。[fixed] -Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。 -影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。 -AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed] +AccordionPanel增加Links属性,可以绑定列表数据到AccordionPanel,呈现的是链接的列表(示例在other/accordion_links_run.aspx)。[fixed] -原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上标签。 -适当增大AccordionPanel中链接的高度20px->22px,同时对链接的样式也做了微调。 -通过BodyPadding控制链接列表的边距。 -这样能大大减少ASPX中HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在ASPX页切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -<em>TabS</em><em>trip</em>/Toolbar -<em>TabS</em><em>trip</em>去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form中动态添加<em>控件</em>的BUG,现在form/form_dynamic_run.aspx示例已经能正确运行。[fixed] +大部分容器的子<em>控件</em>集合更正为Items(以前有些是Rows)。[fixed] -影响的<em>控件</em>包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留<em>TabS</em><em>trip</em>的<em>Tabs</em>(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选中项中会存在当前不存在的行序号,导致服务器端遍历选中项时数组越界。所有使用box<em>控件</em>的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例中表单<em>控件</em>都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/<em>Label</em>/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在ASPX中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在<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>默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/<em>TabS</em><em>trip</em>(Card),所有布局<em>控件</em>默认的布局是Container。 -经常用到的布局<em>控件</em>:SimpleForm/Form/Accordion/<em>TabS</em><em>trip</em>/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果<em>一个</em>菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的ExtAspNet<em>控件</em>增加Hidden属性(少数几个<em>控件</em>没有此属性:Menu),这样在Ajax时可以显示隐藏<em>控件</em>。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的<em>控件</em>渲染到客户端但是隐藏。 -US的ExtAspNet改造强烈依赖于此属性,这个版本发布后可以继续。 -网报中唯一没有用到ExtAspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageContext.Redirect支持普通页面转向和ExtAspNetAjax下页面转向。[fixed] +模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多<em>控件</em>(Grid,DropDownList,<em>TabS</em><em>trip</em>)。 -解决方法: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>控件</em>(以后不会用AspnetAjax,这个<em>控件</em>已经完成使命)。[fixed] -不要使用Asp.net的<em>控件</em>HiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的<em>控件</em>在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList中项如果存在汉字,则会换行的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab中如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个<em>问题</em>。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父<em>控件</em>(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第<em>一个</em>Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config中增加配置项Form<em>Label</em>Width="80"(默认为80),同时PageManager增加Form<em>Label</em>Width属性用来控制页面上所有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 -<em>TabS</em><em>trip</em>增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。 -基本思想:安全的Ajax交互,明确Ajax回发时支持<em>控件</em>哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供<em>控件</em>级别的EnableAjax属性。 -整理支持Ajax的<em>控件</em>属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。 -网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window<em>控件</em>是否弹出的状态在回发时维持。[fixed] -<em>控件</em>设计的<em>一个</em>原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃Asp.NetAjax,ExtAspNet<em>控件</em>内置Ajax支持。[fixed] -这是<em>一个</em>值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击<em>一个</em>按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前ExtAspNetAjax的限制。 -只对ExtAspNet<em>控件</em>起作用,对Asp.net<em>控件</em>不起作用。 -对容器<em>控件</em>(有子<em>控件</em>的<em>控件</em>)不起作用,只对最底层的<em>控件</em>起作用。 -对改变<em>控件</em>的Visible属性会有错误。 -Window<em>控件</em>的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading<em>控件</em>。[fixed] -Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选中的状态在回发后会得到保持。[fixed] -Grid选中行的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知<em>问题</em>:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。 -主要是父页面加载<em>一个</em>比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹出窗口中IFrame的显示速度。[fixed] -在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed] -<em>一个</em>典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.aspx)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +<em>TabS</em><em>trip</em>中非当前Tab会延迟渲染。[fixed] -这会明显加快页面的渲染速度,网报中<em>一个</em>典型的费用审批页面可以减少200ms的渲染时间。 -由于非当前Tab不会在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到<em>控件</em>的render事件中。 -不能比较两个DataPicker大小的BUG。[fixed] -<em>TabS</em><em>trip</em>延迟加载引起的BUG(非当前Tab中的ContentPanel会占据页面空间,已修正)。[fixed] -全新的ExtAspNet.Examples(基础知识/表单<em>控件</em>/数据绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe/default.aspx和iframe/page3.aspx)。[fixed] -测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed] +extjs的BUG,当页面中含有iframe时,Ext.onReady会被调用两次(IE6/IE7)(http://www.extjs.net/forum/showthread.php?t=43246)(示例在test.aspx)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发页面再弹出IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种做法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference("./simpleform.aspx"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下会有JS错误。[fixed] -增加BorderLayout<em>控件</em>,示例在iframe/borderlayout.aspx。[fixed] +Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -动态向Form中添加FormRow,并动态的向FormRow中添加表单字段,以及如何取得表单字段的值。(示例在form_dynamic.aspx)[fixed] +IFrame弹出窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是<em>一个</em>重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window中的IFrame被添加到页面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此<em>问题</em>解决。(示例在button_iframe.aspx) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下会有JS错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正<em>一个</em>的内存泄漏。[fixed] -IE7下测试,打开iframe/default.aspx页面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.aspx页面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.aspx页面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE会自动进行垃圾回收。 +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 -<em>TabS</em><em>trip</em>延时加载出错。[fixed] -Window的IFrameUrl处理的BUG,比如Pages_ExtAspNet目录下的页面应该为./FE_ApplyEditor.aspx或~/Pages_ExtAspNet/FE_ApplyEditor.aspx。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则会JS错误。[fixed] -实现网报首页下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed] -优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.aspx默认会加载form.aspx页面(Window<em>控件</em>的BUG)。[fixed] -Window中的保存并关闭按钮和Asp.netAjax冲突。[fixed] -优化关闭Window的js脚本,减少写到页面的js大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.aspx)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的Asp.net<em>控件</em>一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的js对象的名称简单化,这样可以减少生成的js内容,加快页面加载速度(<em>一个</em>典型页面的js由原来的33.0k降低为21.4k)。[fixed] +弹出窗口中,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed] -因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。 -一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。 -另一种办法就是在PageManager<em>控件</em>中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx/simpleform.aspx)。 +PageManager<em>控件</em>增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed] -这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报中遇到这种情况)。 -每个页面必须添加<em>一个</em>PageManager<em>控件</em>,否则会出错,同时去除DesignTimeStyle<em>控件</em>(作为PageManager的属性出现)。[fixed] -TextField等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed] -最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.aspx/page2.aspx/simpleform.aspx) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window<em>控件</em>增加<em>一个</em>属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,<em>控件</em>本身封装了大量的代码,简单来看现在有三个页面(default.aspx(A)/page2.aspx(B)/simpleform.aspx(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我会通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid中弹出窗口。(default.aspx/page3.aspx/simpleform.aspx) +示例3,TriggerBox弹出窗口。(default.aspx/triggerbox.aspx/simpleform.aspx) -在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。 -示例4,弹出窗口中的弹出窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下<em>TabS</em><em>trip</em>在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对<em>TabS</em><em>trip</em>/Panel/Window中的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不会有残影出现。[fixed] -如果<em>TabS</em><em>trip</em>的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在<em>tabs</em><em>trip</em>_iframe.aspx)。[fixed] -Tree<em>控件</em>,点击<em>一个</em>节点自动回发,则当前点击的那个节点的选中状态不会保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx/simpleform.aspx)。[fixed] -内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.aspx,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。 -参照Yslow的评分规则,将JS文件引用由head移动到body中。[fixed] -Firefox下,如果页面太长会出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed] +IFrame内的页面宽度和高度会自动设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx/simpleform.aspx/simpleform2.aspx)[fixed] -增加PageManager<em>控件</em>(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image<em>控件</em> [feedback:jima]。[fixed] -Tree<em>控件</em>,如果<em>一个</em>节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed] -去掉DropDownList<em>控件</em>的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息中的换行符(转换为),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree<em>控件</em>。[fixed] -如何将数据库中的数据绑定到Tree(示例在tree2_bind_database.aspx)。 -ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.aspx)。 -更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同<em>一个</em>页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltipFormatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed] -发现原来ie6不能正确解析li的高度,必须手工设置才行(style="height:20px;")。 +IE6/IE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed] -虽然最后未能解决##差旅交通费在IE和Firefox下显示的不同效果。 -但是通过用来代替,从而实现FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“差旅交通费”,在IE下和FF下的都不换行,:-) -LinkButton增加OnClick事件 [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树<em>控件</em>(Tree)(示例在tree2.aspx)。[fixed] -可以在回发时维持树的状态(选中行,折叠/展开,CheckBox)。 -可以通过Inline的方式添加树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到页面,也可以引发PostBack事件,可以添加自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel中放置ExtAspNet<em>控件</em>,则渲染时会出现各种<em>问题</em>,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel中渲染ExtAspNet<em>控件</em>,如果容器的display='none',则会出现各种<em>问题</em>(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。 +IE6下,在应用Asp.NetAjax后,Form中字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现<em>问题</em>的经历,你就能明白。 -最后发现IE6下应用Asp.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 页面。 +集成的AspNetAjax有<em>一个</em>很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过<em>一个</em>下午的不断尝试,终于用<em>一个</em>怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject<em>控件</em>。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选中样式微调。[fixed] -预加载Form表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(<em>一个</em>典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid中静态的CheckBoxField图片。[fixed] -<em>TabS</em><em>trip</em>增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击<em>一个</em>Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在<em>tabs</em><em>trip</em>.aspx)[fixed] +2008-07-12 v0.3 beta5 -页面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和<em>Label</em>比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而<em>一个</em>NumberBox和TextBox比较大小需要指定CompareType。 +如果在编辑页面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx/ajax_editor.aspx)。[fixed] -这是由于ajax后执行的javascript中不能有return false语句。 +在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.aspx) [feedback:xmzhu]。[fixed] -在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。 -弹出Window默认显示的错误页面,解决方法在当前目录添加<em>一个</em>空的html页面,然后把Window<em>控件</em>的IFrameUrl指向这个页面而不是"#"。[fixed] +弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例中alert\alert_1.aspx和alert\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。 -点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed] +增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink<em>控件</em>,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed] -增加SplitButton<em>控件</em>。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.aspx。 +<em>TabS</em><em>trip</em>中放置IFrame会出现渲染错误 (示例在<em>tabs</em><em>trip</em>_iframe.aspx)[feedback:jima]。[fixed] -特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed] -FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.aspx)[feedback:jima]。[fixed] +表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有数据,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField<em>控件</em>。[fixed] -其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.aspx)。 -模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed] +控制下拉列表某些项不可以选择(示例在dropdownlist2.aspx)。[fixed] -增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。 -LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.aspx和grid.aspx)。[fixed] +2008-07-07 v0.3 beta2 +增加UpdatePanelConnector<em>控件</em>,支持在布局构建的页面使用Asp.net Ajax。[fixed] -使用UpdatePanelConnector有<em>一个</em>要求:ContentTemplate下只能有<em>一个</em>子节点,比如box:Panel。 -示例在ajax3.aspx/content_page4.aspx。 -示例content_page3.aspx中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器<em>控件</em>的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工添加AutoHeight="true"属性。 +增加UserControlConnector,可以在其中放置用户<em>控件</em>(示例在page_usercontrol.aspx)。[fixed] -也可以在ContentPanel中放置用户<em>控件</em>,注意两者的区别。 +增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed] +支持Asp.net ajax异步加载。[fixed] -有很大局限性,只能在ContentPanel中使用,示例在ajax1.aspx/content_ajax2.aspx中。 -对于使用布局构建的页面(比如content_page1.aspx)还不能使用Asp.net ajax,因为页面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前页面已经被修改(示例在content_page1.aspx/simpleform.aspx)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中做法一致)。 +iframe中的alert/confirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed] -在Firefox下还有<em>问题</em>。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.aspx)。[fixed] -<em>TabS</em><em>trip</em>的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel中放置用户<em>控件</em>(示例在page_usercontrol.aspx)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox<em>控件</em>(示例在twintriggerbox.aspx)。[fixed] -Grid的数据库分页需要增加属性IsDatabasePaging=true,以便普通分页和数据库分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第<em>一个</em>没通过验证的字段)(目前还不能切换到相应的tab)。[fixed] +页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx/simpleform.aspx)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid中的LinkButtonField设置ConfirmText会出错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.aspx示例)。 -Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(<em>一个</em>Grid只能有<em>一个</em>Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。 -切换分页时清空选中的值 [feedback:jqpeng]。 -增加PreRowDataBound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.aspx)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。 +2008-06-25 v0.2 beta9 +Window窗体中的</a></div><div data-report-view="{"mod":"popu_645","index":"5","dest":"https://download.csdn.net/download/zhangsan000000/1059933","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="" alt data-v-ca2d15ac> <a target="_blank" href="https://download.csdn.net/download/zhangsan000000/1059933" data-report-click="{"mod":"popu_645","index":"5","dest":"https://download.csdn.net/download/zhangsan000000/1059933","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew" class="title" data-v-ca2d15ac>asp.net专家疑难解答200问源码</a></div> <a target="_blank" href="https://download.csdn.net/download/zhangsan000000/1059933" data-report-click="{"mod":"popu_645","index":"5","dest":"https://download.csdn.net/download/zhangsan000000/1059933","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\",\"dist_request_id\":\"1713519004769_44848\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew" class="desc" data-v-ca2d15ac>第1章 空 第2章 ASP.NET运行模型 21.如何在页面中应用javascript脚本-示例1 21.如何在页面中应用javascript脚本-示例2 22.如何实现从服务器端向页面动态添加javascript脚本-示例1 22.如何实现从服务器端向页面动态添加javascript脚本-示例2 24.如何处理多页面重定向到同一页面后的返回<em>问题</em> 25.如何用Response.Redirect方法传递汉字 29.如何利用输出缓存技术缓存整个页面 30.如何利用片段缓存技术对用户<em>控件</em>进行缓存 31.如何利用数据缓存技术提高程序的性能 33.如何实现当页面产生错误时重定向到自定义错误界面 35.如何在程序中读写Web.config文件 37.如何使用CSS文件定义<em>控件</em>的样式 38.如何启用和禁用ViewState保存状态信息的功能 39.如何应用IsPostBack控制页面的加载 41.如何使用Trace对象进行跟踪调试(页面级) 42.如何使用#Include语法将文件添加到页面 43.如何使用编程的方式处理异常信息 44.如何将网页错误信息写入事件日志 第3章 常用Web服务<em>控件</em> 46.如何使用<em>Label</em><em>控件</em>动态显示文本信息 47.如何实现当鼠标移到<em>控件</em>时显示提示信息 48.如何在Web应用程序中实现快捷键功能(使用脚本实现) 48.如何在Web应用程序中实现快捷键功能(使用属性实现) 49.如何设置页面上<em>控件</em>的Tab键顺序 50.如何实现用回车键代替Tab键的功能 51.如何为按钮键添加消息框 52.Button、LinkButton和ImageButton服务<em>控件</em>的区别及应用 54.如何使用CheckBox和CheckBoxList<em>控件</em>(CheckBox示例) 54.如何使用CheckBox和CheckBoxList<em>控件</em>(CheckBoxList示例) 55.如何使用RadioButton和RadioButtonList<em>控件</em>(RadioButton示例) 55.如何使用RadioButton和RadioButtonList<em>控件</em>RadioButtonList示例) 56.如何使用Panel<em>控件</em>操作一组<em>控件</em> 57.如何使用Table<em>控件</em>组织页面的内容 58.如何实现DropDownList<em>控件</em>选项的添加、删除等操作 59.如何实现间接改变DropDownList<em>控件</em>的当前选项 60.如何实现两个或多个DropDownList<em>控件</em>的联动 61.如何实现ListBox<em>控件</em>选项的上移、下移、添加和删除操作 62.如何实现ListBox<em>控件</em>中选项的双击事件 63.如何动态设置ListBox<em>控件</em>中各选项的背景颜色 64.如何在页面中动态创建<em>控件</em> 65.如何为HTML服务器<em>控件</em>的事件添加自定义方法 第4章 验证<em>控件</em> 67.如何使用RequiredFieldValidator<em>控件</em>验证用户是否输入信息 68.如何使用RegularExpressionValidator<em>控件</em>验证E-mail地址和邮编等格式 69.如何使用RangeValidator<em>控件</em>验证输入的信息是否在指定范围内 70.如何使用CompareValidator<em>控件</em>对两个输入<em>控件</em>比较验证 71.如何使用CustomValidator<em>控件</em>自定义验证格式 72.如何使用ValidationSummary<em>控件</em>总结所有验证<em>控件</em>的错误信息 73.如何创建自定义功能的验证<em>控件</em> 74.如何禁用服务器<em>控件</em>的验证功能 75.如何控制页面部分验证<em>控件</em>有效 76.如何实现<em>控件</em>即时验证功能 77.如何使用验证<em>控件</em>综合验证用户注册页面 78.如何验证DataGrid<em>控件</em>的编辑列 81.如何使用验证<em>控件</em>验证日期类型的输入(CompareValidator) 81.如何使用验证<em>控件</em>验证日期类型的输入(CustomerValidator) 81.如何使用验证<em>控件</em>验证日期类型的输入(RegularValidator) 第5章 高级Web<em>控件</em> 82.如何在网页中使用Calendar Web<em>控件</em>显示和选择日期 83.如何在Calendar Web<em>控件</em>中控制个别日的内容及显示 84.如何在Calendar Web<em>控件</em>中控制用户日期选定 86.如何使用XML<em>控件</em>显示XML文件和进行XSLT转换 87.如何使用AdRotator Web<em>控件</em>制作广告发布程序-示例1 87.如何使用AdRotator Web<em>控件</em>制作广告发布程序-示例2 88.如何创建用户<em>控件</em> 89.如何将Web窗体转换成用户<em>控件</em> 90.如何实现动态加载用户<em>控件</em> 92.如何使用<em>TabS</em><em>trip</em> Web和MultiP</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/VB_API" class="community-img" data-v-4722a3ae><img src="https://g.csdnimg.cn/static/user-img/default-user.png" alt data-v-4722a3ae> <div title="API" class="community-name" data-v-4722a3ae> API </div></a></div></div> <div class="content" data-v-4722a3ae><div class="detail" data-v-4722a3ae><div title="1486" class="item" data-v-4722a3ae><p class="num" data-v-4722a3ae> 1,486 </p> <p class="desc" data-v-4722a3ae> 社区成员 </p></div> <div title="23280" class="item" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/VB_API" target="_blank" data-v-4722a3ae><p class="num" data-v-4722a3ae> 23,280 </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-2882" 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/shareBg5.9eaaa691.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://g.csdnimg.cn/static/user-img/default-user.png" alt="" class="share-avatar" data-v-ca030a68> <div class="share-tit" data-v-ca030a68>API</div> <div class="share-dec" data-v-ca030a68>VB API</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> VB API </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_29" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/default.jpg!1" alt="API" 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="" 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:///VB_API/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":"YJXcJYcX-y1h4sb6NG4230e38SZyI-9wm37I","origin":"http:\u002F\u002Fbbs.csdn.net","isMobile":false,"cookie":"uuid_tt_dd=10_3168465590-1713519004728-656037;","ip":"18.226.177.223","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":"VB_API","communityHomePage":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FVB_API","owner":{"userName":"community_29","nickName":"API","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":"API","description":"VB API","avatarUrl":"https:\u002F\u002Fg.csdnimg.cn\u002Fstatic\u002Fuser-img\u002Fdefault-user.png","qrCode":"","createTime":"2007-09-28","communityAvatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","communityNotice":null,"userCount":1486,"contentCount":23280,"followersCount":1208,"communityRule":"","communityId":148,"bgImage":"","hashId":"81r28xr5","domain":"","uriName":"VB_API","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_29","tagNameInfo":{"provinceTag":null,"areaTag":null,"technologyTags":null,"customTags":null}},"tabList":[{"tabId":1307,"tabName":"全部","tabUrl":"","tabSwitch":1,"tabType":4,"tabContribute":0,"cardType":0,"indexOrder":-1,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FVB_API?typeId=1307","iframe":false,"sortType":1},{"tabId":1620018,"tabName":"Ada助手","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":20,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FVB_API?typeId=1620018","iframe":false,"sortType":1}],"dataResource":{"mediaType":"c_cloud","subResourceType":"8_c_cloud_long_text","showType":"long_text","tabId":0,"communityName":"API","communityHomePageUrl":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FVB_API","communityType":1,"content":{"id":"90416529","contentId":90416529,"cateId":0,"cateName":null,"url":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F90416529","shareUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F90416529","createTime":"2006-11-15 11:37:46","updateTime":"2021-05-28 15:07:43","resourceUsername":"bizshow","best":0,"top":0,"text":null,"publishDate":"2006-11-15","lastReplyDate":"2007-03-15","type":"13","nickname":"bizshow","avatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F99d14a094ed343398f17d2be870560c8_bizshow.jpg!1","username":"bizshow","commentCount":11,"diggNum":0,"digg":false,"viewCount":226,"hit":false,"resourceSource":6,"status":10,"taskStatus":null,"expired":false,"taskCate":0,"taskAward":0,"taskExpired":null,"checkRedPacket":null,"avgScore":0,"totalScore":0,"topicTitle":"送分啦!!!!一个关于TabStrip和Label控件的问题","insertFirst":false,"likeInfo":null,"description":"一般用TabStrip做分页的时候,都是用PictureBox做每个页的容器,这样操作起来很方便. 可是我发现一个问题,当某些Windows主题的TabStrip有背景的时候,PictureBox却做不出背景来 本来我想放弃PictureBox做容器,直接将控件放到TabStrip上面,然后在切换分页的时候再隐藏\u002F显示控件 但是我又发现一个问题,TabStrip控件是一个和Label控件一样,不能做容器的控件, 而且Label控件也不能置于TabStrip控件的上面 我仔细研究了Windows的","coverImg":"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221109053539.png","content":"一般用TabStrip做分页的时候,都是用PictureBox做每个页的容器,这样操作起来很方便.\u003Cbr \u002F\u003E\n可是我发现一个问题,当某些Windows主题的TabStrip有背景的时候,PictureBox却做不出背景来\u003Cbr \u002F\u003E\n本来我想放弃PictureBox做容器,直接将控件放到TabStrip上面,然后在切换分页的时候再隐藏\u002F显示控件\u003Cbr \u002F\u003E\n但是我又发现一个问题,TabStrip控件是一个和Label控件一样,不能做容器的控件,\u003Cbr \u002F\u003E\n而且Label控件也不能置于TabStrip控件的上面\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n我仔细研究了Windows的属性页,发现没有这个问题,例如在桌面上点右键>属性,\u003Cbr \u002F\u003E\n任何一个页都可以看到背景,所以可以判断没使用PictureBox(事后我用Spy++查了,的确没有)\u003Cbr \u002F\u003E\n所有控件都是直接放到TabStrip上的,可是他是如何做到的呢?\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n目前我能想到的办法只有2个:\u003Cbr \u002F\u003E\n1:用一个透明背景的容器\u003Cbr \u002F\u003E\n2:用一个可以置于其他控件之上的Label控件,并且BackStyle可以=0(透明)]\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n可是这两个控件基本上找不到..\u003Cbr \u002F\u003E\n\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":{"userName":"bizshow","roleId":153,"roleType":0,"roleStatus":1,"honoraryId":0,"roleName":"","honoraryName":null,"communityNickname":"","communitySignature":""},"allowPost":false,"submitHistory":[{"user":{"registerurl":"https:\u002F\u002Fg.csdnimg.cn\u002Fstatic\u002Fuser-reg-year\u002F1x\u002F19.png","avatarurl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F99d14a094ed343398f17d2be870560c8_bizshow.jpg!1","nickname":"bizshow","selfdesc":"","createdate":"2005-06-03 16:58:00","days":"6896","years":"19","username":"bizshow","school":null,"company":null,"job":null},"userName":"bizshow","event":"创建了帖子","body":"2006-11-15 11:37","editId":null}],"resourceExt":{}},"contentReply":{"pageNo":1,"pageSize":20,"totalPages":1,"totalCount":11,"total":0,"list":[{"hit":null,"hitMsg":null,"content":"windows commem control 6.0 不支持透明,除非用很复杂的API,否则picturebox是不能透明的.","topicTitle":null,"description":"windows commem control 6.0 不支持透明,除非用很复杂的API,否则picturebox是不能透明的.","id":70571393,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"liusiheng","userNickName":"liusiheng","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":976195330,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2007-03-15 11:02:46","updateTime":"2007-03-15 11:02:46","formatTime":"2007-03-15","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":"mark","topicTitle":null,"description":"mark","id":65030424,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"baiyu123","userNickName":"学习Java中","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fe3ef1aee059f471f9baa4f1e6f445ba0_baiyu123.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":"2006-11-16 08:51:22","updateTime":"2006-11-16 08:51:22","formatTime":"2006-11-16","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":"form2.0 是ms在vb6sp6补丁中引入的一种新的窗体,他以及它所带的控件有许多新的特性\u003Cbr \u002F\u003E\n要使用form2.0必须先给vb打上sp6的补丁(你在部件里多出来了一个叫microsoft form 2.0 object library的控件,这个控件你不必勾选,即使你勾选了,新的控件的某些功能在旧版本的窗体上也不能很好的运作)\u003Cbr \u002F\u003E\n然后通过“工程”菜单中的Microsoft Form 2.0 form 来添加这个新的窗体","topicTitle":null,"description":"form2.0 是ms在vb6sp6补丁中引入的一种新的窗体,他以及它所带的控件有许多新的特性 要使用form2.0必须先给vb打上sp6的补丁(你在部件里多出来了一个叫microsoft form 2.0 object library的控件,这个控件你不必勾选,即使你勾选了,新的控件的某些功能在旧版本的窗体上也不能很好的运作) 然后通过“工程”菜单中的Microsoft Form 2.0 form 来添加这个新的窗体","id":65030397,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"Alzzl","userNickName":"Alzzl","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":"2006-11-16 08:50:00","updateTime":"2006-11-16 08:50:00","formatTime":"2006-11-16","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":"cangwu_lee(小橙子)\u003Cbr \u002F\u003E\n你说的用TTSTRIP,虽然可以做容器,可是他不支持XP的皮肤啊,\u003Cbr \u002F\u003E\n我做的是一套公共程序,界面元素都比较重要,\u003Cbr \u002F\u003E\n为此我甚至放弃了COMMEN CONTROL 6.0而改用的5.0(5.0可以支持皮肤)\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nAlzzl(果子林) \u003Cbr \u002F\u003E\nForm2.0 是什么意思?","topicTitle":null,"description":"cangwu_lee(小橙子) 你说的用TTSTRIP,虽然可以做容器,可是他不支持XP的皮肤啊, 我做的是一套公共程序,界面元素都比较重要, 为此我甚至放弃了COMMEN CONTROL 6.0而改用的5.0(5.0可以支持皮肤) Alzzl(果子林) Form2.0 是什么意思?","id":65025738,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"bizshow","userNickName":"bizshow","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F99d14a094ed343398f17d2be870560c8_bizshow.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":"2006-11-16 04:56:23","updateTime":"2006-11-16 04:56:23","formatTime":"2006-11-16","userRoleHonorary":{"userName":"bizshow","roleId":153,"roleType":0,"roleStatus":1,"honoraryId":0,"roleName":"","honoraryName":null,"communityNickname":"","communitySignature":""},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"proglovercn(冰雪)\u003Cbr \u002F\u003E\nTextBox背景不透明啊,照样不能显示出TabStrip的背景呀","topicTitle":null,"description":"proglovercn(冰雪) TextBox背景不透明啊,照样不能显示出TabStrip的背景呀","id":64991831,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"bizshow","userNickName":"bizshow","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F99d14a094ed343398f17d2be870560c8_bizshow.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":"2006-11-15 11:57:15","updateTime":"2006-11-15 11:57:15","formatTime":"2006-11-15","userRoleHonorary":{"userName":"bizshow","roleId":153,"roleType":0,"roleStatus":1,"honoraryId":0,"roleName":"","honoraryName":null,"communityNickname":"","communitySignature":""},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"用TextBox代替Label试试","topicTitle":null,"description":"用TextBox代替Label试试","id":64991282,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"proglovercn","userNickName":"proglovercn","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Ff678d37f27ed45df8601c1fe8a03850c_proglovercn.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":"2006-11-15 11:40:04","updateTime":"2006-11-15 11:40:04","formatTime":"2006-11-15","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":"TabStrip 这些属于form2.0的控件只有在form2.0中才能 正常使用","topicTitle":null,"description":"TabStrip 这些属于form2.0的控件只有在form2.0中才能 正常使用","id":65002048,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"Alzzl","userNickName":"Alzzl","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":"2006-11-15 05:16:26","updateTime":"2006-11-15 05:16:26","formatTime":"2006-11-15","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":"用SSTab\u003Cbr \u002F\u003E\n每个页都是容器\u003Cbr \u002F\u003E\n简单的多","topicTitle":null,"description":"用SSTab 每个页都是容器 简单的多","id":64994912,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"yangao","userNickName":"yangao","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F62dfe94a5bb3402bbb3fa6099e6fb6b5_yangao.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":"2006-11-15 01:40:03","updateTime":"2006-11-15 01:40:03","formatTime":"2006-11-15","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":64994743,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"jam021","userNickName":"jam021","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":"2006-11-15 01:35:32","updateTime":"2006-11-15 01:35:32","formatTime":"2006-11-15","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","topicTitle":null,"description":"好久没顶了,顶一个 ","id":64994606,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"iland9876543210","userNickName":"iland9876543210","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fd67cd73a9b62492fac20333f87a67e07_iland9876543210.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":"2006-11-15 01:31:37","updateTime":"2006-11-15 01:31:37","formatTime":"2006-11-15","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":"换用 SSTab 控件 \u003Cbr \u002F\u003E\n \u003Cbr \u002F\u003E\n","topicTitle":null,"description":"换用 SSTab 控件 ","id":64993721,"contentResourceId":90416529,"bindContentResourceId":0,"communityId":148,"username":"cangwu_lee","userNickName":"cangwu_lee","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F4af93a6273264d1ab2c34f6d2f77ab1b_cangwu_lee.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":"2006-11-15 01:05:51","updateTime":"2006-11-15 01:05:51","formatTime":"2006-11-15","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":1307,"recommends":[{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwy600716\u002F172995","title":"ASP.net技术内幕","desc":"ASP的最新版本ASP.NET是Microsoft用于建立动态的数据库驱动网站的技术。内容包括:ASP.NET Web表单的使用,高级ASP.NET页面的开发,ADO.NET的使用,ASP.NET应用程序的使用, ASP.NET应用程序的保护,ASP.NET Web服务的建立,.NET框架的利用,自定义的ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E的建立,ASP.NET的应用程序示例等。\u003Cbr\u002F\u003E本书内容丰富、图文并茂,适合于需要创建网站的专业程序员阅读。本书是关于使用ASP.NET建立网站的完整参考书,书中包含数百个代码示例,读者可以使用这些示例开始建立自己的网站\u003Cbr\u002F\u003E前言\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第一部分 使用ASP.NET Web表单\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第1章 建立ASP.NET页面 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E1.1 ASP.NET和.NET框架 \u003Cbr\u002F\u003E1.1.1 .NET框架类库 \u003Cbr\u002F\u003E1.1.2 理解名称空间 \u003Cbr\u002F\u003E1.1.3 标准的ASP.NET名称空间 \u003Cbr\u002F\u003E1.1.4 与.NET框架兼容的语言 \u003Cbr\u002F\u003E1.2 ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E简介 \u003Cbr\u002F\u003E1.2.1 简单的ASP.NET页面 \u003Cbr\u002F\u003E1.2.2 ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E的优点 \u003Cbr\u002F\u003E1.2.3 ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E概述 \u003Cbr\u002F\u003E1.3 向ASP.NET页面中添加应用逻辑 \u003Cbr\u002F\u003E1.3.1 处理\u003Cem\u003E控件\u003C\u002Fem\u003E事件 \u003Cbr\u002F\u003E1.3.2 处理页面事件 \u003Cbr\u002F\u003E1.4 ASP.NET页面的结构 \u003Cbr\u002F\u003E1.4.1 指令 \u003Cbr\u002F\u003E1.4.2 代码声明块 \u003Cbr\u002F\u003E1.4.3 ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E1.4.4 代码显示块 \u003Cbr\u002F\u003E1.4.5 服务器端注释 \u003Cbr\u002F\u003E1.4.6 服务器端包含指令 \u003Cbr\u002F\u003E1.4.7 文本和HTML标记 \u003Cbr\u002F\u003E1.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第2章 用Web服务器\u003Cem\u003E控件\u003C\u002Fem\u003E建立表单 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E2.1 建立智能表单 \u003Cbr\u002F\u003E2.1.1 \u003Cem\u003ELabel\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E\u003Cbr\u002F\u003E2.1.2 TextBox\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.1.3 Button\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.1.4 RadioButton和RadioButtonList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.1.5 CheckBox和CheckBoxList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.1.6 DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.1.7 ListBox\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.2 控制页面导航 \u003Cbr\u002F\u003E2.2.1 将表单提交到另\u003Cem\u003E一个\u003C\u002Fem\u003E页面 \u003Cbr\u002F\u003E2.2.2 使用Redirect( )方法 \u003Cbr\u002F\u003E2.2.3 使用HyperLink\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E2.3 在\u003Cem\u003E控件\u003C\u002Fem\u003E上进行格式化 \u003Cbr\u002F\u003E2.3.1 基本Web\u003Cem\u003E控件\u003C\u002Fem\u003E属性 \u003Cbr\u002F\u003E2.3.2 在Web\u003Cem\u003E控件\u003C\u002Fem\u003E上应用样式 \u003Cbr\u002F\u003E2.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第3章 用检验\u003Cem\u003E控件\u003C\u002Fem\u003E执行表单的检验 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E3.1 使用客户端检验 \u003Cbr\u002F\u003E3.1.1 配置客户端检验 \u003Cbr\u002F\u003E3.1.2 启用和禁用客户端检验 \u003Cbr\u002F\u003E3.2 必填域:RequiredFieldValidator\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E3.3 检验表达式:RegularExpressionValidator\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E3.3.1 检验电子邮件地址 \u003Cbr\u002F\u003E3.3.2 检验用户名和口令 \u003Cbr\u002F\u003E3.3.3 检验电话号码 \u003Cbr\u002F\u003E3.3.4 检验网址 \u003Cbr\u002F\u003E3.3.5 检验条目长度 \u003Cbr\u002F\u003E3.3.6 检验邮政编码 \u003Cbr\u002F\u003E3.4 比较值:CompareValidator\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E3.4.1 比较\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E与另\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E的值 \u003Cbr\u002F\u003E3.4.2 比较\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E的值与固定值 \u003Cbr\u002F\u003E3.4.3 执行数据类型检查 \u003Cbr\u002F\u003E3.5 检查值的范围:RangeValidator\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E3.6 错误汇总:ValidationSummary\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E3.7 执行自定义的检验:CustomValidator\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E3.8 禁用检验 \u003Cbr\u002F\u003E3.9 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第4章 高级\u003Cem\u003E控件\u003C\u002Fem\u003E编程 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E4.1 使用视图状态 \u003Cbr\u002F\u003E4.1.1 禁用视图状态 \u003Cbr\u002F\u003E4.1.2 将值添加到视图状态 \u003Cbr\u002F\u003E4.2 显示和隐藏内容 \u003Cbr\u002F\u003E4.2.1 使用Visible和Enabled属性 \u003Cbr\u002F\u003E4.2.2 使用Panel\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E4.2.3 模拟多页面表单 \u003Cbr\u002F\u003E4.2.4 通过程序添加\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E4.2.5 将\u003Cem\u003E控件\u003C\u002Fem\u003E添加到页面 \u003Cbr\u002F\u003E4.2.6 PlaceHolder\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E4.2.7 动态产生表单 \u003Cbr\u002F\u003E4.2.8 动态产生列表条目 \u003Cbr\u002F\u003E4.3 使用复杂\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E4.3.1 使用Calendar\u003Cem\u003E控件\u003C\u002Fem\u003E显示交互式的日历 \u003Cbr\u002F\u003E4.3.2 使用AdRotator\u003Cem\u003E控件\u003C\u002Fem\u003E显示广告条 \u003Cbr\u002F\u003E4.3.3 使用HTMLInputFile\u003Cem\u003E控件\u003C\u002Fem\u003E接受文件上传 \u003Cbr\u002F\u003E4.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第二部分 高级ASP.NET页面开发\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第5章 用用户\u003Cem\u003E控件\u003C\u002Fem\u003E创建自定义\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E5.1 用用户\u003Cem\u003E控件\u003C\u002Fem\u003E包含标准内容 \u003Cbr\u002F\u003E5.2 显露用户\u003Cem\u003E控件\u003C\u002Fem\u003E中的属性和方法 \u003Cbr\u002F\u003E5.3 显露用户\u003Cem\u003E控件\u003C\u002Fem\u003E中的Web\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E5.4 显露用户\u003Cem\u003E控件\u003C\u002Fem\u003E中的事件 \u003Cbr\u002F\u003E5.5 通过程序装载用户\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E5.6 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第6章 将代码与表示分离 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E6.1 创建业务组件 \u003Cbr\u002F\u003E6.2 创建多层Web应用程序 \u003Cbr\u002F\u003E6.3 使用code-behind \u003Cbr\u002F\u003E6.3.1 code-behind是如何工作的 \u003Cbr\u002F\u003E6.3.2 编译code-behind文件 \u003Cbr\u002F\u003E6.3.3 从\u003Cem\u003E一个\u003C\u002Fem\u003Ecode-behind文件派生多个页面 \u003Cbr\u002F\u003E6.3.4 编译完整的ASP.NET页面 \u003Cbr\u002F\u003E6.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第7章 用可移动\u003Cem\u003E控件\u003C\u002Fem\u003E为可移动设备服务 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E7.1 使用可移动设备软件模拟器 \u003Cbr\u002F\u003E7.2 无线应用协议简介 \u003Cbr\u002F\u003E7.3 建立WML页面 \u003Cbr\u002F\u003E7.3.1 配置IIS \u003Cbr\u002F\u003E7.3.2 WML和XML \u003Cbr\u002F\u003E7.3.3 创建卡片集 \u003Cbr\u002F\u003E7.3.4 用WML链接文件 \u003Cbr\u002F\u003E7.4 使用ASP.NET可移动\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E7.4.1 创建可移动表单 \u003Cbr\u002F\u003E7.4.2 动态激活可移动表单 \u003Cbr\u002F\u003E7.4.3 显示文本 \u003Cbr\u002F\u003E7.4.4 显示列表 \u003Cbr\u002F\u003E7.4.5 创建文本框 \u003Cbr\u002F\u003E7.4.6 检验用户输入 \u003Cbr\u002F\u003E7.4.7 显示图像 \u003Cbr\u002F\u003E7.4.8 进行电话呼叫 \u003Cbr\u002F\u003E7.4.9 用可移动\u003Cem\u003E控件\u003C\u002Fem\u003E显示广告 \u003Cbr\u002F\u003E7.4.10 使用可移动\u003Cem\u003E控件\u003C\u002Fem\u003E显示日历 \u003Cbr\u002F\u003E7.5 创建跨设备兼容的可移动页面 \u003Cbr\u002F\u003E7.5.1 探测设备功能 \u003Cbr\u002F\u003E7.5.2 使用DeviceSpecific选择设备 \u003Cbr\u002F\u003E7.5.3 使用表单模板集 \u003Cbr\u002F\u003E7.6 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第8章 使用第三方\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E8.1 使用Microsoft Internet Explorer WebControls \u003Cbr\u002F\u003E8.1.1 使用TreeView\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.1.2 使用Toolbar\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.1.3 使用\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.2 使用Superexpert\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.2.1 使用Content Rotator\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.2.2 使用SuperDataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.2.3 使用DataForm\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E8.3 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第三部分 使用ADO.NET\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第9章 ADO.NET简介 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E9.1 ADO.NET概述 \u003Cbr\u002F\u003E9.2 执行常见的数据库任务 \u003Cbr\u002F\u003E9.2.1 打开数据库链接 \u003Cbr\u002F\u003E9.2.2 从数据库表获取记录 \u003Cbr\u002F\u003E9.2.3 在查询中使用参数 \u003Cbr\u002F\u003E9.2.4 向数据库添加记录 \u003Cbr\u002F\u003E9.2.5 更新数据库记录 \u003Cbr\u002F\u003E9.2.6 删除数据库记录 \u003Cbr\u002F\u003E9.3 改进数据库性能 \u003Cbr\u002F\u003E9.3.1 使用SQL存储过程 \u003Cbr\u002F\u003E9.3.2 获取返回值和输出参数 \u003Cbr\u002F\u003E9.3.3 执行复杂的存储过程 \u003Cbr\u002F\u003E9.3.4 用链接缓冲改进性能 \u003Cbr\u002F\u003E9.4 高级的数据库主题 \u003Cbr\u002F\u003E9.4.1 在事务中执行数据库命令 \u003Cbr\u002F\u003E9.4.2 指定命令行为 \u003Cbr\u002F\u003E9.4.3 获取表模式信息 \u003Cbr\u002F\u003E9.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第10章 将数据绑定到Web\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E10.1 数据绑定概述 \u003Cbr\u002F\u003E10.2 将服务器\u003Cem\u003E控件\u003C\u002Fem\u003E绑定到数据源 \u003Cbr\u002F\u003E10.2.1 绑定到Repeater\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.2.2 使用模板 \u003Cbr\u002F\u003E10.2.3 视图状态和Repeater\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.2.4 绑定到DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.2.5 绑定到RadioButtonList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.2.6 绑定到CheckBoxList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.2.7 绑定到ListBox\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.2.8 绑定到其他\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E10.3 创建主\u002F明细表单 \u003Cbr\u002F\u003E10.3.1 创建单页面的主\u002F明细表单 \u003Cbr\u002F\u003E10.3.2 创建多页面的主\u002F明细表单 \u003Cbr\u002F\u003E10.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第11章 使用DataList和DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E11.1 DataList和DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E概述 \u003Cbr\u002F\u003E11.1.1 理解事件冒泡机制 \u003Cbr\u002F\u003E11.1.2 使用模板 \u003Cbr\u002F\u003E11.1.3 使用DataKeys集合 \u003Cbr\u002F\u003E11.2 使用DataList\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E11.2.1 在DataList中显示数据 \u003Cbr\u002F\u003E11.2.2 对DataList使用模板 \u003Cbr\u002F\u003E11.2.3 对DataList使用样式 \u003Cbr\u002F\u003E11.2.4 在DataList中创建多个列 \u003Cbr\u002F\u003E11.2.5 捕获DataList\u003Cem\u003E控件\u003C\u002Fem\u003E中引发的事件 \u003Cbr\u002F\u003E11.2.6 选择DataList中的条目 \u003Cbr\u002F\u003E11.2.7 通过DataList\u003Cem\u003E控件\u003C\u002Fem\u003E使用DataKeys集合 \u003Cbr\u002F\u003E11.2.8 用DataList\u003Cem\u003E控件\u003C\u002Fem\u003E创建主\u002F明细表单 \u003Cbr\u002F\u003E11.2.9 编辑DataList\u003Cem\u003E控件\u003C\u002Fem\u003E中的条目 \u003Cbr\u002F\u003E11.3 使用DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E11.3.1 在DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E中创建列 \u003Cbr\u002F\u003E11.3.2 对DataGrid使用样式 \u003Cbr\u002F\u003E11.3.3 对DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E中的列进行排序 \u003Cbr\u002F\u003E11.3.4 对DataGrid中的记录进行分页 \u003Cbr\u002F\u003E11.3.5 选择DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E中的行 \u003Cbr\u002F\u003E11.3.6 编辑DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E中的条目 \u003Cbr\u002F\u003E11.3.7 使用模板编辑DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E中的条目 \u003Cbr\u002F\u003E11.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第12章 操作DataSet \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E12.1 理解DataSet \u003Cbr\u002F\u003E12.1.1 DataSet的元素 \u003Cbr\u002F\u003E12.1.2 向DataSet添加DataTable \u003Cbr\u002F\u003E12.1.3 将\u003Cem\u003E控件\u003C\u002Fem\u003E绑定到DataSet \u003Cbr\u002F\u003E12.2 理解DataTable \u003Cbr\u002F\u003E12.2.1 通过程序创建DataTable \u003Cbr\u002F\u003E12.2.2 设置DataTable属性 \u003Cbr\u002F\u003E12.2.3 在DataTable中设置列属性 \u003Cbr\u002F\u003E12.2.4 在DataTable中计算列值 \u003Cbr\u002F\u003E12.2.5 在DataTable之间定义关系 \u003Cbr\u002F\u003E12.2.6 获取DataTable模式信息 \u003Cbr\u002F\u003E12.2.7 在DataTable中更新记录 \u003Cbr\u002F\u003E12.3 理解DataView \u003Cbr\u002F\u003E12.3.1 在DataView中对行进行过滤 \u003Cbr\u002F\u003E12.3.2 在DataView中对行进行排序 \u003Cbr\u002F\u003E12.3.3 在DataView中搜索行 \u003Cbr\u002F\u003E12.4 通过ASP.NET页面使用DataSet \u003Cbr\u002F\u003E12.4.1 缓存DataSet \u003Cbr\u002F\u003E12.4.2 显示缓存的数据 \u003Cbr\u002F\u003E12.4.3 过滤缓存的数据 \u003Cbr\u002F\u003E12.4.4 在缓存的DataSet中搜索行 \u003Cbr\u002F\u003E12.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第13章 操作XML \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E13.1 XML类概述 \u003Cbr\u002F\u003E13.2 通过DataSet使用XML \u003Cbr\u002F\u003E13.2.1 将XML文档读入DataSet \u003Cbr\u002F\u003E13.2.2 通过ReadXml使用模式 \u003Cbr\u002F\u003E13.2.3 从DataSet写XML文档 \u003Cbr\u002F\u003E13.2.4 通过DataSet使用XMLData Documents \u003Cbr\u002F\u003E13.3 使用样式单转换XML \u003Cbr\u002F\u003E13.4 使用ASP.NET Xml\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E13.5 使用XslTransform类 \u003Cbr\u002F\u003E13.6 使用强类型的DataSet \u003Cbr\u002F\u003E13.7 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第14章 使用ADO.NET创建搜索页面 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E14.1 使用SQL Server全文搜索 \u003Cbr\u002F\u003E14.1.1 配置Full-Text Search Service \u003Cbr\u002F\u003E14.1.2 对数据库数据执行任意文本查询 \u003Cbr\u002F\u003E14.1.3 对数据库数据执行布尔查询 \u003Cbr\u002F\u003E14.1.4 上传二进制文档并且进行索引 \u003Cbr\u002F\u003E14.2 使用Microsoft Indexing Service \u003Cbr\u002F\u003E14.2.1 配置Microsoft Indexing Service \u003Cbr\u002F\u003E14.2.2 将SQL Server配置为使用Microsoft Indexing Service \u003Cbr\u002F\u003E14.2.3 获取文档属性 \u003Cbr\u002F\u003E14.2.4 对文件系统数据执行任意文本查询 \u003Cbr\u002F\u003E14.2.5 对文件系统数据执行布尔查询 \u003Cbr\u002F\u003E14.2.6 对文档属性执行查询 \u003Cbr\u002F\u003E14.3 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第四部分 使用ASP.NET应用程序\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第15章 创建ASP.NET应用程序 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E15.1 ASP.NET应用程序概述 \u003Cbr\u002F\u003E15.2 使用应用程序状态 \u003Cbr\u002F\u003E15.2.1 理解应用程序状态和同步 \u003Cbr\u002F\u003E15.2.2 使用Global.asax文件 \u003Cbr\u002F\u003E15.2.3 理解Context和使用Global.asax文件 \u003Cbr\u002F\u003E15.2.4 处理应用程序Start和Init事件 \u003Cbr\u002F\u003E15.2.5 处理Application_BeginRequest事件 \u003Cbr\u002F\u003E15.3 使用Web.Config文件 \u003Cbr\u002F\u003E15.3.1 研究配置部分 \u003Cbr\u002F\u003E15.3.2 修改配置设置 \u003Cbr\u002F\u003E15.3.3 设置配置位置 \u003Cbr\u002F\u003E15.3.4 锁定配置设置 \u003Cbr\u002F\u003E15.3.5 添加自定义的配置信息 \u003Cbr\u002F\u003E15.4 使用HTTP处理器和模块 \u003Cbr\u002F\u003E15.4.1 使用HTTP处理器 \u003Cbr\u002F\u003E15.4.2 使用HTTP模块 \u003Cbr\u002F\u003E15.4.3 创建WhosOn应用程序 \u003Cbr\u002F\u003E15.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第16章 跟踪用户会话 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E16.1 使用浏览器cookie \u003Cbr\u002F\u003E16.1.1 cookie如何工作 \u003Cbr\u002F\u003E16.1.2 创建和读取会话cookie \u003Cbr\u002F\u003E16.1.3 创建和读取持久性cookie \u003Cbr\u002F\u003E16.1.4 设置cookie属性 \u003Cbr\u002F\u003E16.1.5 cookie的限制 \u003Cbr\u002F\u003E16.2 使用会话状态 \u003Cbr\u002F\u003E16.2.1 向会话状态中添加条目 \u003Cbr\u002F\u003E16.2.2 从会话状态中删除条目 \u003Cbr\u002F\u003E16.2.3 启动用户会话 \u003Cbr\u002F\u003E16.2.4 结束用户会话 \u003Cbr\u002F\u003E16.2.5 处理会话事件 \u003Cbr\u002F\u003E16.2.6 在进程内存储会话状态 \u003Cbr\u002F\u003E16.2.7 在Windows服务中存储会话状态 \u003Cbr\u002F\u003E16.2.8 在数据库表中存储会话状态 \u003Cbr\u002F\u003E16.2.9 禁止会话状态 \u003Cbr\u002F\u003E16.3 使用无cookie会话 \u003Cbr\u002F\u003E16.3.1 启用无cookie会话 \u003Cbr\u002F\u003E16.3.2 无cookie会话的限制 \u003Cbr\u002F\u003E16.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第17章 缓存ASP.NET应用程序 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E17.1 使用页面输出缓存 \u003Cbr\u002F\u003E17.1.1 按参数改变缓存内容 \u003Cbr\u002F\u003E17.1.2 按头改变缓存内容 \u003Cbr\u002F\u003E17.1.3 按自定义的字符串改变缓存内容 \u003Cbr\u002F\u003E17.1.4 设置缓存位置 \u003Cbr\u002F\u003E17.1.5 使用HttpCachePolicy类 \u003Cbr\u002F\u003E17.2 使用页面分段缓存 \u003Cbr\u002F\u003E17.2.1 按参数改变页面分段缓存 \u003Cbr\u002F\u003E17.2.2 页面分段缓存的限制 \u003Cbr\u002F\u003E17.3 使用页面数据缓存 \u003Cbr\u002F\u003E17.3.1 在缓存中添加条目 \u003Cbr\u002F\u003E17.3.2 添加缓存文件依赖性 \u003Cbr\u002F\u003E17.3.3 添加缓存触发器依赖性 \u003Cbr\u002F\u003E17.3.4 添加缓存键依赖性 \u003Cbr\u002F\u003E17.3.5 建立绝对的过期策略 \u003Cbr\u002F\u003E17.3.6 建立变化的过期策略 \u003Cbr\u002F\u003E17.3.7 设置缓存条目优先级 \u003Cbr\u002F\u003E17.3.8 创建缓存回调方法 \u003Cbr\u002F\u003E17.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第18章 应用程序跟踪和错误处理 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E18.1 响应错误 \u003Cbr\u002F\u003E18.1.1 查看错误信息 \u003Cbr\u002F\u003E18.1.2 页面级错误处理 \u003Cbr\u002F\u003E18.1.3 应用程序级错误处理 \u003Cbr\u002F\u003E18.2 跟踪和监视应用程序 \u003Cbr\u002F\u003E18.2.1 跟踪页面的执行 \u003Cbr\u002F\u003E18.2.2 监视ASP.NET进程 \u003Cbr\u002F\u003E18.2.3 获取进程信息 \u003Cbr\u002F\u003E18.3 记录事件 \u003Cbr\u002F\u003E18.4 使用调试器 \u003Cbr\u002F\u003E18.4.1 连接调试器 \u003Cbr\u002F\u003E18.4.2 建立断点 \u003Cbr\u002F\u003E18.4.3 建立观察 \u003Cbr\u002F\u003E18.4.4 逐步执行ASP.NET页面 \u003Cbr\u002F\u003E18.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第五部分 保护ASP.NET应用程序\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第19章 使用基于表单的身份验证 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E19.1 使用表单身份验证 \u003Cbr\u002F\u003E19.1.1 启用表单身份验证 \u003Cbr\u002F\u003E19.1.2 配置表单身份验证 \u003Cbr\u002F\u003E19.1.3 配置表单授权 \u003Cbr\u002F\u003E19.1.4 获取用户信息 \u003Cbr\u002F\u003E19.1.5 创建注销页面 \u003Cbr\u002F\u003E19.1.6 用Web.Config文件进行用户身份验证 \u003Cbr\u002F\u003E19.1.7 用XML文件进行用户身份验证 \u003Cbr\u002F\u003E19.1.8 用数据库表进行用户身份验证 \u003Cbr\u002F\u003E19.1.9 实现基于角色的身份验证 \u003Cbr\u002F\u003E19.1.10 创建自定义的身份验证票据 \u003Cbr\u002F\u003E19.1.11 表单身份验证和Web阵 \u003Cbr\u002F\u003E19.2 使用Passport身份验证 \u003Cbr\u002F\u003E19.2.1 启用Passport身份验证 \u003Cbr\u002F\u003E19.2.2 允许用户登录和注销 \u003Cbr\u002F\u003E19.2.3 获取用户信息 \u003Cbr\u002F\u003E19.3 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第20章 基于Windows的身份验证 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E20.1 使用基于Windows的身份验证 \u003Cbr\u002F\u003E20.1.1 配置Internet Information Server安全 \u003Cbr\u002F\u003E20.1.2 配置Microsoft Windows安全 \u003Cbr\u002F\u003E20.1.3 配置Windows身份验证 \u003Cbr\u002F\u003E20.1.4 配置Windows授权 \u003Cbr\u002F\u003E20.1.5 配置自定义角色 \u003Cbr\u002F\u003E20.1.6 获取用户信息 \u003Cbr\u002F\u003E20.2 模拟用户账号 \u003Cbr\u002F\u003E20.3 设置安全策略 \u003Cbr\u002F\u003E20.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第21章 加密网上发送的数据 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E21.1 使用Secure Sockets Layer \u003Cbr\u002F\u003E21.1.1 加密 \u003Cbr\u002F\u003E21.1.2 身份验证 \u003Cbr\u002F\u003E21.1.3 数据完整性 \u003Cbr\u002F\u003E21.1.4 SSL有多安全 \u003Cbr\u002F\u003E21.2 将服务器配置为使用SSL \u003Cbr\u002F\u003E21.2.1 产生证书请求文件 \u003Cbr\u002F\u003E21.2.2 申请服务器证书 \u003Cbr\u002F\u003E21.2.3 安装服务器证书 \u003Cbr\u002F\u003E21.3 在ASP.NET页面中使用SSL \u003Cbr\u002F\u003E21.4 使用.NET加密类 \u003Cbr\u002F\u003E21.4.1 使用散列算法 \u003Cbr\u002F\u003E21.4.2 使用对称加密算法 \u003Cbr\u002F\u003E21.4.3 使用不对称加密 \u003Cbr\u002F\u003E21.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第六部分 建立ASP.NET Web服务\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第22章 创建XML Web服务 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E22.1 XML Web服务概述 \u003Cbr\u002F\u003E22.1.1 XML Web服务促进通信 \u003Cbr\u002F\u003E22.1.2 XML Web服务允许聚集 \u003Cbr\u002F\u003E22.2 创建简单的XML Web服务 \u003Cbr\u002F\u003E22.2.1 设置WebMethod属性 \u003Cbr\u002F\u003E22.2.2 设置WebService属性 \u003Cbr\u002F\u003E22.2.3 预编译XML Web服务 \u003Cbr\u002F\u003E22.3 从浏览器测试XML Web服务 \u003Cbr\u002F\u003E22.3.1 用HTTP-Get调用XML Web服务 \u003Cbr\u002F\u003E22.3.2 用HTTP-Post调用XML Web服务 \u003Cbr\u002F\u003E22.3.3 用SOAP调用XML Web服务 \u003Cbr\u002F\u003E22.4 通过代理类访问XML Web服务 \u003Cbr\u002F\u003E22.4.1 产生XML Web服务代理类 \u003Cbr\u002F\u003E22.4.2 使用XML Web服务代理类 \u003Cbr\u002F\u003E22.4.3 使用Web服务描述语言工具 \u003Cbr\u002F\u003E22.4.4 设置代理类属性 \u003Cbr\u002F\u003E22.5 在XML Web服务中传送复杂数据 \u003Cbr\u002F\u003E22.5.1 XML Web服务和数组 \u003Cbr\u002F\u003E22.5.2 XML Web服务和类 \u003Cbr\u002F\u003E22.5.3 Web服务和DataSet \u003Cbr\u002F\u003E22.5.4 Web服务和二进制文件 \u003Cbr\u002F\u003E22.6 XML Web服务和网站的交互 \u003Cbr\u002F\u003E22.6.1 XML Web服务和应用程序状态 \u003Cbr\u002F\u003E22.6.2 XML Web服务和会话状态 \u003Cbr\u002F\u003E22.7 小结\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第23章 高级的XML Web服务 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E23.1 使用WebService行为 \u003Cbr\u002F\u003E23.1.1 WebService行为的限制 \u003Cbr\u002F\u003E23.1.2 用WebService行为创建简单的页面 \u003Cbr\u002F\u003E23.1.3 使用WebService行为回调函数 \u003Cbr\u002F\u003E23.1.4 缓存WebService行为中的错误 \u003Cbr\u002F\u003E23.1.5 使用WebService行为执行部分更新 \u003Cbr\u002F\u003E23.1.6 使用WebService行为获取数据库数据 \u003Cbr\u002F\u003E23.2 保护XML Web服务 \u003Cbr\u002F\u003E23.2.1 安全的XML Web服务 \u003Cbr\u002F\u003E23.2.2 创建数据库表 \u003Cbr\u002F\u003E23.2.3 创建Login( )方法 \u003Cbr\u002F\u003E23.2.4 获取自定义的SOAP头 \u003Cbr\u002F\u003E23.2.5 验证会话键 \u003Cbr\u002F\u003E23.2.6 缓存会话键 \u003Cbr\u002F\u003E23.2.7 建立安全的XML Web服务 \u003Cbr\u002F\u003E23.2.8 访问安全的Web服务 \u003Cbr\u002F\u003E23.3 使用HTML模式匹配 \u003Cbr\u002F\u003E23.3.1 创建WSDL文档 \u003Cbr\u002F\u003E23.3.2 指定正则表达式模式 \u003Cbr\u002F\u003E23.3.3 创建简单的HTML模式匹配服务 \u003Cbr\u002F\u003E23.3.4 在HTML模式匹配中使用输入参数 \u003Cbr\u002F\u003E23.3.5 建立\u003Cem\u003E一个\u003C\u002Fem\u003ESix Degrees Web服务 \u003Cbr\u002F\u003E23.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第七部分 利用.NET框架\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第24章 操作集合和字符串 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E24.1 使用集合 \u003Cbr\u002F\u003E24.1.1 使用ArrayList集合 \u003Cbr\u002F\u003E24.1.2 使用HashTable集合 \u003Cbr\u002F\u003E24.1.3 使用SortedList集合 \u003Cbr\u002F\u003E24.2 使用字符串 \u003Cbr\u002F\u003E24.2.1 对字符串进行格式化 \u003Cbr\u002F\u003E24.2.2 使用String方法和属性 \u003Cbr\u002F\u003E24.2.3 使用StringBuilder类 \u003Cbr\u002F\u003E24.3 使用正则表达式 \u003Cbr\u002F\u003E24.3.1 使用正则表达式类 \u003Cbr\u002F\u003E24.3.2 研究正则表达式的元素 \u003Cbr\u002F\u003E24.3.3 匹配单一字符 \u003Cbr\u002F\u003E24.3.4 匹配特殊字符 \u003Cbr\u002F\u003E24.3.5 匹配字符的替代序列 \u003Cbr\u002F\u003E24.3.6 使用数量词进行匹配 \u003Cbr\u002F\u003E24.3.7 正则表达式的超范围\u003Cem\u003E问题\u003C\u002Fem\u003E \u003Cbr\u002F\u003E24.3.8 捕获和反向引用 \u003Cbr\u002F\u003E24.3.9 使用替换模式 \u003Cbr\u002F\u003E24.3.10 设置正则表达式选项 \u003Cbr\u002F\u003E24.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第25章 操作文件系统 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E25.1 使用文件和目录 \u003Cbr\u002F\u003E25.1.1 创建和读取文本文件 \u003Cbr\u002F\u003E25.1.2 创建和读取二进制文件 \u003Cbr\u002F\u003E25.1.3 显示目录的内容 \u003Cbr\u002F\u003E25.1.4 获取路径信息 \u003Cbr\u002F\u003E25.2 使用串行化 \u003Cbr\u002F\u003E25.2.1 使用二进制串行化 \u003Cbr\u002F\u003E25.2.2 使用XML串行化 \u003Cbr\u002F\u003E25.3 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第26章 发送电子邮件和访问网络 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E26.1 从ASP.NET页面发送电子邮件 \u003Cbr\u002F\u003E26.1.1 Microsoft SMTP Service \u003Cbr\u002F\u003E26.1.2 发送简单的电子邮件 \u003Cbr\u002F\u003E26.1.3 使用MailMessage类 \u003Cbr\u002F\u003E26.1.4 向电子邮件消息添加附件 \u003Cbr\u002F\u003E26.1.5 发送HTML电子邮件 \u003Cbr\u002F\u003E26.2 使用Message Queuing \u003Cbr\u002F\u003E26.2.1 配置Microsoft Message Queuing \u003Cbr\u002F\u003E26.2.2 使用消息队列 \u003Cbr\u002F\u003E26.2.3 向队列发送消息 \u003Cbr\u002F\u003E26.2.4 从队列获取消息 \u003Cbr\u002F\u003E26.2.5 显示消息体 \u003Cbr\u002F\u003E26.2.6 发送和接收复杂的消息 \u003Cbr\u002F\u003E26.3 使用HTTP协议访问其他网站 \u003Cbr\u002F\u003E26.3.1 使用WebClient类 \u003Cbr\u002F\u003E26.3.2 使用HttpWebRequest类 \u003Cbr\u002F\u003E26.3.3 解析域名 \u003Cbr\u002F\u003E26.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第27章 用GDI+动态创建图形 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E27.1 建立简单的图像 \u003Cbr\u002F\u003E27.2 使用GDI+绘制对象 \u003Cbr\u002F\u003E27.2.1 创建位图 \u003Cbr\u002F\u003E27.2.2 使用Graphics对象 \u003Cbr\u002F\u003E27.2.3 设置图形质量 \u003Cbr\u002F\u003E27.2.4 使用颜色 \u003Cbr\u002F\u003E27.2.5 使用画刷 \u003Cbr\u002F\u003E27.2.6 使用画笔 \u003Cbr\u002F\u003E27.2.7 绘制矩形 \u003Cbr\u002F\u003E27.2.8 绘制直线 \u003Cbr\u002F\u003E27.2.9 绘制椭圆 \u003Cbr\u002F\u003E27.2.10 绘制曲线 \u003Cbr\u002F\u003E27.3 绘制文本字符串 \u003Cbr\u002F\u003E27.4 建立GDI+应用程序 \u003Cbr\u002F\u003E27.4.1 创建ASP.NET绘图应用程序 \u003Cbr\u002F\u003E27.4.2 创建简单的图表应用程序 \u003Cbr\u002F\u003E27.5 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第八部分 建立自定义的ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第28章 开发自定义的\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E28.1 创建简单的\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E28.2 使用HtmlTextWriter \u003Cbr\u002F\u003E28.3 向\u003Cem\u003E控件\u003C\u002Fem\u003E添加属性和方法 \u003Cbr\u002F\u003E28.3.1 使用属性访问函数 \u003Cbr\u002F\u003E28.3.2 使用\u003Cem\u003E控件\u003C\u002Fem\u003E方法 \u003Cbr\u002F\u003E28.4 解析内部内容 \u003Cbr\u002F\u003E28.5 向\u003Cem\u003E控件\u003C\u002Fem\u003E添加子\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E28.6 自定义\u003Cem\u003E控件\u003C\u002Fem\u003E和事件 \u003Cbr\u002F\u003E28.7 参与postback \u003Cbr\u002F\u003E28.8 创建组合\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E28.9 派生现有的\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E28.10 访问当前上下文 \u003Cbr\u002F\u003E28.11 调试\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E28.12 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第29章 高级\u003Cem\u003E控件\u003C\u002Fem\u003E开发 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E29.1 向\u003Cem\u003E控件\u003C\u002Fem\u003E添加模板 \u003Cbr\u002F\u003E29.1.1 创建\u003Cem\u003E一个\u003C\u002Fem\u003E模板的多个实例 \u003Cbr\u002F\u003E29.1.2 向\u003Cem\u003E一个\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E添加多个模板 \u003Cbr\u002F\u003E29.2 创建DataBound\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E29.2.1 实现不同的数据源 \u003Cbr\u002F\u003E29.2.2 实现简单的DataBound\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E29.2.3 使用DataBound\u003Cem\u003E控件\u003C\u002Fem\u003E和模板 \u003Cbr\u002F\u003E29.2.4 使用DataBound\u003Cem\u003E控件\u003C\u002Fem\u003E和状态 \u003Cbr\u002F\u003E29.2.5 将自定义\u003Cem\u003E控件\u003C\u002Fem\u003E绑定到DataSet \u003Cbr\u002F\u003E29.3 使用自定义\u003Cem\u003E控件\u003C\u002Fem\u003E和Web服务 \u003Cbr\u002F\u003E29.3.1 创建特色产品Web服务 \u003Cbr\u002F\u003E29.3.2 创建特色产品自定义\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E29.3.3 显示特色产品\u003Cem\u003E控件\u003C\u002Fem\u003E \u003Cbr\u002F\u003E29.4 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第九部分 ASP.NET应用程序示例\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第30章 创建职业介绍网站 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E30.1 安装职业介绍网站 \u003Cbr\u002F\u003E30.2 创建主页 \u003Cbr\u002F\u003E30.3 对用户进行身份验证 \u003Cbr\u002F\u003E30.4 创建虚拟URL \u003Cbr\u002F\u003E30.5 列出和更新职位 \u003Cbr\u002F\u003E30.6 创建职业介绍XML Web服务 \u003Cbr\u002F\u003E30.7 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第31章 创建网上商店 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E31.1 ASP.NET Unleashed示例商店概述 \u003Cbr\u002F\u003E31.2 安装ASP.NET Unleashed示例商店 \u003Cbr\u002F\u003E31.3 建立导航系统 \u003Cbr\u002F\u003E31.4 缓存产品数据 \u003Cbr\u002F\u003E31.5 建立购物车 \u003Cbr\u002F\u003E31.6 动态装载产品模板 \u003Cbr\u002F\u003E31.6.1 使用LoadControl方法 \u003Cbr\u002F\u003E31.6.2 code-behind产品模板 \u003Cbr\u002F\u003E31.7 小结 \u003Cbr\u002F\u003E\u003Cbr\u002F\u003E第十部分 附录\u003Cbr\u002F\u003E\u003Cbr\u002F\u003E附录A 从ASP迁移到ASP.NET \u003Cbr\u002F\u003E附录B HTML\u003Cem\u003E控件\u003C\u002Fem\u003E参考 \u003Cbr\u002F\u003E附录C Web\u003Cem\u003E控件\u003C\u002Fem\u003E参考","createTime":"2007-04-28 09:55:38","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-172995-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-172995-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwy600716\u002F172995\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-172995-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwy600716\u002F172995\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-172995-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657","title":"ExtAspNet v2.2.1 (2009-4-1) 值得一看","desc":"ExtAspNet v2.2.1\n\t\nExtAspNet是一组专业的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E库,拥有原生的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注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。\n\n示例: http:\u002F\u002Fextasp.net\u002F\n开源: http:\u002F\u002Fextaspnet.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+为\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首页最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成Extjs最新版本v3.1.1。\n\t\t-增加\u003Cem\u003E一个\u003C\u002Fem\u003E新的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-使得Asp.net的\u003Cem\u003E控件\u003C\u002Fem\u003EImageButton具有和Asp.net的Button\u003Cem\u003E控件\u003C\u002Fem\u003E类似的行为(Ajax提交)(feedback:261629698)。\n\t+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加GetAddTabReference和GetRemoveTabReference两个函数,用来向\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E动态增加删除Tab。\n\t\t-增加示例\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002F\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E_addtab.aspx。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E更新。\n\t\t-关闭按钮默认直接关闭,不会弹出确认对话框。\n\t\t-GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button\u003Cem\u003E控件\u003C\u002Fem\u003E的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居中,而不是黄金分割位置。\n\t+Button, Window等\u003Cem\u003E控件\u003C\u002Fem\u003E弹出位置属性的变化。\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的最后\u003Cem\u003E一个\u003C\u002Fem\u003E参数target变为枚举类型。\n\t\t-Alert.GetShowReference中的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\u003Cem\u003E问题\u003C\u002Fem\u003E。\n\t-修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button\u003Cem\u003E控件\u003C\u002Fem\u003E将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第\u003Cem\u003E一个\u003C\u002Fem\u003E按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window\u003Cem\u003E控件\u003C\u002Fem\u003E的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。\n\t-增加\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E中Tab\u003Cem\u003E控件\u003C\u002Fem\u003E可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument中Icon属性映射错误(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\u003EJS\u003Cem\u003E问题\u003C\u002Fem\u003E(feedback:lqm4108)。\n\t-修正Alert消息中引号未编码导致的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.aspx),如何通过简单的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-增加中国的省市县三级联动示例(data\u002Fshengshixian.aspx)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的Tab在切换过程中会重复加载的\u003Cem\u003E问题\u003C\u002Fem\u003E,这是\u003Cem\u003E一个\u003C\u002Fem\u003E在v2.1.6引入的\u003Cem\u003E问题\u003C\u002Fem\u003E(feedback:eroach)。\n\t-修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(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.aspx)。\n\t-修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器\u003Cem\u003E控件\u003C\u002Fem\u003E(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的实现,避免选中某项后的闪烁。\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.aspx),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet中的\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-为所有\u003Cem\u003E控件\u003C\u002Fem\u003E增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.aspx)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#处理函数来响应键盘事件。\n\t-为Tree增加AutoLeafIdentification属性。\n\t\t-增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。\n\t\n\t\n\n+2009-11-17 v2.1.4\n\t-修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。\n\t-部分ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E的设计时支持(会在后续版本中逐步完善)。\n\t-v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。\n\t-修正CheckBox\u003Cem\u003E控件\u003C\u002Fem\u003E的CheckedChanged事件会被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等\u003Cem\u003E控件\u003C\u002Fem\u003E增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:form\u002Fform_validate.aspx\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的\u003Cem\u003E控件\u003C\u002Fem\u003E属性列表(\u002Fajax.aspx)。\n\t\t-ExtAspNet支持原生的AJAX,也就是说\u003Cem\u003E控件\u003C\u002Fem\u003E的属性改变在AJAX过程中会反映到页面中,但并不是所有的\u003Cem\u003E控件\u003C\u002Fem\u003E属性都支持AJAX改变。\n\t-加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保Asp.net的按钮\u003Cem\u003E控件\u003C\u002Fem\u003E仍然具有AJAX的特性。\n\t-更新\u002Fbasic\u002Flogin.aspx示例,使用验证图片(feedback:kedee)。\n\t-为Grid增加AutoPostBack属性和RowClick事件,示例在\u002Fdata\u002Fgrid_autopostback.aspx(feedback:chenguizhu2006)。\n\t-为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。\n\t-Grid中TemplateField生成到页面中\u003Cem\u003E控件\u003C\u002Fem\u003E具有唯一ID,例如Grid1_ct5_\u003Cem\u003ELabel\u003C\u002Fem\u003E2,Grid1_ct6_\u003Cem\u003ELabel\u003C\u002Fem\u003E2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree\u003Cem\u003E控件\u003C\u002Fem\u003E增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。\n\t\t-如果Panel具有IconUrl属性,则IconUrl优先于Icon。\n\t\t-所有Icon的列表在icon.aspx。\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\u003Cem\u003E控件\u003C\u002Fem\u003E的Target=\"_parent\")。\n\t+为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-\u003Cem\u003E一个\u003C\u002Fem\u003E典型应用,在Window\u003Cem\u003E控件\u003C\u002Fem\u003E中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-ExtAspNet.Alert.Show(\"参数错误!\", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以自动回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002Fextasp.net\u002Fdata\u002Ftree_run.aspx\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选中任何一项时在父页面弹出对话框的JS代码。\n\t-修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。\n\t-添加定时器\u003Cem\u003E控件\u003C\u002Fem\u003ETimer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree\u003Cem\u003E控件\u003C\u002Fem\u003E的AJAX实现。\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中所有语言的支持。\n\t\t-ExtAspNet扩展的多语言包在js\\languages\\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其中添加自己的语言版本,并执行js\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。\n\t+在aspx页面中必须显示的声明\u003Cem\u003E控件\u003C\u002Fem\u003E的集合属性(比如\u003Cem\u003ETabs\u003C\u002Fem\u003E(\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将会影响所有的aspx页面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX中使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将会影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree\u003Cem\u003E控件\u003C\u002Fem\u003E的\u003Cem\u003E一个\u003C\u002Fem\u003EBUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpContext.Current,而不是\u003Cem\u003E一个\u003C\u002Fem\u003E全局变量。\n\t -这个BUG导致Asp.net compatibility中的示例无法完成,现在已经修正。\n\t+去除PageManager中方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。\n\t -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility中的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。\n -增加示例-如何将Grid\u003Cem\u003E控件\u003C\u002Fem\u003E导出为Excel(data\\grid_excel_run.aspx)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不会被选中(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.aspx)。\n -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。\n +去除PageLayout\u003Cem\u003E控件\u003C\u002Fem\u003E,此\u003Cem\u003E控件\u003C\u002Fem\u003E可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E)都可以通过这种方式全屏。\n\t\t-简单方便,示例可以参考 default.aspx 或者 other\\accordion_tree_run.aspx。\n \n \n\n+2009-08-14 v2.0.6\n\t-动态生成菜单实例(other\\menu_dynamic_run.aspx和other\\menu_dynamic2_run.aspx)(feedback:shguo)。\n\t-优化AJAX的内部实现,每个页面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId自动生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+ExtAspNet和Asp.net的提交按钮兼容\u003Cem\u003E问题\u003C\u002Fem\u003E(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容\u003Cem\u003E问题\u003C\u002Fem\u003E,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们做了优化,现在要使\u003Cem\u003E一个\u003C\u002Fem\u003EAsp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E了。\n\t\t-在Page_Load中设置了哪些需要在AJAX中更新的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的\u003Cem\u003E控件\u003C\u002Fem\u003E。\n\t\t-示例在aspnet\\fckeditor_run.aspx和aspnet\\aspnet_run.aspx。\n\t\t-FCKEditor和上传\u003Cem\u003E控件\u003C\u002Fem\u003E兼容。示例在aspnet\\fileupload_run.aspx。\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+和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加\u003Cem\u003E一个\u003C\u002Fem\u003EhttpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.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\u003Cem\u003E控件\u003C\u002Fem\u003E的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下测试通过。以后ExtAspNet将不会对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的\u003Cem\u003E一个\u003C\u002Fem\u003EBUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此\u003Cem\u003E问题\u003C\u002Fem\u003E)。\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; 目前只有\u003Cem\u003E一个\u003C\u002Fem\u003E缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个页面只包含\u003Cem\u003E一个\u003C\u002Fem\u003EJavaScript文件(语言文件除外)和\u003Cem\u003E一个\u003C\u002Fem\u003ECSS文件。\n\t-ExtAspNet自身的CSS会紧挨着页面\u003Ctitle\u003E标签引入,这样在\u003Chead\u003E中自定义的样式可以覆盖ExtAspNet缺省样式。\n\t+Alert对话框会遮挡所有的Window窗口。\n\t\t-使用\u003Cem\u003E一个\u003C\u002Fem\u003E变通的方法解决,因为无法改变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,则默认选中第一项。\n\t-重新绑定模拟树的下拉列表后,选中项的前面有图片的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中的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed]\n\t-页面包含FileUpload\u003Cem\u003E控件\u003C\u002Fem\u003E,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet\u002Ffileupload.aspx)[fixed]\n\t-HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed]\n\t\n\t\n\n+2009-03-03 v1.3.0\n\t-如果弹出的窗口(Ext-Window)含有ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003EFileUpload,则此弹出窗口在关闭时出现JS错误(http:\u002F\u002Fextjs.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果页面中存在ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的\u003Cem\u003E问题\u003C\u002Fem\u003E)。[fixed]\n\t-页面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed]\n\t-ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在ExtAspNet工程中使用ASP.NET标准\u003Cem\u003E控件\u003C\u002Fem\u003E的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E和ASP.NET标准\u003Cem\u003E控件\u003C\u002Fem\u003E和平共处了。[fixed]\n\t\t-如果\u003Cem\u003E一个\u003C\u002Fem\u003EASP.NET按钮\u003Cem\u003E控件\u003C\u002Fem\u003E要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet\u002Faspnet.aspx)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed]\n\t-自动测试功能会在以后版本中逐步完善。这个版本完成测试框架,采用Extjs中JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建\u003Cem\u003E一个\u003C\u002Fem\u003EWindow\u003Cem\u003E控件\u003C\u002Fem\u003E的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference\u002FGetConfirmFormModifiedCloseRefreshReference\u002FGetConfirmFormModifiedClosePostBackReference三个方法代替。\n\t\t-不会修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面添加box_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的ASPX页面中查找RegisterPageStateChangedScript属性,并删除,否则会运行错误!\n\t\t-A页面有Ext-Window\u003Cem\u003E控件\u003C\u002Fem\u003E弹出B页面,B页面有Ext-Window\u003Cem\u003E控件\u003C\u002Fem\u003E弹出C页面,B页面的Ext-Window\u003Cem\u003E控件\u003C\u002Fem\u003E设置Target='_parent',则弹出的Ext-Window(C页面)会覆盖整个A页面,这是正确的。\n\t\t---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不会出错了。\n\t\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window\u003Cem\u003E控件\u003C\u002Fem\u003E增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。\n\t\t---Window\u003Cem\u003E控件\u003C\u002Fem\u003E的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window\u003Cem\u003E控件\u003C\u002Fem\u003E的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。\n\t\t-如果弹出窗口(Window\u003Cem\u003E控件\u003C\u002Fem\u003E)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E的IFrameName属性是自动生成的,只读属性。(因为有可能所有的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的地方,需要删除第\u003Cem\u003E一个\u003C\u002Fem\u003E参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel中内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed]\n\t-DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed]\n\t-升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏\u003Cem\u003E问题\u003C\u002Fem\u003E的修正)。[fixed]\n\t-页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added]\n\t+增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选中任何一项,回发时报错[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),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image\u003Cem\u003E控件\u003C\u002Fem\u003E增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包中增加\u003Cem\u003E一个\u003C\u002Fem\u003EWeb.config.txt,这是\u003Cem\u003E一个\u003C\u002Fem\u003E空的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+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的Tab\u003Cem\u003E控件\u003C\u002Fem\u003E的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed]\n\t\t-有这样\u003Cem\u003E一个\u003C\u002Fem\u003E效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用\u003Cem\u003E控件\u003C\u002Fem\u003E的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的\u003Cem\u003E问题\u003C\u002Fem\u003E。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-aspnet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemText\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new ExtAspNet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。\n\t\t\t-和Asp.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列表项。\n\t-处于布局内的容器\u003Cem\u003E控件\u003C\u002Fem\u003E(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,\u003Cem\u003E控件\u003C\u002Fem\u003E的高度指的是整个\u003Cem\u003E控件\u003C\u002Fem\u003E的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有\u003Cem\u003E控件\u003C\u002Fem\u003E属性增加在VS中的智能提示。[fixed]\n\t\t-需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。\n\t+\u003Cem\u003E控件\u003C\u002Fem\u003E的属性如果是枚举类型,如果此属性可以不取值,则默认为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+注意:\u003Cem\u003E一个\u003C\u002Fem\u003E属性可以拥有多个值的情况。[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)中通过js切换父页面中选中的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.aspx,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的动态添加\u003Cem\u003E控件\u003C\u002Fem\u003E,并且可以给\u003Cem\u003E控件\u003C\u002Fem\u003E添加服务器端事件(示例在form\u002Fform_dynamic_run.aspx)。[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属性,这样就可以直接在前台(ASPX)中设置哪些项不可选择,以及创建模拟下拉树。\n\t\t-DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则自动将EnableSimulateTree设置为true。\n\t\n\t\n\n+2008-09-27 v1.2 beta4\n\t+EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other\u002Faccordion_run.aspx)。[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.aspx)。[fixed]\n\t\t-原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上\u003CItems\u003E标签。\n\t\t-适当增大AccordionPanel中链接的高度20px-\u003E22px,同时对链接的样式也做了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少ASPX中HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在ASPX页切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002FToolbar\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向Form中动态添加\u003Cem\u003E控件\u003C\u002Fem\u003E的BUG,现在form\u002Fform_dynamic_run.aspx示例已经能正确运行。[fixed]\n\t+大部分容器的子\u003Cem\u003E控件\u003C\u002Fem\u003E集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的\u003Cem\u003E控件\u003C\u002Fem\u003E包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimpleForm\u002FWindow等。\n\t\t-保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的\u003Cem\u003ETabs\u003C\u002Fem\u003E(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选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选中项中会存在当前不存在的行序号,导致服务器端遍历选中项时数组越界。所有使用box\u003Cem\u003E控件\u003C\u002Fem\u003E的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例中表单\u003Cem\u003E控件\u003C\u002Fem\u003E都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimpleForm\u002FButton\u002FHyperLink\u002F\u003Cem\u003ELabel\u003C\u002Fem\u003E\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在ASPX中设置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中。[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中布局可供使用。\n\t\t-其中一些\u003Cem\u003E控件\u003C\u002Fem\u003E默认使用一种布局:SimpleForm(Form)\u002FForm(Form)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002F\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E(Card),所有布局\u003Cem\u003E控件\u003C\u002Fem\u003E默认的布局是Container。\n\t\t-经常用到的布局\u003Cem\u003E控件\u003C\u002Fem\u003E:SimpleForm\u002FForm\u002FAccordion\u002F\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果\u003Cem\u003E一个\u003C\u002Fem\u003E菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E增加Hidden属性(少数几个\u003Cem\u003E控件\u003C\u002Fem\u003E没有此属性:Menu),这样在Ajax时可以显示隐藏\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的\u003Cem\u003E控件\u003C\u002Fem\u003E渲染到客户端但是隐藏。\n\t\t-US的ExtAspNet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报中唯一没有用到ExtAspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageContext.Redirect支持普通页面转向和ExtAspNetAjax下页面转向。[fixed]\n\t+模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多\u003Cem\u003E控件\u003C\u002Fem\u003E(Grid,DropDownList,\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E)。\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\u003E控件\u003C\u002Fem\u003E(以后不会用AspnetAjax,这个\u003Cem\u003E控件\u003C\u002Fem\u003E已经完成使命)。[fixed]\n\t-不要使用Asp.net的\u003Cem\u003E控件\u003C\u002Fem\u003EHiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的\u003Cem\u003E控件\u003C\u002Fem\u003E在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList中项如果存在汉字,则会换行的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前Tab中如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个\u003Cem\u003E问题\u003C\u002Fem\u003E。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父\u003Cem\u003E控件\u003C\u002Fem\u003E(SimpleForm\u002FForm)的背景色一致。[fixed]\n\t-TwinTriggerBox的第\u003Cem\u003E一个\u003C\u002Fem\u003ETrigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config中增加配置项Form\u003Cem\u003ELabel\u003C\u002Fem\u003EWidth=\"80\"(默认为80),同时PageManager增加Form\u003Cem\u003ELabel\u003C\u002Fem\u003EWidth属性用来控制页面上所有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-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加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回发时支持\u003Cem\u003E控件\u003C\u002Fem\u003E哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供\u003Cem\u003E控件\u003C\u002Fem\u003E级别的EnableAjax属性。\n\t\t-整理支持Ajax的\u003Cem\u003E控件\u003C\u002Fem\u003E属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对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\u003Cem\u003E控件\u003C\u002Fem\u003E是否弹出的状态在回发时维持。[fixed]\n\t\t-\u003Cem\u003E控件\u003C\u002Fem\u003E设计的\u003Cem\u003E一个\u003C\u002Fem\u003E原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃Asp.NetAjax,ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E内置Ajax支持。[fixed]\n\t\t-这是\u003Cem\u003E一个\u003C\u002Fem\u003E值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击\u003Cem\u003E一个\u003C\u002Fem\u003E按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前ExtAspNetAjax的限制。\n\t\t\t-只对ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E起作用,对Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E不起作用。\n\t\t\t-对容器\u003Cem\u003E控件\u003C\u002Fem\u003E(有子\u003Cem\u003E控件\u003C\u002Fem\u003E的\u003Cem\u003E控件\u003C\u002Fem\u003E)不起作用,只对最底层的\u003Cem\u003E控件\u003C\u002Fem\u003E起作用。\n\t\t\t-对改变\u003Cem\u003E控件\u003C\u002Fem\u003E的Visible属性会有错误。\n\t\t\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t-Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选中的状态在回发后会得到保持。[fixed]\n\t-Grid选中行的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知\u003Cem\u003E问题\u003C\u002Fem\u003E:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父页面加载\u003Cem\u003E一个\u003C\u002Fem\u003E比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口中IFrame的显示速度。[fixed]\n\t\t-在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed]\n\t\t-\u003Cem\u003E一个\u003C\u002Fem\u003E典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.aspx)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\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事件中。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E延迟加载引起的BUG(非当前Tab中的ContentPanel会占据页面空间,已修正)。[fixed]\n\t-全新的ExtAspNet.Examples(基础知识\u002F表单\u003Cem\u003E控件\u003C\u002Fem\u003E\u002F数据绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe\u002Fdefault.aspx和iframe\u002Fpage3.aspx)。[fixed]\n\t\t-测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+extjs的BUG,当页面中含有iframe时,Ext.onReady会被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.extjs.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.aspx)[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.aspx\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下会有JS错误。[fixed]\n\t-增加BorderLayout\u003Cem\u003E控件\u003C\u002Fem\u003E,示例在iframe\u002Fborderlayout.aspx。[fixed]\n\t+Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed]\n\t\t-全新的样式。\n\t\t-去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。\n\t\t-GetValueReference取得的值不正确的BUG。\n\t-动态向Form中添加FormRow,并动态的向FormRow中添加表单字段,以及如何取得表单字段的值。(示例在form_dynamic.aspx)[fixed]\n\t+IFrame弹出窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是\u003Cem\u003E一个\u003C\u002Fem\u003E重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window中的IFrame被添加到页面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此\u003Cem\u003E问题\u003C\u002Fem\u003E解决。(示例在button_iframe.aspx)\n\t\n\t\n\t\n+2008-08-13 v0.4 beta4\n\t-点击关闭窗口的按钮,在IE下会有JS错误。[fixed]\n\t-Window的右上角关闭图标增加提示,优化事件响应。[fixed]\t\n\t-Window的代码重构。[fixed]\t\n\t+修正\u003Cem\u003E一个\u003C\u002Fem\u003E的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.aspx页面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.aspx页面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.aspx页面8次后iexplorer占76.492M内存。\n\t\t-IE窗口最小化时,IE会自动进行垃圾回收。\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-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E延时加载出错。[fixed]\n\t-Window的IFrameUrl处理的BUG,比如Pages_ExtAspNet目录下的页面应该为.\u002FFE_ApplyEditor.aspx或~\u002FPages_ExtAspNet\u002FFE_ApplyEditor.aspx。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则会JS错误。[fixed]\n\t-实现网报首页下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed]\n\t-优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.aspx默认会加载form.aspx页面(Window\u003Cem\u003E控件\u003C\u002Fem\u003E的BUG)。[fixed]\n\t-Window中的保存并关闭按钮和Asp.netAjax冲突。[fixed]\n\t-优化关闭Window的js脚本,减少写到页面的js大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.aspx)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E一样不可编辑。[fixed]\n\t-DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的js对象的名称简单化,这样可以减少生成的js内容,加快页面加载速度(\u003Cem\u003E一个\u003C\u002Fem\u003E典型页面的js由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口中,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。\n\t\t-一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。\n\t\t-另一种办法就是在PageManager\u003Cem\u003E控件\u003C\u002Fem\u003E中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx\u002Fsimpleform.aspx)。\n\t+PageManager\u003Cem\u003E控件\u003C\u002Fem\u003E增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed]\n\t\t-这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报中遇到这种情况)。\n\t-每个页面必须添加\u003Cem\u003E一个\u003C\u002Fem\u003EPageManager\u003Cem\u003E控件\u003C\u002Fem\u003E,否则会出错,同时去除DesignTimeStyle\u003Cem\u003E控件\u003C\u002Fem\u003E(作为PageManager的属性出现)。[fixed]\n\t-TextField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.aspx\u002Fpage2.aspx\u002Fsimpleform.aspx)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window\u003Cem\u003E控件\u003C\u002Fem\u003E增加\u003Cem\u003E一个\u003C\u002Fem\u003E属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,\u003Cem\u003E控件\u003C\u002Fem\u003E本身封装了大量的代码,简单来看现在有三个页面(default.aspx(A)\u002Fpage2.aspx(B)\u002Fsimpleform.aspx(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我会通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid中弹出窗口。(default.aspx\u002Fpage3.aspx\u002Fsimpleform.aspx)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.aspx\u002Ftriggerbox.aspx\u002Fsimpleform.aspx)\t\n\t\t\t-在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口中的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed]\n\t-对\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002FPanel\u002FWindow中的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不会有残影出现。[fixed]\n\t-如果\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E_iframe.aspx)。[fixed]\n\t-Tree\u003Cem\u003E控件\u003C\u002Fem\u003E,点击\u003Cem\u003E一个\u003C\u002Fem\u003E节点自动回发,则当前点击的那个节点的选中状态不会保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx\u002Fsimpleform.aspx)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.aspx,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将JS文件引用由head移动到body中。[fixed]\n\t-Firefox下,如果页面太长会出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed]\n\t+IFrame内的页面宽度和高度会自动设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx\u002Fsimpleform.aspx\u002Fsimpleform2.aspx)[fixed]\n\t\t-增加PageManager\u003Cem\u003E控件\u003C\u002Fem\u003E(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image\u003Cem\u003E控件\u003C\u002Fem\u003E [feedback:jima]。[fixed]\n\t-Tree\u003Cem\u003E控件\u003C\u002Fem\u003E,如果\u003Cem\u003E一个\u003C\u002Fem\u003E节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed]\n\t-去掉DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息中的换行符(转换为\u003Cbr\u002F\u003E),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t\t-如何将数据库中的数据绑定到Tree(示例在tree2_bind_database.aspx)。\n\t\t-ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.aspx)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同\u003Cem\u003E一个\u003C\u002Fem\u003E页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltipFormatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[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,从而实现FF和IE下样式的统一。\n\t\t-刚看到old9的解决方案:把“差旅交通费”改成“\u003Cspan style=\"margin-right: -1000px;\"\u003E差旅交通费\u003C\u002Fspan\u003E”,在IE下和FF下的都不换行,:-)\n\t-LinkButton增加OnClick事件 [feedback:huihuang]。[fixed]\n\t-Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed]\n\t+增加树\u003Cem\u003E控件\u003C\u002Fem\u003E(Tree)(示例在tree2.aspx)。[fixed]\n\t\t-可以在回发时维持树的状态(选中行,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式添加树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到页面,也可以引发PostBack事件,可以添加自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel中放置ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E,则渲染时会出现各种\u003Cem\u003E问题\u003C\u002Fem\u003E,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel中渲染ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E,如果容器的display='none',则会出现各种\u003Cem\u003E问题\u003C\u002Fem\u003E(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。\n\t+IE6下,在应用Asp.NetAjax后,Form中字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现\u003Cem\u003E问题\u003C\u002Fem\u003E的经历,你就能明白。\n\t\t-最后发现IE6下应用Asp.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();):\n\t\t 示例在 Site.Master 页面。\n\t+集成的AspNetAjax有\u003Cem\u003E一个\u003C\u002Fem\u003E很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过\u003Cem\u003E一个\u003C\u002Fem\u003E下午的不断尝试,终于用\u003Cem\u003E一个\u003C\u002Fem\u003E怪异的方法解决(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\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选中样式微调。[fixed]\n\t-预加载Form表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(\u003Cem\u003E一个\u003C\u002Fem\u003E典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid中静态的CheckBoxField图片。[fixed]\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击\u003Cem\u003E一个\u003C\u002Fem\u003ETab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E.aspx)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-页面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和\u003Cem\u003ELabel\u003C\u002Fem\u003E比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而\u003Cem\u003E一个\u003C\u002Fem\u003ENumberBox和TextBox比较大小需要指定CompareType。\n\t+如果在编辑页面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx\u002Fajax_editor.aspx)。[fixed]\n\t\t-这是由于ajax后执行的javascript中不能有return false语句。\n\t+在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.aspx) [feedback:xmzhu]。[fixed]\n\t\t-在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误页面,解决方法在当前目录添加\u003Cem\u003E一个\u003C\u002Fem\u003E空的html页面,然后把Window\u003Cem\u003E控件\u003C\u002Fem\u003E的IFrameUrl指向这个页面而不是\"#\"。[fixed]\n\t+弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例中alert\\alert_1.aspx和alert\\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。\n\t-点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed]\n\t+增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink\u003Cem\u003E控件\u003C\u002Fem\u003E,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed]\n\t-增加SplitButton\u003Cem\u003E控件\u003C\u002Fem\u003E。[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.aspx。\n\t+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E中放置IFrame会出现渲染错误 (示例在\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E_iframe.aspx)[feedback:jima]。[fixed]\n\t\t-特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed]\n\t-FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.aspx)[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\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t\t-其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.aspx)。\n\t-模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed]\n\t+控制下拉列表某些项不可以选择(示例在dropdownlist2.aspx)。[fixed]\n\t\t-增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。\n\t-LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.aspx和grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-07 v0.3 beta2\n\t+增加UpdatePanelConnector\u003Cem\u003E控件\u003C\u002Fem\u003E,支持在布局构建的页面使用Asp.net Ajax。[fixed]\n\t\t-使用UpdatePanelConnector有\u003Cem\u003E一个\u003C\u002Fem\u003E要求:ContentTemplate下只能有\u003Cem\u003E一个\u003C\u002Fem\u003E子节点,比如box:Panel。\n\t\t-示例在ajax3.aspx\u002Fcontent_page4.aspx。\n\t\t-示例content_page3.aspx中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器\u003Cem\u003E控件\u003C\u002Fem\u003E的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工添加AutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其中放置用户\u003Cem\u003E控件\u003C\u002Fem\u003E(示例在page_usercontrol.aspx)。[fixed]\n\t\t-也可以在ContentPanel中放置用户\u003Cem\u003E控件\u003C\u002Fem\u003E,注意两者的区别。\n\t+增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed]\n\t+支持Asp.net ajax异步加载。[fixed]\n\t\t-有很大局限性,只能在ContentPanel中使用,示例在ajax1.aspx\u002Fcontent_ajax2.aspx中。\n\t\t-对于使用布局构建的页面(比如content_page1.aspx)还不能使用Asp.net ajax,因为页面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前页面已经被修改(示例在content_page1.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中做法一致)。\n\t+iframe中的alert\u002Fconfirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed]\n\t\t-在Firefox下还有\u003Cem\u003E问题\u003C\u002Fem\u003E。[fix pending]\n\t+排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed]\n\t\t-可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。\n\t\t-可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。\n\t+HyperLinkField\u002FWindowField的链接地址支持服务器端格式(即是~\u002Falert.aspx)。[fixed]\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed]\n\t-可以在ContentPanel中放置用户\u003Cem\u003E控件\u003C\u002Fem\u003E(示例在page_usercontrol.aspx)。[fixed]\n\t\t\n\t\n\t\n+2008-06-30 v0.2 beta11\n\t-增加TwinTriggerBox\u003Cem\u003E控件\u003C\u002Fem\u003E(示例在twintriggerbox.aspx)。[fixed]\n\t-Grid的数据库分页需要增加属性IsDatabasePaging=true,以便普通分页和数据库分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第\u003Cem\u003E一个\u003C\u002Fem\u003E没通过验证的字段)(目前还不能切换到相应的tab)。[fixed]\n\t+页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid中的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.aspx示例)。\n\t\t-Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(\u003Cem\u003E一个\u003C\u002Fem\u003EGrid只能有\u003Cem\u003E一个\u003C\u002Fem\u003EColumn指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。\n\t\t-切换分页时清空选中的值 [feedback:jqpeng]。\n\t\t-增加PreRowDataBound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.aspx)。\n\t-DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。\n\t\n\t\n\t\n+2008-06-25 v0.2 beta9\n\t+Window窗体中的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-在simpleform.aspx中:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其中26是Toolbar的高度,32是窗口的标题栏和下边框的高度。\n\t+关闭Iframe的LoadMask,所以需要Iframe页面添加PageLoading\u003Cem\u003E控件\u003C\u002Fem\u003E,这样效果统一。[fixed]\n\t+Grid完善。\n\t\t-去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在ASP.NET应用中会有很多\u003Cem\u003E问题\u003C\u002Fem\u003E(主要是状态保持的\u003Cem\u003E问题\u003C\u002Fem\u003E)。\n\t\t+EnableServerSort改名AllowSorting。(示例在grid_sorting.aspx)\n\t\t\t-使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件处理函数中重新绑定数据。\n\t\t+增加AllowPaging属性。(示例在grid_paging.aspx)\n\t\t\t-使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件处理函数中Grid1.PageIndex = e.NewPageIndex;OK。\n\t\t+数据库分页支持。(示例在grid_database_paging.aspx)\n\t\t\t-使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件处理函数中Grid1.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-2-2190657-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2190657-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"2\",\"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-2-2190657-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"2\",\"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-2-2190657-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fedu.csdn.net\u002Fcourse\u002Fdetail\u002F26597","title":"VBA从入门到精通(\u003Cem\u003E控件\u003C\u002Fem\u003E+类模块+ADO+SQL数据库)","desc":"VBA中比较高阶的课程,主要讲解关于各种事件的应用,各种\u003Cem\u003E控件\u003C\u002Fem\u003E的应用,如果使用类模块,如果在VBA用调用SQL语句去处理数据库中的数据等操作。学习完成本课后,你可以在Excel中开发各种小型应用系统。以下是课程主要...","createTime":"2019-11-01 11:46:28","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fedu.csdn.net\u002Fcourse\u002Fdetail\u002F26597\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fedu.csdn.net\u002Fcourse\u002Fdetail\u002F26597\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-course-2~default~OPENSEARCH~Rate-3-26597-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"course"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130","title":"ExtAspNet_v2.3.2_dll","desc":"ExtAspNet - ExtJS based ASP.NET Controls with Full AJAX Support\n\t\nExtAspNet是一组专业的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E库,拥有原生的AJAX支持和丰富的UI效果,\n目标是创建没有ViewState,没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。\n\n支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+\n\n注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。\n\n示例: http:\u002F\u002Fextasp.net\u002F\n开源: http:\u002F\u002Fextaspnet.codeplex.com\u002F\n博客: http:\u002F\u002Fsanshi.cnblogs.com\u002F\n邮箱: sanshi.ustc@gmail.com\n\n\n发布历史:\n\n+2010-09-29 v2.3.2\n\t-不绑定任何数据到Grid时,确保页面不会出错。\n\t-修正了Grid列属性DataFormatString的\u003Cem\u003E一个\u003C\u002Fem\u003Ebug,比如设置{0:yy-MM-dd HH:mm}时没有效果。\n\t-修正下拉列表\u003Cem\u003E控件\u003C\u002Fem\u003E不能绑定DataTable的BUG(feedback:RedOcean)。\n\t-增加土耳其语言资料文件(feedback:abdullaharslan)。\n\t-Grid的BoundField增加NullDisplayText属性,用于处理数据库中的null值,如果没有设置则默认为空字符串。\n\t-修正DatePicker中的\u003Cem\u003E一个\u003C\u002Fem\u003Ebug(31\u002F01\u002F2010将会返回NULL)使用DateFormatString来生成SelectedDate属性(feedback:OktaEndy)。\n\t-修正extjs最新版本(v3.2.2)中的\u003Cem\u003E一个\u003C\u002Fem\u003Ebug,如果下拉列表中存在两个相同的Text,则SelectedValue返回值永远是第\u003Cem\u003E一个\u003C\u002Fem\u003EText的值(feedback:ben.zhou)。\n\t-应用补丁#6593, #6621(feedback:vbelyaev)。\n\t+修正IE7下Grid分页速度慢(feedback:youwei, StevenGuan, hazardvn, gavindou, ttjacky)。\n\t\t-实际上IE7下所以的回发都慢,原因是客户端的Base64编码速度慢,已经使用encodeURIComponent来代替Base64编码。\n\t-俄语翻译(feedback:vbelyaev)。\n\t\n\t\n\n+2010-06-30 v2.3.1\n\t-ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E将不在依赖ViewState,减少1\u002F4左右的HTTP数据传输量。\n\t-\u003Cem\u003E控件\u003C\u002Fem\u003E和示例的增强。\n\t\n\t\n\n+2010-03-28 v2.2.1\n\t+为\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首页最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成Extjs最新版本v3.1.1。\n\t\t-增加\u003Cem\u003E一个\u003C\u002Fem\u003E新的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-使得Asp.net的\u003Cem\u003E控件\u003C\u002Fem\u003EImageButton具有和Asp.net的Button\u003Cem\u003E控件\u003C\u002Fem\u003E类似的行为(Ajax提交)(feedback:261629698)。\n\t+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加GetAddTabReference和GetRemoveTabReference两个函数,用来向\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E动态增加删除Tab。\n\t\t-增加示例\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002F\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E_addtab.aspx。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E更新。\n\t\t-关闭按钮默认直接关闭,不会弹出确认对话框。\n\t\t-GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button\u003Cem\u003E控件\u003C\u002Fem\u003E的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居中,而不是黄金分割位置。\n\t+Button, Window等\u003Cem\u003E控件\u003C\u002Fem\u003E弹出位置属性的变化。\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的最后\u003Cem\u003E一个\u003C\u002Fem\u003E参数target变为枚举类型。\n\t\t-Alert.GetShowReference中的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\u003Cem\u003E问题\u003C\u002Fem\u003E。\n\t-修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button\u003Cem\u003E控件\u003C\u002Fem\u003E将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第\u003Cem\u003E一个\u003C\u002Fem\u003E按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window\u003Cem\u003E控件\u003C\u002Fem\u003E的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。\n\t-增加\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E中Tab\u003Cem\u003E控件\u003C\u002Fem\u003E可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument中Icon属性映射错误(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\u003EJS\u003Cem\u003E问题\u003C\u002Fem\u003E(feedback:lqm4108)。\n\t-修正Alert消息中引号未编码导致的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.aspx),如何通过简单的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-增加中国的省市县三级联动示例(data\u002Fshengshixian.aspx)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的Tab在切换过程中会重复加载的\u003Cem\u003E问题\u003C\u002Fem\u003E,这是\u003Cem\u003E一个\u003C\u002Fem\u003E在v2.1.6引入的\u003Cem\u003E问题\u003C\u002Fem\u003E(feedback:eroach)。\n\t-修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(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.aspx)。\n\t-修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器\u003Cem\u003E控件\u003C\u002Fem\u003E(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的实现,避免选中某项后的闪烁。\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.aspx),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet中的\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-为所有\u003Cem\u003E控件\u003C\u002Fem\u003E增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.aspx)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#处理函数来响应键盘事件。\n\t-为Tree增加AutoLeafIdentification属性。\n\t\t-增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。\n\t\n\t\n\n+2009-11-17 v2.1.4\n\t-修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。\n\t-部分ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E的设计时支持(会在后续版本中逐步完善)。\n\t-v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。\n\t-修正CheckBox\u003Cem\u003E控件\u003C\u002Fem\u003E的CheckedChanged事件会被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等\u003Cem\u003E控件\u003C\u002Fem\u003E增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:form\u002Fform_validate.aspx\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的\u003Cem\u003E控件\u003C\u002Fem\u003E属性列表(\u002Fajax.aspx)。\n\t\t-ExtAspNet支持原生的AJAX,也就是说\u003Cem\u003E控件\u003C\u002Fem\u003E的属性改变在AJAX过程中会反映到页面中,但并不是所有的\u003Cem\u003E控件\u003C\u002Fem\u003E属性都支持AJAX改变。\n\t-加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保Asp.net的按钮\u003Cem\u003E控件\u003C\u002Fem\u003E仍然具有AJAX的特性。\n\t-更新\u002Fbasic\u002Flogin.aspx示例,使用验证图片(feedback:kedee)。\n\t-为Grid增加AutoPostBack属性和RowClick事件,示例在\u002Fdata\u002Fgrid_autopostback.aspx(feedback:chenguizhu2006)。\n\t-为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。\n\t-Grid中TemplateField生成到页面中\u003Cem\u003E控件\u003C\u002Fem\u003E具有唯一ID,例如Grid1_ct5_\u003Cem\u003ELabel\u003C\u002Fem\u003E2,Grid1_ct6_\u003Cem\u003ELabel\u003C\u002Fem\u003E2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree\u003Cem\u003E控件\u003C\u002Fem\u003E增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。\n\t\t-如果Panel具有IconUrl属性,则IconUrl优先于Icon。\n\t\t-所有Icon的列表在icon.aspx。\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\u003Cem\u003E控件\u003C\u002Fem\u003E的Target=\"_parent\")。\n\t+为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-\u003Cem\u003E一个\u003C\u002Fem\u003E典型应用,在Window\u003Cem\u003E控件\u003C\u002Fem\u003E中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-ExtAspNet.Alert.Show(\"参数错误!\", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以自动回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002Fextasp.net\u002Fdata\u002Ftree_run.aspx\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选中任何一项时在父页面弹出对话框的JS代码。\n\t-修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。\n\t-添加定时器\u003Cem\u003E控件\u003C\u002Fem\u003ETimer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree\u003Cem\u003E控件\u003C\u002Fem\u003E的AJAX实现。\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中所有语言的支持。\n\t\t-ExtAspNet扩展的多语言包在js\\languages\\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其中添加自己的语言版本,并执行js\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。\n\t+在aspx页面中必须显示的声明\u003Cem\u003E控件\u003C\u002Fem\u003E的集合属性(比如\u003Cem\u003ETabs\u003C\u002Fem\u003E(\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将会影响所有的aspx页面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX中使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将会影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree\u003Cem\u003E控件\u003C\u002Fem\u003E的\u003Cem\u003E一个\u003C\u002Fem\u003EBUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpContext.Current,而不是\u003Cem\u003E一个\u003C\u002Fem\u003E全局变量。\n\t -这个BUG导致Asp.net compatibility中的示例无法完成,现在已经修正。\n\t+去除PageManager中方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。\n\t -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility中的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。\n -增加示例-如何将Grid\u003Cem\u003E控件\u003C\u002Fem\u003E导出为Excel(data\\grid_excel_run.aspx)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不会被选中(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.aspx)。\n -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。\n +去除PageLayout\u003Cem\u003E控件\u003C\u002Fem\u003E,此\u003Cem\u003E控件\u003C\u002Fem\u003E可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E)都可以通过这种方式全屏。\n\t\t-简单方便,示例可以参考 default.aspx 或者 other\\accordion_tree_run.aspx。\n \n \n\n+2009-08-14 v2.0.6\n\t-动态生成菜单实例(other\\menu_dynamic_run.aspx和other\\menu_dynamic2_run.aspx)(feedback:shguo)。\n\t-优化AJAX的内部实现,每个页面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId自动生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+ExtAspNet和Asp.net的提交按钮兼容\u003Cem\u003E问题\u003C\u002Fem\u003E(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容\u003Cem\u003E问题\u003C\u002Fem\u003E,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们做了优化,现在要使\u003Cem\u003E一个\u003C\u002Fem\u003EAsp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E了。\n\t\t-在Page_Load中设置了哪些需要在AJAX中更新的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的\u003Cem\u003E控件\u003C\u002Fem\u003E。\n\t\t-示例在aspnet\\fckeditor_run.aspx和aspnet\\aspnet_run.aspx。\n\t\t-FCKEditor和上传\u003Cem\u003E控件\u003C\u002Fem\u003E兼容。示例在aspnet\\fileupload_run.aspx。\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+和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加\u003Cem\u003E一个\u003C\u002Fem\u003EhttpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.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\u003Cem\u003E控件\u003C\u002Fem\u003E的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下测试通过。以后ExtAspNet将不会对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的\u003Cem\u003E一个\u003C\u002Fem\u003EBUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此\u003Cem\u003E问题\u003C\u002Fem\u003E)。\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; 目前只有\u003Cem\u003E一个\u003C\u002Fem\u003E缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个页面只包含\u003Cem\u003E一个\u003C\u002Fem\u003EJavaScript文件(语言文件除外)和\u003Cem\u003E一个\u003C\u002Fem\u003ECSS文件。\n\t-ExtAspNet自身的CSS会紧挨着页面标签引入,这样在中自定义的样式可以覆盖ExtAspNet缺省样式。\n\t+Alert对话框会遮挡所有的Window窗口。\n\t\t-使用\u003Cem\u003E一个\u003C\u002Fem\u003E变通的方法解决,因为无法改变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,则默认选中第一项。\n\t-重新绑定模拟树的下拉列表后,选中项的前面有图片的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中的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed]\n\t-页面包含FileUpload\u003Cem\u003E控件\u003C\u002Fem\u003E,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet\u002Ffileupload.aspx)[fixed]\n\t-HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed]\n\t\n\t\n\n+2009-03-03 v1.3.0\n\t-如果弹出的窗口(Ext-Window)含有ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003EFileUpload,则此弹出窗口在关闭时出现JS错误(http:\u002F\u002Fextjs.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果页面中存在ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的\u003Cem\u003E问题\u003C\u002Fem\u003E)。[fixed]\n\t-页面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed]\n\t-ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在ExtAspNet工程中使用ASP.NET标准\u003Cem\u003E控件\u003C\u002Fem\u003E的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E和ASP.NET标准\u003Cem\u003E控件\u003C\u002Fem\u003E和平共处了。[fixed]\n\t\t-如果\u003Cem\u003E一个\u003C\u002Fem\u003EASP.NET按钮\u003Cem\u003E控件\u003C\u002Fem\u003E要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET\u003Cem\u003E控件\u003C\u002Fem\u003E的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet\u002Faspnet.aspx)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed]\n\t-自动测试功能会在以后版本中逐步完善。这个版本完成测试框架,采用Extjs中JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建\u003Cem\u003E一个\u003C\u002Fem\u003EWindow\u003Cem\u003E控件\u003C\u002Fem\u003E的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference\u002FGetConfirmFormModifiedCloseRefreshReference\u002FGetConfirmFormModifiedClosePostBackReference三个方法代替。\n\t\t-不会修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面添加box_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的ASPX页面中查找RegisterPageStateChangedScript属性,并删除,否则会运行错误!\n\t\t-A页面有Ext-Window\u003Cem\u003E控件\u003C\u002Fem\u003E弹出B页面,B页面有Ext-Window\u003Cem\u003E控件\u003C\u002Fem\u003E弹出C页面,B页面的Ext-Window\u003Cem\u003E控件\u003C\u002Fem\u003E设置Target='_parent',则弹出的Ext-Window(C页面)会覆盖整个A页面,这是正确的。\n\t\t---当时如果用户直接访问B页面,就会报JS错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不会出错了。\n\t\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window\u003Cem\u003E控件\u003C\u002Fem\u003E增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。\n\t\t---Window\u003Cem\u003E控件\u003C\u002Fem\u003E的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window\u003Cem\u003E控件\u003C\u002Fem\u003E的关闭按钮添加关闭后刷新父页面或者关闭后回发父页面的行为。\n\t\t-如果弹出窗口(Window\u003Cem\u003E控件\u003C\u002Fem\u003E)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时页面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E的IFrameName属性是自动生成的,只读属性。(因为有可能所有的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的地方,需要删除第\u003Cem\u003E一个\u003C\u002Fem\u003E参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel中内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed]\n\t-DropDownList在页面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed]\n\t-升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏\u003Cem\u003E问题\u003C\u002Fem\u003E的修正)。[fixed]\n\t-页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added]\n\t+增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选中任何一项,回发时报错[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),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image\u003Cem\u003E控件\u003C\u002Fem\u003E增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包中增加\u003Cem\u003E一个\u003C\u002Fem\u003EWeb.config.txt,这是\u003Cem\u003E一个\u003C\u002Fem\u003E空的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+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的Tab\u003Cem\u003E控件\u003C\u002Fem\u003E的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed]\n\t\t-有这样\u003Cem\u003E一个\u003C\u002Fem\u003E效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后会回发Tab1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用\u003Cem\u003E控件\u003C\u002Fem\u003E的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的\u003Cem\u003E问题\u003C\u002Fem\u003E。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-aspnet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemText\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new ExtAspNet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。\n\t\t\t-和Asp.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string text, string value),这样方便后台添加列表项。\n\t-处于布局内的容器\u003Cem\u003E控件\u003C\u002Fem\u003E(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,\u003Cem\u003E控件\u003C\u002Fem\u003E的高度指的是整个\u003Cem\u003E控件\u003C\u002Fem\u003E的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有\u003Cem\u003E控件\u003C\u002Fem\u003E属性增加在VS中的智能提示。[fixed]\n\t\t-需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。\n\t+\u003Cem\u003E控件\u003C\u002Fem\u003E的属性如果是枚举类型,如果此属性可以不取值,则默认为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+注意:\u003Cem\u003E一个\u003C\u002Fem\u003E属性可以拥有多个值的情况。[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)中通过js切换父页面中选中的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.aspx,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的动态添加\u003Cem\u003E控件\u003C\u002Fem\u003E,并且可以给\u003Cem\u003E控件\u003C\u002Fem\u003E添加服务器端事件(示例在form\u002Fform_dynamic_run.aspx)。[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属性,这样就可以直接在前台(ASPX)中设置哪些项不可选择,以及创建模拟下拉树。\n\t\t-DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则自动将EnableSimulateTree设置为true。\n\t\n\t\n\n+2008-09-27 v1.2 beta4\n\t+EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只会改变Accordion的标题大小,而不会对AccordionPanel起作用(示例见other\u002Faccordion_run.aspx)。[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.aspx)。[fixed]\n\t\t-原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上标签。\n\t\t-适当增大AccordionPanel中链接的高度20px-\u003E22px,同时对链接的样式也做了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少ASPX中HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在ASPX页切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002FToolbar\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向Form中动态添加\u003Cem\u003E控件\u003C\u002Fem\u003E的BUG,现在form\u002Fform_dynamic_run.aspx示例已经能正确运行。[fixed]\n\t+大部分容器的子\u003Cem\u003E控件\u003C\u002Fem\u003E集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的\u003Cem\u003E控件\u003C\u002Fem\u003E包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimpleForm\u002FWindow等。\n\t\t-保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的\u003Cem\u003ETabs\u003C\u002Fem\u003E(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选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选中项中会存在当前不存在的行序号,导致服务器端遍历选中项时数组越界。所有使用box\u003Cem\u003E控件\u003C\u002Fem\u003E的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例中表单\u003Cem\u003E控件\u003C\u002Fem\u003E都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimpleForm\u002FButton\u002FHyperLink\u002F\u003Cem\u003ELabel\u003C\u002Fem\u003E\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在ASPX中设置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中。[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中布局可供使用。\n\t\t-其中一些\u003Cem\u003E控件\u003C\u002Fem\u003E默认使用一种布局:SimpleForm(Form)\u002FForm(Form)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002F\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E(Card),所有布局\u003Cem\u003E控件\u003C\u002Fem\u003E默认的布局是Container。\n\t\t-经常用到的布局\u003Cem\u003E控件\u003C\u002Fem\u003E:SimpleForm\u002FForm\u002FAccordion\u002F\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果\u003Cem\u003E一个\u003C\u002Fem\u003E菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E增加Hidden属性(少数几个\u003Cem\u003E控件\u003C\u002Fem\u003E没有此属性:Menu),这样在Ajax时可以显示隐藏\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的\u003Cem\u003E控件\u003C\u002Fem\u003E渲染到客户端但是隐藏。\n\t\t-US的ExtAspNet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报中唯一没有用到ExtAspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageContext.Redirect支持普通页面转向和ExtAspNetAjax下页面转向。[fixed]\n\t+模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多\u003Cem\u003E控件\u003C\u002Fem\u003E(Grid,DropDownList,\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E)。\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\u003E控件\u003C\u002Fem\u003E(以后不会用AspnetAjax,这个\u003Cem\u003E控件\u003C\u002Fem\u003E已经完成使命)。[fixed]\n\t-不要使用Asp.net的\u003Cem\u003E控件\u003C\u002Fem\u003EHiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的\u003Cem\u003E控件\u003C\u002Fem\u003E在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList中项如果存在汉字,则会换行的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前Tab中如果有ContentPanel,则在页面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢页面的加载速度),现在已经解决这个\u003Cem\u003E问题\u003C\u002Fem\u003E。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父\u003Cem\u003E控件\u003C\u002Fem\u003E(SimpleForm\u002FForm)的背景色一致。[fixed]\n\t-TwinTriggerBox的第\u003Cem\u003E一个\u003C\u002Fem\u003ETrigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config中增加配置项Form\u003Cem\u003ELabel\u003C\u002Fem\u003EWidth=\"80\"(默认为80),同时PageManager增加Form\u003Cem\u003ELabel\u003C\u002Fem\u003EWidth属性用来控制页面上所有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-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加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回发时支持\u003Cem\u003E控件\u003C\u002Fem\u003E哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供\u003Cem\u003E控件\u003C\u002Fem\u003E级别的EnableAjax属性。\n\t\t-整理支持Ajax的\u003Cem\u003E控件\u003C\u002Fem\u003E属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对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\u003Cem\u003E控件\u003C\u002Fem\u003E是否弹出的状态在回发时维持。[fixed]\n\t\t-\u003Cem\u003E控件\u003C\u002Fem\u003E设计的\u003Cem\u003E一个\u003C\u002Fem\u003E原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃Asp.NetAjax,ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E内置Ajax支持。[fixed]\n\t\t-这是\u003Cem\u003E一个\u003C\u002Fem\u003E值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击\u003Cem\u003E一个\u003C\u002Fem\u003E按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前ExtAspNetAjax的限制。\n\t\t\t-只对ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E起作用,对Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E不起作用。\n\t\t\t-对容器\u003Cem\u003E控件\u003C\u002Fem\u003E(有子\u003Cem\u003E控件\u003C\u002Fem\u003E的\u003Cem\u003E控件\u003C\u002Fem\u003E)不起作用,只对最底层的\u003Cem\u003E控件\u003C\u002Fem\u003E起作用。\n\t\t\t-对改变\u003Cem\u003E控件\u003C\u002Fem\u003E的Visible属性会有错误。\n\t\t\t-Window\u003Cem\u003E控件\u003C\u002Fem\u003E的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都添加PageLoading\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t-Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选中的状态在回发后会得到保持。[fixed]\n\t-Grid选中行的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知\u003Cem\u003E问题\u003C\u002Fem\u003E:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父页面加载\u003Cem\u003E一个\u003C\u002Fem\u003E比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口中IFrame的显示速度。[fixed]\n\t\t-在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed]\n\t\t-\u003Cem\u003E一个\u003C\u002Fem\u003E典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.aspx)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\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事件中。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E延迟加载引起的BUG(非当前Tab中的ContentPanel会占据页面空间,已修正)。[fixed]\n\t-全新的ExtAspNet.Examples(基础知识\u002F表单\u003Cem\u003E控件\u003C\u002Fem\u003E\u002F数据绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe\u002Fdefault.aspx和iframe\u002Fpage3.aspx)。[fixed]\n\t\t-测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+extjs的BUG,当页面中含有iframe时,Ext.onReady会被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.extjs.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.aspx)[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.aspx\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下会有JS错误。[fixed]\n\t-增加BorderLayout\u003Cem\u003E控件\u003C\u002Fem\u003E,示例在iframe\u002Fborderlayout.aspx。[fixed]\n\t+Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed]\n\t\t-全新的样式。\n\t\t-去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。\n\t\t-GetValueReference取得的值不正确的BUG。\n\t-动态向Form中添加FormRow,并动态的向FormRow中添加表单字段,以及如何取得表单字段的值。(示例在form_dynamic.aspx)[fixed]\n\t+IFrame弹出窗口关闭后回发父页面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是\u003Cem\u003E一个\u003C\u002Fem\u003E重要的BUG,会严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父页面后Window中的IFrame被添加到页面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此\u003Cem\u003E问题\u003C\u002Fem\u003E解决。(示例在button_iframe.aspx)\n\t\n\t\n\t\n+2008-08-13 v0.4 beta4\n\t-点击关闭窗口的按钮,在IE下会有JS错误。[fixed]\n\t-Window的右上角关闭图标增加提示,优化事件响应。[fixed]\t\n\t-Window的代码重构。[fixed]\t\n\t+修正\u003Cem\u003E一个\u003C\u002Fem\u003E的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.aspx页面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.aspx页面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.aspx页面8次后iexplorer占76.492M内存。\n\t\t-IE窗口最小化时,IE会自动进行垃圾回收。\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-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E延时加载出错。[fixed]\n\t-Window的IFrameUrl处理的BUG,比如Pages_ExtAspNet目录下的页面应该为.\u002FFE_ApplyEditor.aspx或~\u002FPages_ExtAspNet\u002FFE_ApplyEditor.aspx。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则会JS错误。[fixed]\n\t-实现网报首页下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在页面显示后进行,不计算在js渲染时间内。[fixed]\n\t-优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.aspx默认会加载form.aspx页面(Window\u003Cem\u003E控件\u003C\u002Fem\u003E的BUG)。[fixed]\n\t-Window中的保存并关闭按钮和Asp.netAjax冲突。[fixed]\n\t-优化关闭Window的js脚本,减少写到页面的js大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.aspx)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的Asp.net\u003Cem\u003E控件\u003C\u002Fem\u003E一样不可编辑。[fixed]\n\t-DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的js对象的名称简单化,这样可以减少生成的js内容,加快页面加载速度(\u003Cem\u003E一个\u003C\u002Fem\u003E典型页面的js由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口中,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为js调用此脚本时报错。\n\t\t-一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。\n\t\t-另一种办法就是在PageManager\u003Cem\u003E控件\u003C\u002Fem\u003E中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(会在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx\u002Fsimpleform.aspx)。\n\t+PageManager\u003Cem\u003E控件\u003C\u002Fem\u003E增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed]\n\t\t-这个手工添加onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报中遇到这种情况)。\n\t-每个页面必须添加\u003Cem\u003E一个\u003C\u002Fem\u003EPageManager\u003Cem\u003E控件\u003C\u002Fem\u003E,否则会出错,同时去除DesignTimeStyle\u003Cem\u003E控件\u003C\u002Fem\u003E(作为PageManager的属性出现)。[fixed]\n\t-TextField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.aspx\u002Fpage2.aspx\u002Fsimpleform.aspx)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window\u003Cem\u003E控件\u003C\u002Fem\u003E增加\u003Cem\u003E一个\u003C\u002Fem\u003E属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,\u003Cem\u003E控件\u003C\u002Fem\u003E本身封装了大量的代码,简单来看现在有三个页面(default.aspx(A)\u002Fpage2.aspx(B)\u002Fsimpleform.aspx(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我会通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid中弹出窗口。(default.aspx\u002Fpage3.aspx\u002Fsimpleform.aspx)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.aspx\u002Ftriggerbox.aspx\u002Fsimpleform.aspx)\t\n\t\t\t-在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口中的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed]\n\t-对\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E\u002FPanel\u002FWindow中的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不会有残影出现。[fixed]\n\t-如果\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E_iframe.aspx)。[fixed]\n\t-Tree\u003Cem\u003E控件\u003C\u002Fem\u003E,点击\u003Cem\u003E一个\u003C\u002Fem\u003E节点自动回发,则当前点击的那个节点的选中状态不会保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx\u002Fsimpleform.aspx)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simpleform.aspx,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将JS文件引用由head移动到body中。[fixed]\n\t-Firefox下,如果页面太长会出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed]\n\t+IFrame内的页面宽度和高度会自动设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx\u002Fsimpleform.aspx\u002Fsimpleform2.aspx)[fixed]\n\t\t-增加PageManager\u003Cem\u003E控件\u003C\u002Fem\u003E(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image\u003Cem\u003E控件\u003C\u002Fem\u003E [feedback:jima]。[fixed]\n\t-Tree\u003Cem\u003E控件\u003C\u002Fem\u003E,如果\u003Cem\u003E一个\u003C\u002Fem\u003E节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起页面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed]\n\t-去掉DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息中的换行符(转换为),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t\t-如何将数据库中的数据绑定到Tree(示例在tree2_bind_database.aspx)。\n\t\t-ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.aspx)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同\u003Cem\u003E一个\u003C\u002Fem\u003E页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltipFormatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才行(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed]\n\t\t-虽然最后未能解决##差旅交通费在IE和Firefox下显示的不同效果。\n\t\t-但是通过用来代替,从而实现FF和IE下样式的统一。\n\t\t-刚看到old9的解决方案:把“差旅交通费”改成“差旅交通费”,在IE下和FF下的都不换行,:-)\n\t-LinkButton增加OnClick事件 [feedback:huihuang]。[fixed]\n\t-Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed]\n\t+增加树\u003Cem\u003E控件\u003C\u002Fem\u003E(Tree)(示例在tree2.aspx)。[fixed]\n\t\t-可以在回发时维持树的状态(选中行,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式添加树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到页面,也可以引发PostBack事件,可以添加自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel中放置ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E,则渲染时会出现各种\u003Cem\u003E问题\u003C\u002Fem\u003E,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel中渲染ExtAspNet\u003Cem\u003E控件\u003C\u002Fem\u003E,如果容器的display='none',则会出现各种\u003Cem\u003E问题\u003C\u002Fem\u003E(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。\n\t+IE6下,在应用Asp.NetAjax后,Form中字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现\u003Cem\u003E问题\u003C\u002Fem\u003E的经历,你就能明白。\n\t\t-最后发现IE6下应用Asp.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();):\n\t\t 示例在 Site.Master 页面。\n\t+集成的AspNetAjax有\u003Cem\u003E一个\u003C\u002Fem\u003E很大的BUG,只要你在页面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过\u003Cem\u003E一个\u003C\u002Fem\u003E下午的不断尝试,终于用\u003Cem\u003E一个\u003C\u002Fem\u003E怪异的方法解决(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\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选中样式微调。[fixed]\n\t-预加载Form表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(\u003Cem\u003E一个\u003C\u002Fem\u003E典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid中静态的CheckBoxField图片。[fixed]\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击\u003Cem\u003E一个\u003C\u002Fem\u003ETab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E.aspx)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-页面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和\u003Cem\u003ELabel\u003C\u002Fem\u003E比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而\u003Cem\u003E一个\u003C\u002Fem\u003ENumberBox和TextBox比较大小需要指定CompareType。\n\t+如果在编辑页面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx\u002Fajax_editor.aspx)。[fixed]\n\t\t-这是由于ajax后执行的javascript中不能有return false语句。\n\t+在文本框失去焦点时,执行一些Javascript脚本(示例在textbox_blur.aspx) [feedback:xmzhu]。[fixed]\n\t\t-在页面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误页面,解决方法在当前目录添加\u003Cem\u003E一个\u003C\u002Fem\u003E空的html页面,然后把Window\u003Cem\u003E控件\u003C\u002Fem\u003E的IFrameUrl指向这个页面而不是\"#\"。[fixed]\n\t+弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例中alert\\alert_1.aspx和alert\\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。\n\t-点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed]\n\t+增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink\u003Cem\u003E控件\u003C\u002Fem\u003E,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed]\n\t-增加SplitButton\u003Cem\u003E控件\u003C\u002Fem\u003E。[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.aspx。\n\t+\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E中放置IFrame会出现渲染错误 (示例在\u003Cem\u003Etabs\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E_iframe.aspx)[feedback:jima]。[fixed]\n\t\t-特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed]\n\t-FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.aspx)[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\u003Cem\u003E控件\u003C\u002Fem\u003E。[fixed]\n\t\t-其实用TextBox也能模拟HiddenField的行为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.aspx)。\n\t-模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed]\n\t+控制下拉列表某些项不可以选择(示例在dropdownlist2.aspx)。[fixed]\n\t\t-增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。\n\t-LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.aspx和grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-07 v0.3 beta2\n\t+增加UpdatePanelConnector\u003Cem\u003E控件\u003C\u002Fem\u003E,支持在布局构建的页面使用Asp.net Ajax。[fixed]\n\t\t-使用UpdatePanelConnector有\u003Cem\u003E一个\u003C\u002Fem\u003E要求:ContentTemplate下只能有\u003Cem\u003E一个\u003C\u002Fem\u003E子节点,比如box:Panel。\n\t\t-示例在ajax3.aspx\u002Fcontent_page4.aspx。\n\t\t-示例content_page3.aspx中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器\u003Cem\u003E控件\u003C\u002Fem\u003E的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工添加AutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其中放置用户\u003Cem\u003E控件\u003C\u002Fem\u003E(示例在page_usercontrol.aspx)。[fixed]\n\t\t-也可以在ContentPanel中放置用户\u003Cem\u003E控件\u003C\u002Fem\u003E,注意两者的区别。\n\t+增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed]\n\t+支持Asp.net ajax异步加载。[fixed]\n\t\t-有很大局限性,只能在ContentPanel中使用,示例在ajax1.aspx\u002Fcontent_ajax2.aspx中。\n\t\t-对于使用布局构建的页面(比如content_page1.aspx)还不能使用Asp.net ajax,因为页面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前页面已经被修改(示例在content_page1.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中做法一致)。\n\t+iframe中的alert\u002Fconfirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed]\n\t\t-在Firefox下还有\u003Cem\u003E问题\u003C\u002Fem\u003E。[fix pending]\n\t+排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed]\n\t\t-可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。\n\t\t-可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。\n\t+HyperLinkField\u002FWindowField的链接地址支持服务器端格式(即是~\u002Falert.aspx)。[fixed]\n\t-\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed]\n\t-可以在ContentPanel中放置用户\u003Cem\u003E控件\u003C\u002Fem\u003E(示例在page_usercontrol.aspx)。[fixed]\n\t\t\n\t\n\t\n+2008-06-30 v0.2 beta11\n\t-增加TwinTriggerBox\u003Cem\u003E控件\u003C\u002Fem\u003E(示例在twintriggerbox.aspx)。[fixed]\n\t-Grid的数据库分页需要增加属性IsDatabasePaging=true,以便普通分页和数据库分页,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第\u003Cem\u003E一个\u003C\u002Fem\u003E没通过验证的字段)(目前还不能切换到相应的tab)。[fixed]\n\t+页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx\u002Fsimpleform.aspx)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid中的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.aspx示例)。\n\t\t-Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(\u003Cem\u003E一个\u003C\u002Fem\u003EGrid只能有\u003Cem\u003E一个\u003C\u002Fem\u003EColumn指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。\n\t\t-切换分页时清空选中的值 [feedback:jqpeng]。\n\t\t-增加PreRowDataBound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.aspx)。\n\t-DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。\n\t\n\t\n\t\n+2008-06-25 v0.2 beta9\n\t+Window窗体中的","createTime":"2010-09-29 14:37:08","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fzhangsan000000\u002F1059933","title":"asp.net专家疑难解答200问源码","desc":"第1章 空 \n 第2章 ASP.NET运行模型 \n21.如何在页面中应用javascript脚本-示例1 \n21.如何在页面中应用javascript脚本-示例2 \n22.如何实现从服务器端向页面动态添加javascript脚本-示例1 \n22.如何实现从服务器端向页面动态添加javascript脚本-示例2 \n24.如何处理多页面重定向到同一页面后的返回\u003Cem\u003E问题\u003C\u002Fem\u003E \n25.如何用Response.Redirect方法传递汉字 \n29.如何利用输出缓存技术缓存整个页面 \n30.如何利用片段缓存技术对用户\u003Cem\u003E控件\u003C\u002Fem\u003E进行缓存 \n31.如何利用数据缓存技术提高程序的性能 \n33.如何实现当页面产生错误时重定向到自定义错误界面 \n35.如何在程序中读写Web.config文件 \n37.如何使用CSS文件定义\u003Cem\u003E控件\u003C\u002Fem\u003E的样式 \n38.如何启用和禁用ViewState保存状态信息的功能 \n39.如何应用IsPostBack控制页面的加载 \n41.如何使用Trace对象进行跟踪调试(页面级) \n42.如何使用#Include语法将文件添加到页面 \n43.如何使用编程的方式处理异常信息 \n44.如何将网页错误信息写入事件日志 \n 第3章 常用Web服务\u003Cem\u003E控件\u003C\u002Fem\u003E \n46.如何使用\u003Cem\u003ELabel\u003C\u002Fem\u003E\u003Cem\u003E控件\u003C\u002Fem\u003E动态显示文本信息 \n47.如何实现当鼠标移到\u003Cem\u003E控件\u003C\u002Fem\u003E时显示提示信息 \n48.如何在Web应用程序中实现快捷键功能(使用脚本实现) \n48.如何在Web应用程序中实现快捷键功能(使用属性实现) \n49.如何设置页面上\u003Cem\u003E控件\u003C\u002Fem\u003E的Tab键顺序 \n50.如何实现用回车键代替Tab键的功能 \n51.如何为按钮键添加消息框 \n52.Button、LinkButton和ImageButton服务\u003Cem\u003E控件\u003C\u002Fem\u003E的区别及应用 \n54.如何使用CheckBox和CheckBoxList\u003Cem\u003E控件\u003C\u002Fem\u003E(CheckBox示例) \n54.如何使用CheckBox和CheckBoxList\u003Cem\u003E控件\u003C\u002Fem\u003E(CheckBoxList示例) \n55.如何使用RadioButton和RadioButtonList\u003Cem\u003E控件\u003C\u002Fem\u003E(RadioButton示例) \n55.如何使用RadioButton和RadioButtonList\u003Cem\u003E控件\u003C\u002Fem\u003ERadioButtonList示例) \n56.如何使用Panel\u003Cem\u003E控件\u003C\u002Fem\u003E操作一组\u003Cem\u003E控件\u003C\u002Fem\u003E \n57.如何使用Table\u003Cem\u003E控件\u003C\u002Fem\u003E组织页面的内容 \n58.如何实现DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E选项的添加、删除等操作 \n59.如何实现间接改变DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E的当前选项 \n60.如何实现两个或多个DropDownList\u003Cem\u003E控件\u003C\u002Fem\u003E的联动 \n61.如何实现ListBox\u003Cem\u003E控件\u003C\u002Fem\u003E选项的上移、下移、添加和删除操作 \n62.如何实现ListBox\u003Cem\u003E控件\u003C\u002Fem\u003E中选项的双击事件 \n63.如何动态设置ListBox\u003Cem\u003E控件\u003C\u002Fem\u003E中各选项的背景颜色 \n64.如何在页面中动态创建\u003Cem\u003E控件\u003C\u002Fem\u003E \n65.如何为HTML服务器\u003Cem\u003E控件\u003C\u002Fem\u003E的事件添加自定义方法 \n 第4章 验证\u003Cem\u003E控件\u003C\u002Fem\u003E \n67.如何使用RequiredFieldValidator\u003Cem\u003E控件\u003C\u002Fem\u003E验证用户是否输入信息 \n68.如何使用RegularExpressionValidator\u003Cem\u003E控件\u003C\u002Fem\u003E验证E-mail地址和邮编等格式 \n69.如何使用RangeValidator\u003Cem\u003E控件\u003C\u002Fem\u003E验证输入的信息是否在指定范围内 \n70.如何使用CompareValidator\u003Cem\u003E控件\u003C\u002Fem\u003E对两个输入\u003Cem\u003E控件\u003C\u002Fem\u003E比较验证 \n71.如何使用CustomValidator\u003Cem\u003E控件\u003C\u002Fem\u003E自定义验证格式 \n72.如何使用ValidationSummary\u003Cem\u003E控件\u003C\u002Fem\u003E总结所有验证\u003Cem\u003E控件\u003C\u002Fem\u003E的错误信息 \n73.如何创建自定义功能的验证\u003Cem\u003E控件\u003C\u002Fem\u003E \n74.如何禁用服务器\u003Cem\u003E控件\u003C\u002Fem\u003E的验证功能 \n75.如何控制页面部分验证\u003Cem\u003E控件\u003C\u002Fem\u003E有效 \n76.如何实现\u003Cem\u003E控件\u003C\u002Fem\u003E即时验证功能 \n77.如何使用验证\u003Cem\u003E控件\u003C\u002Fem\u003E综合验证用户注册页面 \n78.如何验证DataGrid\u003Cem\u003E控件\u003C\u002Fem\u003E的编辑列 \n81.如何使用验证\u003Cem\u003E控件\u003C\u002Fem\u003E验证日期类型的输入(CompareValidator) \n81.如何使用验证\u003Cem\u003E控件\u003C\u002Fem\u003E验证日期类型的输入(CustomerValidator) \n81.如何使用验证\u003Cem\u003E控件\u003C\u002Fem\u003E验证日期类型的输入(RegularValidator) \n 第5章 高级Web\u003Cem\u003E控件\u003C\u002Fem\u003E \n82.如何在网页中使用Calendar Web\u003Cem\u003E控件\u003C\u002Fem\u003E显示和选择日期 \n83.如何在Calendar Web\u003Cem\u003E控件\u003C\u002Fem\u003E中控制个别日的内容及显示 \n84.如何在Calendar Web\u003Cem\u003E控件\u003C\u002Fem\u003E中控制用户日期选定 \n86.如何使用XML\u003Cem\u003E控件\u003C\u002Fem\u003E显示XML文件和进行XSLT转换 \n87.如何使用AdRotator Web\u003Cem\u003E控件\u003C\u002Fem\u003E制作广告发布程序-示例1 \n87.如何使用AdRotator Web\u003Cem\u003E控件\u003C\u002Fem\u003E制作广告发布程序-示例2 \n88.如何创建用户\u003Cem\u003E控件\u003C\u002Fem\u003E \n89.如何将Web窗体转换成用户\u003Cem\u003E控件\u003C\u002Fem\u003E \n90.如何实现动态加载用户\u003Cem\u003E控件\u003C\u002Fem\u003E \n92.如何使用\u003Cem\u003ETabS\u003C\u002Fem\u003E\u003Cem\u003Etrip\u003C\u002Fem\u003E Web和MultiP","createTime":"2009-03-02 15:59:31","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"5\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fzhangsan000000\u002F1059933\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"5\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fzhangsan000000\u002F1059933\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-1059933-bbs-90416529.264^v3^pc_relevant_bbs_down_v2_opensearchbbsnew\\\",\\\"dist_request_id\\\":\\\"1713519004769_44848\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"}],"staffDOList":[{"id":null,"communityId":148,"username":"community_29","userNickname":"API","roleCode":1,"status":1,"createUsername":"","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","createTime":"2021-05-12 18:06:01","updateTime":"2021-05-12 18:06:01","lastLoginTime":"2021-05-12 18:06:01"}],"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\u002F90416529","openUrl":"","isApp":false,"localUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F90416529","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":["90416529"],"deviceType":"pc","isSpider":"","hostname":["bbs.csdn.net"]},"basePath":"bbs.csdn.net\u002Fccloud\u002Ftopics\u002F90416529","hrefUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F90416529","active":0,"navBarFixed":false,"title":"送分啦!!!!一个关于TabStrip和Label控件的问题","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":148,"topicId":90416529},"keywords":"","description":"以下内容是CSDN社区关于送分啦!!!!一个关于TabStrip和Label控件的问题相关内容,如果想了解更多关于API社区其他内容,请访问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>