Ext中.多个tab页中的Form想同时提交怎么处理???

萧学森 2009-12-30 05:34:22
急急急~~~~~
...全文
301 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
DearJr 2011-06-02
  • 打赏
  • 举报
回复
form1.submit({
url:'aaa.do',
...
});

form2.submit({
url:'bbb.do',
...
});


这样写可吗?为什么我的只执行第一个,也就是form1.submit呢?
萧学森 2011-06-02
  • 打赏
  • 举报
回复
你调用form1.submit()当然只提交第一个...


我都忘了我这个贴子的事了..不好意思啊...09年的..汗...
萧学森 2009-12-31
  • 打赏
  • 举报
回复
3q.. 我已经解决了.....
woshifou 2009-12-30
  • 打赏
  • 举报
回复
学习。
  • 打赏
  • 举报
回复
N个tab都是一样提交的,只要拿到每个form对象,想怎么操作就这么操作!!
xiuyouxu 2009-12-30
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 xiuyouxu 的回复:]
在一个函数里写,给两个form定义变量名,不就可以提交了吗,每个form可以独立提交的
form1.submit({
url:'aaa.do',
...
}
form2.submit({
url:'bbb.do',
...
}
[/Quote]
改成
form1.submit({
url:'aaa.do',
...
});

form2.submit({
url:'bbb.do',
...
});
忘了括号了...
xiuyouxu 2009-12-30
  • 打赏
  • 举报
回复
在一个函数里写,给两个form定义变量名,不就可以提交了吗,每个form可以独立提交的
form1.submit({
url:'aaa.do',
...
}
form2.submit({
url:'bbb.do',
...
}
萧学森 2009-12-30
  • 打赏
  • 举报
回复
补充一下...两个TAb的From提交表单的路径不一样....
Ex4.0共2个压缩包特性,《ext js权威指南》 前 言 第1章 ext js 4开发入门 / 1 1.1 学习ext js必需的基础知识 / 1 1.2 json概述 / 3 1.2.1 认识json / 3 1.2.2 json的结构 / 3 1.2.3 json的例子 / 4 1.2.4 在javascript使用json / 4 1.2.5 在.net使用json / 8 1.2.6 在java使用json / 12 1.2.7 更多有关json的信息 / 15 1.3 ext js 4概述 / 15 1.4 ext js的开发工具的获取、安装与配置介绍 / 18 1.4.1 ext designer / 18 1.4.2 在visual studio实现智能提示 / 23 1.4.3 spket / 28 1.4.4 在eclipse实现智能提示 / 32 1.5 如何获得帮助 / 32 1.6 本章小结 / 33 .第2章 从“hello world”开始 / 34 2.1 获取ext js 4 / 34 2.2 配置使用ext js库 / 35 2.3 编写“hello world”程序 / 37 2.4 关于ext.onready / 38 2.5 关于ext.blank_image_url / 40 2.6 关于字体 / 42 2.7 ext js 4语法 / 42 2.8 本地化 / 60 2.9 为本书示例准备一个模板 / 60 2.10 本章小结 / 61 第3章 调试工具及技巧 / 62 3.1 使用firebug进行调试 / 62 3.2 在ie调试 / 76 3.2.1 使用debugbar和companion.js调试 / 76 3.2.2 使用ietester测试 / 80 3.2.3 在ie 8或ie 9调试 / 83 3.3 在chrome调试 / 84 3.4 调试工具的总结 / 84 3.5 调试技巧 / 85 3.6 本章小结 / 89 第4章 ext js的基础架构 / 90 4.1 ext js框架的命名空间:ext / 90 4.1.1 概述 / 90 4.1.2 apply和applyif方法 / 90 4.1.3 不推荐的extend方法 / 92 4.1.4 数据及其类型检测 / 95 4.1.5 其他的基础方法 / 99 4.2 为框架顺利运行提供支持 / 107 4.2.1 平台检测工具:ext.is / 107 4.2.2 当前运行环境检测工具:ext.supports / 109 4.3 ext js的静态方法 / 112 4.3.1 概述 / 112 4.3.2 ext.object的静态方法 / 113 4.3.3 ext.function的静态方法 / 120 4.3.4 ext.array的静态方法 / 127 4.3.5 ext.error的静态方法 / 133 4.4 深入了解类的创建及管理 / 135 4.4.1 开始创建类 / 135 4.4.2 创建类的类:ext.class / 137 4.4.3 所有继承类的基类:ext.base / 151 4.4.4 实现动态加载:ext.loader / 151 4.4.5 管理类的类:ext.classmanager / 159 4.4.6 类创建的总结 / 161 4.5 动态加载的路径设置 / 163 4.6 综合实例:面计算器 / 165 4.7 本章小结 / 169 第5章 ext js的事件及其应用 / 170 5.1 概述 / 170 5.2 浏览器事件 / 170 5.2.1 绑定浏览器事件的过程:ext.eventmanager / 170 5.2.2 封装浏览器事件:ext.eventobject / 179 5.2.3 移除浏览器事件 / 181 5.3 内部事件 / 184 5.3.1 内部事件对象:ext.util.event / 184 5.3.2 为组件添加事件接口:ext.util.observable / 188 5.3.3 为组件绑定事件 / 189 5.3.4 内部事件的触发过程 / 192 5.3.5 移除事件 / 194 5.4 特定功能的事件对象 / 196 5.4.1 延时任务:ext.util.delayedtask / 196 5.4.2 一般任务:ext.util.taskrunner与ext.taskmanager / 198 5.4.3 封装好的单击事件:ext.util.clickrepeater / 200 5.5 键盘事件 / 201 5.5.1 为元素绑定键盘事件:ext.util.keymap / 201 5.5.2 键盘导航:ext.util.keynav / 204 5.6 综合实例:股票数据的实时更新 / 205 5.7 本章小结 / 214 第6章 选择器与dom操作 / 215 6.1 ext js的选择器:ext.domquery / 215 6.1.1 选择器的作用 / 215 6.1.2 使用ext.query选择面元素 / 215 6.1.3 基本选择符 / 223 6.1.4 属性选择符 / 229 6.1.5 css属性值选择符 / 234 6.1.6 伪类选择符 / 235 6.1.7 扩展选择器 / 248 6.1.8 ext.domquery的使用方法 / 249 6.1.9 ext js选择器的总结 / 252 6.2 获取单一元素:ext.dom.element / 252 6.2.1 从错误开始 / 252 6.2.2 使用ext.get获取元素 / 253 6.2.3 使用ext.fly获取元素 / 256 6.2.4 使用ext.getdom获取元素 / 257 6.2.5 获取元素的总结 / 258 6.3 元素生成器:ext.dom.helper / 258 6.3.1 概述 / 258 6.3.2 使用createhtml或markup方法生成html代码 / 258 6.3.3 使用createdom方法生成dom对象 / 261 6.3.4 使用createtemplate方法创建模板 / 263 6.3.5 helper对象的使用方法 / 263 6.4 元素的操作 / 273 6.5 获取元素集合:ext.compositeelementlite与ext.compositeelement / 277 6.5.1 使用ext.select获取元素集合 / 277 6.5.2 ext.dom.compositeelement与ext.dom.compositeelementlite的区别 / 279 6.5.3 操作元素集合 / 279 6.6 综合实例:可折叠的面板accordion / 280 6.7 本章小结 / 283 第7章 数据交互 / 284 7.1 数据交互基础 / 284 7.1.1 ajax概述 / 284 7.1.2 封装ajax:ext.data.connection与ext.ajax / 284 7.1.3 使用ajax / 291 7.1.4 跨域获取数据:ext.data.jsonp / 295 7.1.5 为element对象提供加载功能:ext.elementloader / 295 7.1.6 为组件提供加载功能:ext.componentloader / 296 7.2 代理 / 299 7.2.1 代理概述 / 299 7.2.2 基本的代理:ext.data.proxy.proxy / 300 7.2.3 进行批量操作:ext.data.batch与ext.data.operation / 303 7.2.4 服务器端代理:ext.data.proxy.server / 305 7.2.5 使用ajax处理数据的代理:ext.data.proxy.ajax与ext.data.proxy.rest / 308 7.2.6 跨域处理数据的代理:ext.data.proxy.jsonp / 312 7.2.7 为ext.direct服务的代理:ext.data.proxy.direct / 312 7.2.8 客户端代理:ext.data.proxy.client / 314 7.2.9 从变量提取数据的代理:ext.data.proxy.memory / 314 7.2.10 使用浏览器存储的代理:ext.data.webstorageproxy、ext.data. sessionstorageproxy和ext.data.proxy.localstorage / 314 7.3 读取和格式化数据 / 315 7.3.1 概述 / 315 7.3.2 数据的转换过程:ext.data.reader.xml、ext.data.reader.json和ext.data.reader.array / 315 7.3.3 reader对象的配置项 / 321 7.3.4 格式化提交数据:ext.data.writer.writer、ext.data.writer.json和ext.data. writer.xml / 322 7.3.5 writer对象的配置项 / 325 7.4 数据模型 / 326 7.4.1 概述 / 326 7.4.2 数据类型及排序类型:ext.data.types与ext.data.sorttypes / 326 7.4.3 数据模型的骨架——字段:ext.data.field / 330 7.4.4 数据集:ext.util.abstractmixedcollection与ext.util.mixedcollection / 330 7.4.5 数据验证及错误处理ext.data.validations与ext.data.errors / 332 7.4.6 模型的关系:ext.data.association、ext.data.hasmanyassociation和ext.data.belongstoassociation / 334 7.4.7 管理数据模型:ext.abstractmanager与ext.modelmanager / 336 7.4.8 定义数据模型:ext.data.model / 336 7.4.9 数据模型的定义过程 / 337 7.4.10 数据模型的创建 / 340 7.4.11 数据模型的配置项、属性和方法 / 343 7.5 store / 344 7.5.1 概述 / 344 7.5.2 store对象的实例化过程 / 345 7.5.3 treestore对象的实例化过程 / 348 7.5.4 ext.data.store加载数据的方法 / 350 7.5.5 ext.data.treestore加载数据的方法 / 354 7.5.6 store的配置项 / 358 7.5.7 store的分 / 359 7.5.8 store的排序:ext.util.sorter与ext.util.sortable / 360 7.5.9 store的过滤:ext.util.filter / 363 7.5.10 store的分组:ext.util.grouper / 363 7.5.11 树节点:ext.data.nodeinterface与ext.data.tree / 364 7.5.12 store的方法 / 366 7.5.13 store的事件 / 368 7.5.14 store管理器:ext.data.storemanager / 369 7.6 综合实例 / 369 7.6.1 远程读取json数据 / 369 7.6.2 读取xml数据 / 378 7.6.3 store的数据操作 / 379 7.7 本章小结 / 384 第8章 模板与组件基础 / 385 8.1 模板 / 385 8.1.1 模板概述 / 385 8.1.2 ext.template的创建与编译 / 385 8.1.3 格式化输出数据:ext.string、ext.number、ext.date和ext.util.format / 389 8.1.4 超级模板:ext.xtemplate(包括ext.xtemplateparser和ext.xtemplatecompiler) / 393 8.1.5 模板的方法 / 396 8.2 组件的基础知识 / 396 8.2.1 概述 / 396 8.2.2 组件类的整体架构 / 397 8.2.3 布局类的整体架构 / 402 8.2.4 组件的创建流程 / 403 8.2.5 常用的组件配置项、属性、方法和事件 / 415 8.3 为组件添加功能 / 418 8.3.1 为元素添加阴影:ext.shadow与ext.shadowpool / 418 8.3.2 为组件提供阴影和shim功能:ext.layer / 419 8.3.3 让组件实现浮动功能:ext.util.floating / 420 8.3.4 记录组件状态:ext.state.stateful / 420 8.3.5 实现调整大小功能:ext.resizer.resizer与ext.resizer.resizetracker / 420 8.3.6 为组件提供拖动功能:ext.util.componentdragger / 421 8.3.7 为组件实现动画功能:ext.util.animate / 422 8.3.8 其他的组件辅助功能类 / 423 8.4 组件的管理 / 423 8.4.1 组件管理及查询:ext.componentmanager与ext.componentquery / 423 8.4.2 焦点管理:ext.focusmanager / 424 8.4.3 z-order管理:ext.zindexmanager与ext.windowmanager / 425 8.4.4 状态管理:ext.state.manager、ext.state.provider、ext.state.local-storageprovider和ext.state.cookieprovider / 426 8.5 综合实例 / 426 8.5.1 使用子模板 / 426 8.5.2 递归调用模板 / 428 8.6 本章小结 / 429 第9章 容器、面板、布局和视图 / 430 9.1 容器与布局的关系 / 430 9.2 容器 / 431 9.2.1 容器的创建过程:ext.container.abstractcontainer与ext.container.container / 431 9.2.2  ext.container.abstractcontainer和ext.container.container的配置项、属性、方法和事件 / 434 9.2.3 将body元素作为容器:ext.container.viewport / 435 9.3 面板 / 436 9.3.1 面板的结构 / 436 9.3.2 构件的放置:dockeditems / 438 9.3.3 面板标题栏构件:ext.panel.header与ext.panel.tool / 438 9.3.4 记录和恢复面板属性:ext.util.memento / 439 9.3.5 面板常用的配置项、方法和事件 / 439 9.4 布局 / 441 9.4.1 布局概述 / 441 9.4.2 布局的运行流程:ext.layout.layout / 441 9.4.3 容器类布局基类:ext.layout.container.container / 442 9.4.4 盒子布局、垂直布局与水平布局:ext.layout.container.box、ext.layout.container.vbox与ext.layout.container.hbox / 442 9.4.5 为盒子模型提供调整大小的功能:ext.resizer.splitter / 445 9.4.6 手风琴布局:ext.layout.container.accordion / 447 9.4.7 锚固布局:ext.layout.container.anchor / 448 9.4.8 绝对定位布局:ext.layout.container.absolute / 450 9.4.9 边框布局:ext.layout.container.border / 451 9.4.10 自动布局:ext.layout.container.auto / 453 9.4.11 表格布局:ext.layout.container.table / 454 9.4.12 列布局:ext.layout.container.column / 455 9.4.13 自适应布局:ext.layout.container.abstractfit与ext.layout.container.fit / 456 9.4.14 卡片布局:ext.layout.container.abstractcard与ext.layout.container.card / 456 9.5 标签面板 / 458 9.5.1 标签面板的构成及其运行流程:ext.tab.panel、ext.tab.bar与ext.tab.tab / 458 9.5.2 标签面板的配置项、属性、方法和事件 / 462 9.5.3 使用标签 / 463 9.5.4 可重用的标签 / 465 9.6 视图与选择模型 / 465 9.6.1 视图与选择模型概述 / 465 9.6.2 视图的运行流程:ext.view.abstractview与ext.view.view / 466 9.6.3 选择模型的工作流程 / 475 9.6.4 选择模型的配置项、属性、方法和事件 / 480 9.6.5 视图的配置项、属性、方法和事件 / 482 9.6.6 使用视图 / 484 9.7 面布局设计 / 491 9.8 综合实例 / 492 9.8.1 布局设计实例:仿eclipse界面 / 492 9.8.2 在单面应用使用卡片布局实现“面”切换 / 496 9.9 本章小结 / 498 第10章 重构后的grid / 500 10.1 grid的基类及其构成 / 500 10.1.1 概述 / 500 10.1.2 表格面板的运行流程:ext.panel.table / 500 10.1.3 表格视图的运行流程:ext.view.table与ext.view.tablechunker / 505 10.1.4 列标题容器的运行流程:ext.grid.header.container / 508 10.1.5 列标题的运行流程:ext.grid.column.column / 510 10.1.6 虚拟滚动条的工作原理:ext.grid.pagingscroller / 511 10.1.7 锁定列的运行流程:ext.grid.lockable与ext.grid.lockingview / 516 10.2 使用grid / 520 10.2.1 最简单的grid / 520 10.2.2 列的配置项 / 521 10.2.3 自定义单元格的显示格式 / 523 10.2.4 通过列对象定义单元格的显示格式 / 525 10.2.5 设置行的背景颜色 / 532 10.2.6 列标题的分组 / 533 10.2.7 使用锁定列 / 534 10.2.8 grid的配置项、属性、方法和事件 / 535 10.3 grid的附加功能 / 537 10.3.1 概述 / 537 10.3.2 附加功能基类:ext.grid.featrue.featrue / 537 10.3.3 为行添加附加信息:ext.grid.featrue.rowbody / 538 10.3.4 数据汇总功能:ext.grid.featrue.abstractsummary与ext.grid.featrue. summary / 539 10.3.5 分组功能:ext.grid.featrue.grouping / 543 10.3.6 分组汇总功能:ext.grid.featrue.groupingsummary / 545 10.4 可编辑的grid / 546 10.4.1 概述 / 546 10.4.2 grid实现可编辑功能的运行流程:ext.grid.plugin.editing / 547 10.4.3 单元格编辑的运行流程:ext.grid.plugin.cellediting、ext.grid.celleditor与ext.editor / 550 10.4.4 行编辑的运行流程:ext.grid.plugin.rowediting与ext.grid.roweditor / 556 10.4.5 在grid使用单元格编辑模式 / 561 10.4.6 在grid使用行编辑模式 / 562 10.4.7 grid编辑插件的配置项、属性、方法和事件 / 563 10.5 关于列表视图:listview / 564 10.6 属性grid / 564 10.6.1 概述 / 564 10.6.2 使用属性grid / 564 10.6.3 自定义编辑组件 / 565 10.6.4 propertygrid的配置项、属性、方法和事件 / 566 10.7 综合实例 / 567 10.7.1 使用不同选择模型的grid以及设置默认选择行 / 567 10.7.2 grid的本地排序和过滤 / 569 10.7.3 使用分工具条(pagingtoolbar)实现远程分、排序和过滤 / 570 10.7.4 使用分滚动条(pagingscroller)实现远程分、排序和过滤 / 574 10.7.5 使用cellediting实现数据的增删改 / 578 10.7.6 使用rowediting实现数据的增删改 / 587 10.7.7 主从表的显示 / 589 10.8 本章小结 / 595 第11章 与grid同源的树 / 597 11.1 树的构成 / 597 11.1.1 概述 / 597 11.1.2 树面板的运行流程:ext.tree.panel / 597 11.1.3 treestore的运行流程:ext.data.treestore / 600 11.1.4 treecolumn的运行流程:ext.tree.column / 602 11.1.5 视图的运行流程:ext.tree.view与ext.data.nodestore / 602 11.1.6 树的选择模型:ext.selection.treemodel / 603 11.2 树的使用 / 603 11.2.1 一个最简单的树 / 603 11.2.2 树节点的默认字段 / 603 11.2.3 为树节点添加附加字段 / 604 11.2.4 显示多列数据(treegrid效果) / 605 11.2.5 在树使用复选框 / 605 11.2.6 树的配置项、属性、方法和事件 / 607 11.3 综合实例 / 608 11.3.1 树的远程加载 / 608 11.3.2 树的动态加载及节点维护 / 610 11.3.3 xml树及节点维护 / 617 11.3.4 使用树动态控制grid的显示 / 622 11.4 本章小结 / 625 第12章 表单 / 626 12.1 表单的构成及操作 / 626 12.1.1 表单面板的运行流程:ext.form.panel与ext.form.fieldancestor / 626 12.1.2 表单面板的配置项、属性、方法和事件 / 628 12.1.3 表单的管理:ext.form.basic / 629 12.1.4 basicform的配置项、属性、方法和事件 / 635 12.1.5 表单的操作:ext.form.action.action / 636 12.1.6 加载操作的运行流程:ext.form.action.load与ext.form.action.directload / 637 12.1.7 提交操作的运行流程:ext.form.action.submit、ext.form.action.directsubmit与ext.form.action.standardsubmit / 641 12.1.8 字段的构成 / 643 12.1.9 basefield的配置项、属性、方法和事件 / 643 12.1.10 常用的验证函数:ext.form.field.vtypes / 647 12.2 使用字段 / 647 12.3 使用trigger类字段 / 664 12.3.1 具有单击功能的字段:ext.form.field.trigger / 664 12.3.2 实现微调功能的spinner字段 / 665 12.3.3 使用numberfield字段 / 666 12.3.4 下拉选择类字段的基类:ext.form.field.picker / 667 12.3.5 使用datefield字段 / 667 12.3.6 使用timefield字段 / 669 12.4 使用combobox字段 / 669 12.4.1 概述 / 669 12.4.2 boundlist对象的运行流程 / 670 12.4.3 combobox字段的配置项、属性、方法和事件 / 671 12.4.4 最简单的combobox / 672 12.4.5 自定义列表显示格式的combobox / 673 12.4.6 动态调整combobox的列表数据 / 674 12.4.7 实现combobox的联动 / 676 12.4.8 使用combobox的查询功能 / 684 12.4.9 设置combobox的默认值 / 688 12.5 表单的验证和加载数据 / 690 12.5.1 表单的验证及错误显示方式 / 690 12.5.2 为表单加载数据 / 695 12.6 在表单使用布局 / 701 12.6.1 分列显示表单的字段 / 701 12.6.2 使用fieldset作为列容器 / 703 12.6.3 使用两列布局加htmleditor的表单 / 704 12.6.4 在表单使用标签 / 705 12.7 综合实例:实现products表的管理功能 / 706 12.8 本章小结 / 715 第13章 窗口 / 716 13.1 窗口:ext.window.window. / 716 13.1.1 窗口的构成 / 716 13.1.2 窗口的配置项、属性、方法和事件 / 716 13.1.3 使用窗口 / 718 13.1.4 在窗口内使用布局 / 719 13.2 信息提示窗口:ext.window.messagebox / 720 13.2.1 概述 / 720 13.2.2 信息提示窗口的构成 / 720 13.2.3 使用信息提示窗口 / 722 13.2.4 信息提示窗口按钮的本地化 / 723 13.2.5 使用alert方法 / 724 13.2.6 使用confirm方法 / 724 13.2.7 使用progress方法 / 725 13.2.8 使用prompt方法 / 726 13.2.9 使用wait方法 / 727 13.2.10 使用信息提示窗口要注意的问题 / 727 13.3 综合实例:实现登录窗口 / 729 13.4 本章小结 / 733 第14章 按钮、菜单与工具条 / 734 14.1 按钮 / 734 14.1.1 按钮的构成:ext.button.button / 734 14.1.2 按钮的配置项、属性、方法和事件 / 734 14.1.3 使用按钮 / 736 14.1.4 带分割线的按钮:ext.button.split / 737 14.1.5 多状态按钮:ext.button.cycle / 737 14.1.6 按钮组:ext.container.buttongroup / 738 14.2 菜单及菜单项 / 739 14.2.1 ext js的菜单(menu对象)是什么 / 739 14.2.2 菜单管理器:ext.menu.manager / 740 14.2.3 菜单项:ext.menu.item / 740 14.2.4 可复选的菜单项:ext.menu.checkitem / 741 14.2.5 菜单分隔条:ext.menu.separator / 741 14.2.6 颜色选择器菜单:ext.menu.colorpicker / 742 14.2.7 日期选择菜单:ext.menu.datepicker / 742 14.2.8 使用菜单 / 742 14.3 工具栏及工具栏组件 / 743 14.3.1 工具栏:ext.toolbar.toolbar / 743 14.3.2 非交互式工具栏条目的基类:ext.toolbar.item / 743 14.3.3 文本项:ext.toolbar.textitem / 744 14.3.4 填充项:ext.toolbar.fill / 744 14.3.5 工具栏分隔条:ext.toolbar.separator / 744 14.3.6 空白项:ext.toolbar.spacer / 744 14.3.7 分工具栏:ext.toolbar.paging / 744 14.3.8 使用工具栏 / 747 14.4 使用ext.action / 747 14.4.1 概述 / 747 14.4.2 action对象配置项和方法 / 748 14.4.3 使用示例 / 748 14.5 综合实例:在grid使用右键菜单 / 750 14.6 本章小结 / 752 第15章 图形与图表 / 753 15.1 基础知识 / 753 15.1.1 svg简介 / 753 15.1.2 vml简介 / 754 15.2 图形介绍 / 755 15.2.1 概述 / 755 15.2.2 画布的工作流程:ext.draw.component / 755 15.2.3 图形引擎及接口:ext.draw.surface、ext.draw.engine.svg和ext.draw.engine.vml / 757 15.2.4 画笔:ext.draw.sprite / 760 15.2.5 图层:ext.draw.compositesprite / 760 15.2.6 调色板:ext.draw.color / 760 15.2.7 辅助对象:ext.draw.draw与ext.draw.matrix / 760 15.3 使用图形功能 / 760 15.3.1 简单的开始 / 760 15.3.2 drawcomponent对象的配置项、属性、方法和事件 / 761 15.3.3 surface对象的配置项、属性、方法和事件 / 761 15.3.4 drawsprite对象的配置项、属性、方法和事件 / 762 15.3.5 compositesprite对象的配置项、属性、方法和事件 / 763 15.3.6 使用基本图形 / 764 15.3.7 使用图片 / 765 15.3.8 使用路径 / 766 15.3.9 移动、旋转和缩放图形 / 767 15.3.10 使用渐变效果 / 770 15.3.11 使用图层 / 771 15.4 图表介绍 / 772 15.4.1 概述 / 772 15.4.2 图表的工作流程 / 773 15.5 使用图表 / 776 15.5.1 从一个简单例子开始 / 776 15.5.2 坐标轴的配置项 / 777 15.5.3 series对象的配置项、属性、方法和事件 / 779 15.5.4 折线图的配置项 / 780 15.5.5 显示多个折线图及使用图例 / 782 15.5.6 使用面积图 / 783 15.5.7 简单条形图(bar和column chart)及使用标签(label对象) / 785 15.5.8 堆积条形图 / 787 15.5.9 分组条形图 / 788 15.5.10 自定义条形颜色 / 789 15.5.11 使用散点图 / 789 15.5.12 使用饼图 / 791 15.5.13 自定义饼块颜色 / 792 15.5.14 使用表盘图 / 792 15.5.15 使用雷达图 / 795 15.5.16 使用时间轴 / 796 15.5.17 实现实时动态的图表 / 797 15.5.18 使用组合图 / 800 15.5.19 在图表使用背景 / 801 15.5.20 在图表自定义主题 / 803 15.6 本章小结 / 805 第16章 其他组件及实用功能 / 806 16.1 其他组件 / 806 16.2 使用滑块 / 812 16.3 使用提示信息 / 814 16.4 实用功能 / 822 16.5 本章小结 / 826 第17章 可简化通信的ext.direct / 827 17.1 准备工作 / 827 17.2 ext.direct的工作原理及构成 / 827 17.2.1 工作原理 / 827 17.2.2 ext.direct的构成 / 828 17.2.3 remotingprovider对象的具体工作流程 / 829 17.2.4 pollingprovider对象的具体工作流程 / 838 17.3 配置ext.direct的使用环境 / 839 17.3.1 概述 / 839 17.3.2 .net环境的配置 / 839 17.3.3 java环境的配置 / 842 17.4 使用ext.direct / 846 17.4.1 概述 / 846 17.4.2 使用directproxy及进行curd操作 / 846 17.4.3 使用ext.direct实现树的动态加载及节点维护 / 854 17.4.4 使用directload为表单加载数据 / 858 17.4.5 使用directsubmit提交表单及使用session / 863 17.4.6 使用ext.direct上传文件 / 866 17.4.7 使用pollingprovider对象 / 868 17.4.8 错误处理 / 871 17.5 本章小结 / 872 第18章 动画功能 / 873 18.1 动画功能的构成及工作流程 / 873 18.1.1 概述 / 873 18.1.2 动画功能的工作流程:ext.fx.anim / 874 18.1.3 分步动画的工作流程:ext.fx.animator / 877 18.2 使用动画 / 880 18.2.1 由最简单的动画开始 / 880 18.2.2 过渡效果使用的功能函数介绍 / 880 18.2.3 使用分步动画 / 882 18.2.4 注意的问题 / 883 18.3 在element对象使用动画 / 883 18.4 本章小结 / 888 第19章 拖放功能 / 889 19.1 拖放功能的构成及工作流程 / 889 19.1.1 概述 / 889 19.1.2 dragdropmanager对象的工作流程 / 891 19.1.3 注册节点:ext.dd.registry / 893 19.1.4 一般拖动功能的工作流程:ext.dd.dd / 894 19.1.5 dragsource对象的工作流程 / 897 19.1.6 droptarget对象的工作流程 / 898 19.1.7 dragzone对象的工作流程 / 899 19.1.8 dropzone对象的工作流程 / 899 19.2 使用拖放功能 / 899 19.2.1 最简单的拖动效果 / 899 19.2.2 使用dragsource对象与droptarget对象 / 900 19.2.3 使用dragzone对象与dropzone对象(使用registry对象) / 902 19.2.4 使用dragzone对象与dropzone对象(不使用registry对象) / 903 19.2.5 通过拖动实现节点排序 / 904 19.2.6 使用gridviewdropzoneplugin插件 / 905 19.2.7 使用treeviewdragdropplugin插件 / 907 19.2.8 关于grid和tree拖动后的数据保存问题 / 910 19.3 本章小结 / 910 第20章 扩展与插件 / 911 20.1 扩展与插件的区别 / 911 20.2 扩展与插件如何选择 / 911 20.3 如何编写扩展 / 911 20.3.1 命名空间 / 911 20.3.2 定义扩展 / 912 20.3.3 定义别名 / 912 20.3.4 定义备用名 / 912 20.3.5 要求加载的类:requires与uses / 912 20.3.6 混入功能 / 913 20.3.7 构造函数与initcomponent方法 / 913 20.3.8 静态属性和方法与单件模式 / 913 20.3.9 可自动生成set和get方法的属性与initconfig方法 / 914 20.3.10 在扩展常用的方法 / 914 20.3.11 编写扩展:treecombobox / 914 20.4 如何编写插件 / 920 20.4.1 概述 / 920 20.4.2 abstractplugin对象 / 921 20.4.3 插件的别名 / 921 20.4.4 编写插件:rowcolor / 922 20.5 扩展和插件介绍 / 923 20.5.1 概述 / 923 20.5.2 本地分代理:ext.ux.data.pagingmemoryproxy / 923 20.5.3 标签滚动菜单:ext.ux.tabscrollermenu / 925 20.5.4 编辑器tinymce / 926 20.6 本章小结 / 928 第21章 主题开发 / 929 21.1 准备工作 / 929 21.1.1 安装ruby / 929 21.1.2 安装compass / 930 21.1.3 sass介绍 / 931 21.2 为ext js 4创建新主题 / 933 21.2.1 概述 / 933 21.2.2 目录结构 / 933 21.2.3 修改配置 / 933 21.2.4 编译 / 935 21.2.5 测试主题 / 935 21.3 通过ui配置项设置组件样式 / 937 21.4 本章小结 / 937 第22章 mvc应用架构 / 938 22.1 mvc应用架构的构成及工作流程 / 938 22.1.1 构成 / 938 22.1.2 控制器的工作流程:ext.app.controller / 938 22.1.3 application对象的工作流程 / 940 22.2 一步一步实现mvc框架 / 942 22.2.1 概述 / 942 22.2.2 创建目录 / 942 22.2.3 创建首 / 942 22.2.4 创建启动脚本:app.js / 943 22.2.5 定义登录对话框 / 944 22.2.6 创建应用脚本:application.js / 948 22.2.7 创建viewport视图 / 949 22.2.8 菜单视图及控制器 / 950 22.2.9 实现订单管理 / 952 22.2.10 实现产品管理 / 958 22.2.11 示例效果 / 969 22.3 本章小结 / 970 附录 简写类名与ext js类名对照表 / 971
前言 第1章 认识ExtJS 1.1 ExtJS的精彩表现 1.2 ExtJS的前世今生 1.3 是否真的需要学习ExtJS 1.4 ExtJS4.0新特性 1.5 ExtJSUI组件基础 1.6 了解一下类似技术 1.7 本章小结 第2章 开始ExtJS之旅 2.1 认识ExtJS的开发包 2.2 也从Helloworld开始 2.3 ExtJS的基本概念 2.4 非常有用的开发工具 2.4.1 开发插件spket 2.4.2 FullSource 2.4.3 MicrosoftScriptDebugger 2.5 ExtJS对原有JavaScript对象的扩展 2.5.1 Ext.Array 2.5.2 Ext.Date 2.5.3 Ext.Function 2.5.4 Ext.Number 2.5.5 Ext.String 2.5.6 Ext.Object 2.6 本章小结 第3章 ExtJS4.0的基本功能 3.1 ExtJS组件配置说明 3.1.1 JSON介绍 3.1.2 ExtJS组件配置方式介绍 3.2 信息提示框组件介绍 3.2.1 认识Ext.window.MessageBox 3.2.2 Ext.MessageBox.alert() 3.2.3 Ext.MessageBox.confirm() 3.2.4 Ext.MessageBox.prompt() 3.2.5 Ext.MessageBox.wait() 3.2.6 Ext.MessageBox.show() 3.2.7 Ext.window.MessageBox的其他功能 3.3 进度条组件介绍 3.3.1 认识Ext.ProgressBar 3.3.2 手工模式的进度条 3.3.3 自动模式的进度条 3.3.4 自定义样式的进度条样式 3.4 实现工具栏和菜单栏 3.4.1 认识Ext.toolbar.Toolbar 3.4.2 只包含按钮的简单工具栏 3.4.3 包含多种元素的复杂工具栏 3.4.4 启用和禁用工具栏 3.4.5 认识Ext.menu.Menu菜单 3.4.6 最简单的菜单栏 3.4.7 创建二级或多级菜单 3.4.8 将更多组件加入菜单 3.4.9 具有选择框的菜单 3.5 本章小结 第4章 最常用的表单 4.1 表单及表单元素 4.1.1 了解Ext.form.Basic基本表单 4.1.2 认识Ext.form.Panel表单面板 4.1.3 Ext.form.field.Base基础表单字段 4.1.4 Ext.form.field.Text文本域 4.1.5 Ext.form.field.TextArea文本区 4.1.6 Ext.form.field.Number数字输入框 4.1.7 Ext.form.field.Checkbox复选框和Ext.form.field.Radio单选框 4.1.8 Ext.form.CheckboxGroup和Ext.form.RadioGroup 4.1.9 Ext.form.field.Trigger触发字段 4.1.10 Ext.form.field.Spinner微调字段 4.1.11 Ext.form.field.Picker拾取器字段 4.1.12 Ext.form.field.ComboBox组合框 4.1.13 Ext.form.field.Time时间选择框 4.1.14 Ext.form.field.Date日期选择框 4.1.15 Ext.form.field.Hidden隐藏字段 4.1.16 Ext.form.field.HtmlEditor编辑器字段 4.1.17 Ext.form.field.Display只读文本字段 4.1.18 Ext.form.Label标签字段 4.1.19 Ext.form.FieldSet字段集 4.1.20 Ext.form.FieldContainer容器字段 4.1.21 Ext.form.field.File文件上传字段 4.2 实现表单验证 4.2.1 常见的验证类型 4.2.2 表单验证(VType) 4.2.3 自定义VType验证 4.3 表单的提交和加载 4.3.1 Ext.form.action.Action基础 4.3.2 Ajax模式的表单数据加载 4.3.3 Ajax模式的表单数据提交 4.3.4 标准模式的表单数据提交 4.3.5 使用Direct技术 4.4 本章小结 第5章 面板及布局类 5.1 面板panel 5.1.1 认识Ext.panel.Panel 5.1.2 Ext.panel.Panel的主要功能 5.1.3 使用Ext.panel.Panel 5.2 标准布局类 5.2.1 Auto自动布局 5.2.2 Fit自适应布局 5.2.3 Accordion折叠布局 5.2.4 Card卡片式布局 5.2.5 Anchor锚点布局 5.2.6 Absolute绝对位置布局 5.2.7 CheckboxGroup复选框组布局 5.2.8 Column列布局 5.2.9 Table表格布局 5.2.1 0Border边框布局 5.2.1 1Box盒布局 5.3 使用ViewPort 5.4 Ext.tab.Panel签 5.5 本章小结 第6章 常用工具类与函数 6.1 非常有用的Ext.core.Element 6.2 Ext常用函数 6.2.1 Ext.onReady() 6.2.2 Ext.get() 6.2.3 Ext.select() 6.2.4 Ext.query() 6.2.5 Ext.getCmp() 6.2.6 Ext.getDom() 6.2.7 Ext.isEmpty() 6.2.8 Ext.namespace() 6.2.9 Ext.each() 6.2.1 0Ext.apply() 6.2.1 1Ext.encode() 6.2.1 2Ext.htmlDecode() 6.2.1 3Ext.typeOf() 6.3 Ext.core.DomHelper 6.3.1 Ext.core.DomHepler.append() 6.3.2 Ext.core.DomHelper.applyStyles() 6.3.3 createTemplate() 6.3.4 insertAfter() 6.3.5 insertBefore() 6.3.6 insertFirst() 6.3.7 insertHtml() 6.3.8 overwrite() 6.4 Ext.core.DomQuery 6.4.1 compile() 6.4.2 filter() 6.4.3 is() 6.4.4 jsSelect() 6.4.5 selectNode() 6.5 Ext.util.CSS 6.5.1 createStyleSheet() 6.5.2 getRule() 6.5.3 swapStyleSheet() 6.5.4 removeStyleSheet() 6.6 Ext.util.ClickRepeater 6.6.1 click() 6.6.2 mousedown() 6.6.3 mouseup() 6.7 Ext.util.DelayedTask提供setTimeout的简单替代 6.7.1 cancle() 6.7.2 delay() 6.8 Ext.util.Format提供常用的格式化方法 6.8.1 ellipsis() 6.8.2 capitalize() 6.8.3 date() 6.8.4 htmlEncode() 6.8.5 htmlDecode() 6.8.6 stripTags() 6.8.7 substr() 6.8.8 lowercase() 6.8.9 number() 6.8.10 round() 6.9 Ext.util.JSON编码和解码Json对象 6.9.1 decode() 6.9.2 encode() 6.10 Ext.util.MixedCollection 6.10.1 向集合加入对象 6.10.2 将数组的对象加入到集合 6.10.3 移除集合的对象 6.10.4 克隆集合 6.10.5 匹配集合关联对象 6.10.6 迭代集合的对象调用指定的方法 6.10.7 获取集合的对象 6.10.8 该类的其他一些有用的方法 6.10.9 该类重要的事件(Events) 6.11 Ext.util.TaskRunner 6.11.1 构造函数 6.11.2 启动一个线程start() 6.11.3 停止一个线程stop() 6.11.4 停止所有的线程stopAll() 6.12 Ext.util.TextMetrics得到块状化文本规格 6.12.1 块的绑定 6.12.2 实例化对象 6.12.3 获取文本的高度 6.12.4 获取文本的宽、高 6.12.5 获取文本的宽度 6.12.6 获取指定节点内文本块的宽、高 6.12.7 指定文本块的宽 6.13 Ext.KeyNav为元素提供简单的按键处理方法 6.13.1 实例化一个键盘绑定对象 6.13.2 废弃原有键盘绑定 6.13.3 将废弃的键盘绑定重新生效 6.14 Ext.KeyMap提供更灵活强大的对按键的处理方法 6.14.1 构造函数 6.14.2 给对象添加键盘绑定 6.14.3 废弃已绑定到KeyMap的配置 6.14.4 将KeyMap或废弃的配置重新生效 6.14.5 获取当前KeyMap配置是否为有效 6.14.6 事件绑定函数 6.15 本章小结 第7章 让ExtJS开始响应事件 第8章 常见Web框架的ExtJS改造 第9章 ExtJS对Ajax的支持 第10章 增强型模板 第11章 数据模型 第12章 Grid组件 第13章 Tree组件 第14章 ExtJS与服务端框架的整合 第15章 主题 第16章 Ext.Direct 第17章 Draw图形 第18章 Chart图表 附录A
这个文档的话题与解决方案, 几乎全部来自 UniGUI 的交流群, 群活跃的 BDS2007、 cmj 等人,给了众多使用 UniGUI 的人很多帮助。 这个文档, 主要是学习与方便后来之人, 文档积累的起因是严肃而正式的, 因为每个人 都有学习的需求;但文档的所谓版权、著述, 我希望它是有公益色彩的东西,如有哪位不希 望解决方案不出现在这里,请您告知。 此外, 就是期待大家都能把自己的一些经验, 给指导和帮助后来人的东西, 在不影响您 正常工作与其他事情的前提下,奉献出来。至于正确与错误、高超或低下,无关大体。 目 录 1. 事件的代码在服务器端和客户端,哪一端执行? ........................................................... 3 2. 为什么 UniGUI 控件在 IE显示的字体会变小、模糊? .................................................... 3 3. 在浏览器端不能使用 ShowMessage() .................................................................................... 5 4. 修改工程文件,使 exe 程序编译成 dll .................................................................................. 6 5. UniGUI 开发的 dll 如何发布 .................................................................................................... 7 6. uniGUI0.94 以 EXE形式发布程序的布署方法 ..................................................................... 13 7. uniGUI 执行程序部署有 3 种形式 ......................................................................................... 14 8. 在 UniGUI 里使用 ADO 的设置 .............................................................................................. 16 9. MainModule 怎样得到 js 变量的值 ...................................................................................... 16 10. TUniServerModule 和 TUniMainModule 这两模块有何区别 ....................................... 16 11. MainModule 里一般放什么, ServerModule 一般放什么? ....................................... 17 12. 主窗体的标题怎么去掉 ................................................................................................. 17 13. 用 ExtEvent 打开链接和下载文件 ................................................................................. 17 14. WebApplication 显示对话框 .......................................................................................... 17 15. Uni 的 UniChart 的 Series增删 .................................................................................. 17 16. 怎样给每一个在线用户建立一套变量,在用户断开后立即清除 ............................. 18 17. TUniHiddenPanel 的作用 ................................................................................................ 18 18. UniDBGrid 如何转为 Excel供下载? ............................................................................. 18 19. uniGUI 实现 Excel的导出 .............................................................................................. 18 20. UniDBGrid Excel文件下载 .............................................................................................. 19 21. Excel文件导入系统 ........................................................................................................ 21 22. 文件转档与下载 ............................................................................................................. 21 23. Send File()应用 ............................................................................................................... 21 24. UniGUI 的 Canvas使用 ................................................................................................... 22 25. 动态生成 TTabSheet or TUniTabSheet ........................................................................... 22 26. UniGUI 如果获得 Session情况 .................................................................................. 23 27. UniGUI Func 之 Sessions ............................................................................................... 23 28. uniGUI 通过 SessionList操作另外的登录用户 ............................................................ 24 29. UniGui 如何监听 Session的开始与结束 ................................................................... 25 30. UniGUI 如何禁止关闭新窗口 ........................................................................................ 27 31. UniGUI 控件类名的变化 ............................................................................................ 27 32. 再议 UniGUI 使用 Grid+Rport 报表控件 (推荐此方法 ) ............................................. 28 33. UniGUI 的布局面板控件 TUniRegionPanel ................................................................... 28 34. UniGUI 使用报表 Grid+Report 的方法之一 (静态调用 ) ................................................ 28 35. UniGUI 使用报表 Grid+Report 的方法之二 (动态调用 ) ................................................ 28 36. UniGUI Cookies 使用文汉字的方法 ...................................................................... 28 37. UniGUI 如何实现压缩传输数据? ................................................................................ 29 38. UniGUI 的 ShowModal .................................................................................................... 29 39. UniGUI 前台用户如何在软件点击一个按钮打开浏览器并打开地址? ................ 29 40. How To Make Caption In UniGUI? ................................................................................. 30 41. 在 UniGUI 的 UniHtmlFrame 不能使用的 HTML 标签 .............................................. 30 42. 利用 UniGUI 的 TUniPageControl 实现多面 .......................................................... 30 43. UniGUI TreeView 处理 .................................................................................................... 31 44. UniGUI 设置超时 ........................................................................................................... 31 45. UniGUI 如何实现登陆面 ............................................................................................ 31 46. UniGUI 如何实现超链接 ................................................................................................ 32 47. 从 ASP网站登录到 UniGUI ....................................................................................... 32 48. UniGUI 数据库初始化要放到 MainModule 里 ............................................................. 32 49. UniGUI Cookies ................................................................................................................ 32 50. Form Inheritance ............................................................................................................. 33 51. UniGUI 组件的 Client JavaScript Delphi 组件之间的操作 ......................................... 33 52. JS能取 Delphi 控件的值? ............................................................................................ 34 53. 写 js 的注意 .................................................................................................................... 34 54. unigui 结合 JS方法记录 ................................................................................................. 34 55. JS,Jquery获取各种屏幕的宽度和高度 ......................................................................... 35 56. uniGUI 动态建立 Form 及释放 ...................................................................................... 37 57. uniGUI 经验两则 uniTimer uniHtmlFrame .................................................................... 37 58. uniGUI 使用百度地图 api 进行标注 .............................................................................. 37 59. fileupload 的问题 ........................................................................................................... 38 60. unigui unidbgrid 显示列的合计值 ................................................................................. 38 61. UniGui 设置 uniEdit 控件的 fieldLabel ,emptyTextExtjs 属性 .............................. 40 62. uniGUI 用 Grid++Report 报表插件设计保存报表 (For unigui ver:0.95.0.1045) ............ 40 63. UniGUI 的 TUniLoginForm 窗口自定义背景色 .............................................................. 46 64. uniGUI 显示 Warning: Form must be shown after it is created 的解决办法 ................. 46 65. 界面上的快捷方式 ......................................................................................................... 46 66. 调用 WebService............................................................................................................. 47 67. TUniTreeView 的 CheckBox ............................................................................................ 49 68. 通过 URL来获取相关参数 ............................................................................................ 52 69. uniDBGrid 实行多选表格行 ........................................................................................... 52 70. UniDBGrid 增加显示记录数的 label 及隐藏 refresh 按钮 ............................................ 56 71. 对 UniDBGrid 的单元格操作 .......................................................................................... 57 72. DBGrid 多选后计算问题(是否可以作为参考?) .................................................... 58 73. UniDBGrid 选择字段 Boolean 处理 ................................................................................ 59 74. UniDBGrid 自带 MultiSelect 无法使用【最新版可以】 ............................................... 60 75. 如何打开 URL,让系统看起来舒服点 ......................................................................... 61 76. 如何修改 UniGUI 下的文信息 ................................................................................... 62 77. 如何实现 UniDBGrid 下字段显示按钮 .......................................................................... 62 78. 如何实现 UniDBGrid 下字段自动换行 .......................................................................... 62 79. 如何结合 kbmMW .......................................................................................................... 63 80. 如何规避浏览器访问时 ajax 异常 ................................................................................ 63 81. 事件操作时,如果出现等待效果 ................................................................................. 63 82. 登录面和主面切换之间碰到的异常 ..................................................................... 63 83. 让 Page 切换 Tab效果稍微好一点 ........................................................................... 64 84. UniImage 可以嵌入 PNG图片 ....................................................................................... 64 85. UniImage 自带导入 PNG图片的问题 ........................................................................... 65
ExtAspNet - ExtJS based ASP.NET Controls with Full AJAX Support ExtAspNet是一组专业的Asp.net控件库,拥有原生的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的一个bug,比如设置{0:yy-MM-dd HH:mm}时没有效果。 -修正下拉列表控件不能绑定DataTable的BUG(feedback:RedOcean)。 -增加土耳其语言资料文件(feedback:abdullaharslan)。 -Grid的BoundField增加NullDisplayText属性,用于处理数据库的null值,如果没有设置则默认为空字符串。 -修正DatePicker的一个bug(31/01/2010将会返回NULL)使用DateFormatString来生成SelectedDate属性(feedback:OktaEndy)。 -修正extjs最新版本(v3.2.2)的一个bug,如果下拉列表存在两个相同的Text,则SelectedValue返回值永远是第一个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控件将不在依赖ViewState,减少1/4左右的HTTP数据传输量。 -控件和示例的增强。 +2010-03-28 v2.2.1 +为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。 -隐藏示例首最外层RegionPanel的边框ShowBorder="false"。 +集成Extjs最新版本v3.1.1。 -增加一个新的Theme - Access。 -修正了Firefox下Zoom In/Out时面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax提交)(feedback:261629698)。 +TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。 -增加示例tabstrip/tabstrip_addtab.aspx。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window控件更新。 -关闭按钮默认直接关闭,不会弹出确认对话框。 -GetConfirmFormModifiedHideReference的函数的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居,而不是黄金分割位置。 +Button, Window等控件弹出位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后一个参数target变为枚举类型。 -Alert.GetShowReference的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Extjs最新版本v3.1.0。 -修正灰色皮肤的CSS问题。 -修正Grid的列名不能包含文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏ExtAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其的Close全部改为Hide。 -增加TabStripTab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocumentIcon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时会出现空白面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid的一个JS问题(feedback:lqm4108)。 -修正Alert消息引号未编码导致的JS错误(feedback:sun1299shine)。 +集成extjs3.0.3。 -修正弹出对话框的宽度计算错误(会保持最小的状态)。 -增加新的皮肤Gray。 -为示例工程添加改变语言和皮肤的下拉列表。 -为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。 +2009-12-01 v2.1.7 -增加示例(iframe/parent_postback_run3.aspx),如何通过简单的Javascript代码回发父面(feedback:eroach)。 -修正一些书写错误(feedback:bmck)。 -从Region控件删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加国的省市县三级联动示例(data/shengshixian.aspx)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程会重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。 +2009-11-26 v2.1.6 +修正动态创建Grid列的BUG(feedback:gxpan)。 -增加示例(data/grid_dynamic_columns.aspx)。 -修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。 -增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。 -为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。 -重新设计模拟树的下拉列表的实现,避免选某项后的闪烁。 +2009-11-21 v2.1.5 +Tree优化。 -修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。 -GetNodeById更名为FindNode,保持和FindControl一致命名。 -删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。 -删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。 -增加示例(data/tree_select_run.aspx),如何选当前节点的所有子节点(feedback:wjl_wjl520)。 +TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet的一个命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。 -增加示例(other/custom_postback.aspx)(feedback:thebox)。 -如何自定义Javascript脚本和C#处理函数来响应键盘事件。 -为Tree增加AutoLeafIdentification属性。 -增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。 +2009-11-17 v2.1.4 -修正Window的关闭按钮提示信息一直是文的BUG(feedback:thebox)。 -部分ExtAspNet控件的设计时支持(会在后续版本逐步完善)。 -v0.2beta2版本关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。 -修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。 +为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.aspx +2009-10-19 v2.1.3 +增加支持在AJAX时改变的控件属性列表(/ajax.aspx)。 -ExtAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程会反映到,但并不是所有的控件属性都支持AJAX改变。 -加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保Asp.net的按钮控件仍然具有AJAX的特性。 -更新/basic/login.aspx示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.aspx(feedback:chenguizhu2006)。 -为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。 -GridTemplateField生成到控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。 -修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。 -增加pt_BR语言,由Ujvari提供。 +为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其包含1700多个小图标。 -如果Panel具有IconUrl属性,则IconUrl优先于Icon。 -所有Icon的列表在icon.aspx。 -为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。 +2009-09-15 v2.1.1 -修正不能动态修改AccordionPane属性Items的BUG。 +为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。 -如果需要在父面弹出确认对话框,需要设置ConfirmTarget="_parent"(类似Window控件的Target="_parent")。 +为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。 -一个典型应用,在Window控件打开新面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。 -ExtAspNet.Alert.Show("参数错误!", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference()); +TreeNode的前面的多选框可以自动回发了。 -为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://extasp.net/data/tree_run.aspx -Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选任何一项时在父面弹出对话框的JS代码。 -修正IE7下不能以下划线作为CSS类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree控件的AJAX实现。 +为面的Form添加autocomplete="off"属性。 -参考http://www.cnblogs.com/sanshi/archive/2009/09/04/1560146.html#1635830 +添加对extjs3.0所有语言的支持。 -ExtAspNet扩展的多语言包在js\languages\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现 -你可以向其添加自己的语言版本,并执行js\languages下的pack.bat打包,最后编译工程。 +2009-09-01 v2.0.9 -为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父面弹出窗口。 +在aspx必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。 -这将会影响所有的aspx面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将会影响所有的aspx面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config修改。 -将所有的示例转化为英语版本。 -修正Tree控件的一个BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。 -这个BUG导致Asp.net compatibility的示例无法完成,现在已经修正。 +去除PageManager方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。 -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility的示例。 +2009-08-25 v2.0.7 -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。 -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid每个单元格的值了。 -增加示例-如何将Grid控件导出为Excel(data\grid_excel_run.aspx)(feedback:503684912)。 -如果TreeNode的属性Enabled="false",则此项变灰并且不会被选(feedback:your568)。 -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~/开头)的BUG。 -增加Accordion和Tree配合使用的示例(other\accordion_tree_run.aspx)。 -修正Panel图标不能显示的BUG(CSSclass名不能有$字符)。 +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。 -简单方便,示例可以参考 default.aspx 或者 other\accordion_tree_run.aspx。 +2009-08-14 v2.0.6 -动态生成菜单实例(other\menu_dynamic_run.aspx和other\menu_dynamic2_run.aspx)(feedback:shguo)。 -优化AJAX的内部实现,每个面保存的ViewState现在减少1/3左右(重要更新)。 -优化Tree节点的NodeId自动生成,减少ViewState占用。 +2009-08-09 v2.0 beta5 +ExtAspNet和Asp.net的提交按钮兼容问题(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们做了优化,现在要使一个Asp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load设置需要在AJAX需要更新的Asp.net控件了。 -在Page_Load设置了哪些需要在AJAX更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。 -示例在aspnet\fckeditor_run.aspx和aspnet\aspnet_run.aspx。 -FCKEditor和上传控件兼容。示例在aspnet\fileupload_run.aspx。 -修正ToolbarText的文本在AJAX下更新的BUG。 -Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。 -更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。 +2009-08-02 v2.0 beta4 +和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。 -采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。 -现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.PageContext.Redirect重定向面,两者效果一样。 -支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。 -Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。 -修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。 -修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。 -增加Menu和Accordion的示例。 -修正Window控件的IconUrl有时不显示(Target="_parent")的BUG[feedback:xmq&mgzhenhong]。 +2009-07-22 v2.0 beta3 -兼容FCKEditor。 -在IE8.0,Firefox3.5下测试通过。以后ExtAspNet将不会对IE6.0提供支持。 +2009-07-13 v2.0 beta2 -集成extjs最新版本v3.0。 +兼容IE6.0-7.0-8.0。 -这应该是Extjs3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新extjs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。 -ExtAspNet自身的CSS会紧挨着面标签引入,这样在自定义的样式可以覆盖ExtAspNet缺省样式。 +Alert对话框会遮挡所有的Window窗口。 -使用一个变通的方法解决,因为无法改变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控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet/fileupload.aspx)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(Ext-Window)含有ASP.NET控件FileUpload,则此弹出窗口在关闭时出现JS错误(http://extjs.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果存在ASP.NET控件(TextBox),则第二次提交表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed] -面上放置ExtAspNet-Button和ASP.NET-Button,则点击ExtAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和Extjs2.2.1Ext.Ajax.serializeForm的实现有关。[fixed] -ExtAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added] +如果以前你听过不要在ExtAspNet工程使用ASP.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在ExtAspNet控件和ASP.NET标准控件和平共处了。[fixed] -如果一个ASP.NET按钮控件要使用ExtAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次ExtAspNet的原生AJAX回发时更新ASP.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet/aspnet.aspx)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新面重试。”。[fixed] -自动测试功能会在以后版本逐步完善。这个版本完成测试框架,采用ExtjsJS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建一个Window控件的代码由原来的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控件弹出B面,B面有Ext-Window控件弹出C面,B面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C面)会覆盖整个A面,这是正确的。 ---当时如果用户直接访问B面,就会报JS错误,因为此时找不到B面的父面A了。现在的版本修正为如果找不到父面,则就在当前面弹出窗口,这样用户直接访问B面也不会出错了。 -Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父面或回发父面”。 ---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父面或者关闭后回发父面的行为。 -如果弹出窗口(Window控件)IFrame的面不能正常加载(网络暂时出错或面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时面尚未加载完毕。 ---此版本修正了这个BUG,即时面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window控件的IFrameName属性是自动生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed] -DropDownList在面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed] -升级底层ExtJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[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控件增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +TabStrip的Tab控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都会回发)。[fixed] -有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则面加载完毕后会回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-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),这样方便后台添加列表项。 -处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed] -注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS的height不同,CSS的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有控件属性增加在VS的智能提示。[fixed] -需要将ExtAspNet.XML和ExtAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。 +控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:一个属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为控件。[fixed] -可以方便的在子面(iframe)通过js切换父的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.aspx,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的动态添加控件,并且可以给控件添加服务器端事件(示例在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控制链接列表的边距。 -这样能大大减少ASPXHTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在ASPX切换到“设计时”,方便属性的更改和事件处理函数的添加)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -TabStrip/Toolbar -TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form动态添加控件的BUG,现在form/form_dynamic_run.aspx示例已经能正确运行。[fixed] +大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed] -影响的控件包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留TabStrip的Tabs(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选项(SelectedRowIndexArray)在ajax回发过程存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选会存在当前不存在的行序号,导致服务器端遍历选项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例表单控件都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/Label/Image/LinkButton/TextBox -TriggerBox/TwinTriggerBox/Window/TextArea/HtmlEditor/DatePicker/NumberBox -CheckBox/RadioButton/RadioButtonList/DropDownList -Grid +2008-09-19 v1.2 beta1 -Image/LinkButton/HyperLink增加一些Ajax可更新属性。[fixed] +隐藏的方式由HideMode属性控制Visibility/Offsets/Display。[fixed] -修正Form/SimpleForm隐藏一个表单字段(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属性,在网报可以用自定义样式实现,而不应该写在控件。[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布局可供使用。 -其一些控件默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/TabStrip(Card),所有布局控件默认的布局是Container。 -经常用到的布局控件:SimpleForm/Form/Accordion/TabStrip/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的ExtAspNet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。 -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涉及很多控件(Grid,DropDownList,TabStrip)。 -解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) >= 0){ok}。 -DropDownList在Ajax时应该先更新数据再设置选定项 [feedback:xmzhu]。[fixed] -Button/MenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed] -Tree的Ajax支持(尚需优化)。[fixed] +2008-09-02 v1.1 beta5 -DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed] -模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(面第一次加载时,即使没有数据也需要设置DataTextField/DataValueField/DataSimulateTreeLevelField/DataEnableSelectField等属性的值,否则Ajax回发时会出错)。[fixed] -UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用AspnetAjax,这个控件已经完成使命)。[fixed] -不要使用Asp.net的控件HiddenField,而是使用ExtAspNet的HiddenField,因为Asp.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList项如果存在汉字,则会换行的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab如果有ContentPanel,则在面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢面的加载速度),现在已经解决这个问题。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第一个Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config增加配置项FormLabelWidth="80"(默认为80),同时PageManager增加FormLabelWidth属性用来控制面上所有SimpleForm/Form的表单字段标题的宽度。[fixed] +完善Ajax。[fixed] -RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue/SelectedItem)。 -DropDownList增加Ajax可更新属性Enable/SelectedIndex(SelectedValue/SelectedItem)/DataSource。 -Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。 -ToolbarText增加Ajax可更新属性Text。 +2008-08-31 v1.1 beta3 -TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法会出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。 -基本思:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。 -整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。 -网报Ajax整合(目前只支持所有的列表面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window控件是否弹出的状态在回发时维持。[fixed] -控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃Asp.NetAjax,ExtAspNet控件内置Ajax支持。[fixed] -这是一个值得骄傲的设计,可以明显提高面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前ExtAspNetAjax的限制。 -只对ExtAspNet控件起作用,对Asp.net控件不起作用。 -对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。 -对改变控件的Visible属性会有错误。 -Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个面都添加PageLoading控件。[fixed] -Grid的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选的状态在回发后会得到保持。[fixed] -Grid选行的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。 -主要是父面加载一个比较大的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] -一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器Cookie设置的值)(示例在default.aspx)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +TabStrip非当前Tab会延迟渲染。[fixed] -这会明显加快面的渲染速度,网报一个典型的费用审批面可以减少200ms的渲染时间。 -由于非当前Tab不会在面加载时渲染,所以那些Tab的节点在面加载后也是不可见的,需要将相关的脚本移动到控件的render事件。 -不能比较两个DataPicker大小的BUG。[fixed] -TabStrip延迟加载引起的BUG(非当前Tab的ContentPanel会占据面空间,已修正)。[fixed] -全新的ExtAspNet.Examples(基础知识/表单控件/数据绑定/容器布局/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控件,示例在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] -这是一个重要的BUG,会严重影响面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父面后Window的IFrame被添加到面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.aspx) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下会有JS错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正一个的内存泄漏。[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 -TabStrip延时加载出错。[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控件的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控件一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的js对象的名称简单化,这样可以减少生成的js内容,加快面加载速度(一个典型面的js由原来的33.0k降低为21.4k)。[fixed] +弹出窗口,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed] -因为在面的Page_Load,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向面注册了一段脚本,但是这段脚本在回发时没有注册到面,因为js调用此脚本时报错。 -一种解决方法是将向面注册脚本的函数移动到if语句的外面,即每次都向面注册此脚本。 -另一种办法就是在PageManager控件增加RegisterPageStateChangedScript(向面注册监视表单内容改变的脚本)的属性(会在每次面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx/simpleform.aspx)。 +PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed] -这个手工添加onReady函数能够在每次面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报遇到这种情况)。 -每个面必须添加一个PageManager控件,否则会出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed] -TextField等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed] -最大的好处是可以减少面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父面,也可在关闭后刷新或回发父面。(default.aspx/page2.aspx/simpleform.aspx) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加一个属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,控件本身封装了大量的代码,简单来看现在有三个面(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下TabStrip在Ajax回发后不会去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对TabStrip/Panel/Window的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到面节点,同时第二次打开Window的IFrame不会有残影出现。[fixed] -如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则会延迟加载(示例在tabstrip_iframe.aspx)。[fixed] -Tree控件,点击一个节点自动回发,则当前点击的那个节点的选状态不会保持的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控件(需要指定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控件 [feedback:jima]。[fixed] -Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed] -去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息的换行符(转换为),否则提示信息可能导致面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree控件。[fixed] -如何将数据库的数据绑定到Tree(示例在tree2_bind_database.aspx)。 -ajax加载树节点,放在UpdatePanel才有ajax的效果(示例在tree2_ajax.aspx)。 -更改TreeNode的ID为NodeId,否则两个树不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同一个面放置两个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] +增加树控件(Tree)(示例在tree2.aspx)。[fixed] -可以在回发时维持树的状态(选行,折叠/展开,CheckBox)。 -可以通过Inline的方式添加树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到面,也可以引发PostBack事件,可以添加自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel放置ExtAspNet控件,则渲染时会出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel渲染ExtAspNet控件,如果容器的display='none',则会出现各种问题(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。 +IE6下,在应用Asp.NetAjax后,Form字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。 -最后发现IE6下应用Asp.NetAjax后不仅Form列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正所有表单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 面。 +集成的AspNetAjax有一个很大的BUG,只要你在面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject控件。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选样式微调。[fixed] -预加载Form表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快面的渲染速度(一个典型的20个记录的面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid静态的CheckBoxField图片。[fixed] -TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.aspx)[fixed] +2008-07-12 v0.3 beta5 -面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.aspx)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个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默认显示的错误面,解决方法在当前目录添加一个空的html面,然后把Window控件的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控件,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed] -增加SplitButton控件。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.aspx。 +TabStrip放置IFrame会出现渲染错误 (示例在tabstrip_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控件。[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控件,支持在布局构建的面使用Asp.net Ajax。[fixed] -使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。 -示例在ajax3.aspx/content_page4.aspx。 -示例content_page3.aspx,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器控件的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工添加AutoHeight="true"属性。 +增加UserControlConnector,可以在其放置用户控件(示例在page_usercontrol.aspx)。[fixed] -也可以在ContentPanel放置用户控件,注意两者的区别。 +增加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下还有问题。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.aspx)。[fixed] -TabStrip的Tab如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel放置用户控件(示例在page_usercontrol.aspx)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox控件(示例在twintriggerbox.aspx)。[fixed] -Grid的数据库分需要增加属性IsDatabasePaging=true,以便普通分和数据库分,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的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属性(一个Grid只能有一个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窗体
ExtAspNet v2.2.1 ExtAspNet是一组专业的Asp.net控件库,拥有原生的AJAX支持和丰富的UI效果, 目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。 支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+ 注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。 示例: http://extasp.net/ 开源: http://extaspnet.codeplex.com/ 博客: http://sanshi.cnblogs.com/ 邮箱: sanshi.ustc@gmail.com 发布历史: +2010-03-28 v2.2.1 +为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。 -隐藏示例首最外层RegionPanel的边框ShowBorder="false"。 +集成Extjs最新版本v3.1.1。 -增加一个新的Theme - Access。 -修正了Firefox下Zoom In/Out时面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax提交)(feedback:261629698)。 +TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。 -增加示例tabstrip/tabstrip_addtab.aspx。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window控件更新。 -关闭按钮默认直接关闭,不会弹出确认对话框。 -GetConfirmFormModifiedHideReference的函数的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居,而不是黄金分割位置。 +Button, Window等控件弹出位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后一个参数target变为枚举类型。 -Alert.GetShowReference的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Extjs最新版本v3.1.0。 -修正灰色皮肤的CSS问题。 -修正Grid的列名不能包含文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏ExtAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其的Close全部改为Hide。 -增加TabStripTab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocumentIcon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时会出现空白面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid的一个JS问题(feedback:lqm4108)。 -修正Alert消息引号未编码导致的JS错误(feedback:sun1299shine)。 +集成extjs3.0.3。 -修正弹出对话框的宽度计算错误(会保持最小的状态)。 -增加新的皮肤Gray。 -为示例工程添加改变语言和皮肤的下拉列表。 -为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。 +2009-12-01 v2.1.7 -增加示例(iframe/parent_postback_run3.aspx),如何通过简单的Javascript代码回发父面(feedback:eroach)。 -修正一些书写错误(feedback:bmck)。 -从Region控件删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加国的省市县三级联动示例(data/shengshixian.aspx)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程会重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。 +2009-11-26 v2.1.6 +修正动态创建Grid列的BUG(feedback:gxpan)。 -增加示例(data/grid_dynamic_columns.aspx)。 -修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。 -增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。 -为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。 -重新设计模拟树的下拉列表的实现,避免选某项后的闪烁。 +2009-11-21 v2.1.5 +Tree优化。 -修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。 -GetNodeById更名为FindNode,保持和FindControl一致命名。 -删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。 -删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。 -增加示例(data/tree_select_run.aspx),如何选当前节点的所有子节点(feedback:wjl_wjl520)。 +TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet的一个命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。 -增加示例(other/custom_postback.aspx)(feedback:thebox)。 -如何自定义Javascript脚本和C#处理函数来响应键盘事件。 -为Tree增加AutoLeafIdentification属性。 -增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。 +2009-11-17 v2.1.4 -修正Window的关闭按钮提示信息一直是文的BUG(feedback:thebox)。 -部分ExtAspNet控件的设计时支持(会在后续版本逐步完善)。 -v0.2beta2版本关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。 -修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。 +为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.aspx +2009-10-19 v2.1.3 +增加支持在AJAX时改变的控件属性列表(/ajax.aspx)。 -ExtAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程会反映到,但并不是所有的控件属性都支持AJAX改变。 -加载s.gif图片在本机进行,不会请求extjs.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保Asp.net的按钮控件仍然具有AJAX的特性。 -更新/basic/login.aspx示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.aspx(feedback:chenguizhu2006)。 -为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。 -GridTemplateField生成到控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。 -修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。 -增加pt_BR语言,由Ujvari提供。 +为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其包含1700多个小图标。 -如果Panel具有IconUrl属性,则IconUrl优先于Icon。 -所有Icon的列表在icon.aspx。 -为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。 +2009-09-15 v2.1.1 -修正不能动态修改AccordionPane属性Items的BUG。 +为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。 -如果需要在父面弹出确认对话框,需要设置ConfirmTarget="_parent"(类似Window控件的Target="_parent")。 +为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。 -一个典型应用,在Window控件打开新面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。 -ExtAspNet.Alert.Show("参数错误!", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference()); +TreeNode的前面的多选框可以自动回发了。 -为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://extasp.net/data/tree_run.aspx -Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选任何一项时在父面弹出对话框的JS代码。 -修正IE7下不能以下划线作为CSS类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree控件的AJAX实现。 +为面的Form添加autocomplete="off"属性。 -参考http://www.cnblogs.com/sanshi/archive/2009/09/04/1560146.html#1635830 +添加对extjs3.0所有语言的支持。 -ExtAspNet扩展的多语言包在js\languages\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现 -你可以向其添加自己的语言版本,并执行js\languages下的pack.bat打包,最后编译工程。 +2009-09-01 v2.0.9 -为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父面弹出窗口。 +在aspx必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。 -这将会影响所有的aspx面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将会影响所有的aspx面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config修改。 -将所有的示例转化为英语版本。 -修正Tree控件的一个BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。 -这个BUG导致Asp.net compatibility的示例无法完成,现在已经修正。 +去除PageManager方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。 -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility的示例。 +2009-08-25 v2.0.7 -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。 -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid每个单元格的值了。 -增加示例-如何将Grid控件导出为Excel(data\grid_excel_run.aspx)(feedback:503684912)。 -如果TreeNode的属性Enabled="false",则此项变灰并且不会被选(feedback:your568)。 -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~/开头)的BUG。 -增加Accordion和Tree配合使用的示例(other\accordion_tree_run.aspx)。 -修正Panel图标不能显示的BUG(CSSclass名不能有$字符)。 +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。 -简单方便,示例可以参考 default.aspx 或者 other\accordion_tree_run.aspx。 +2009-08-14 v2.0.6 -动态生成菜单实例(other\menu_dynamic_run.aspx和other\menu_dynamic2_run.aspx)(feedback:shguo)。 -优化AJAX的内部实现,每个面保存的ViewState现在减少1/3左右(重要更新)。 -优化Tree节点的NodeId自动生成,减少ViewState占用。 +2009-08-09 v2.0 beta5 +ExtAspNet和Asp.net的提交按钮兼容问题(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们做了优化,现在要使一个Asp.net的按钮能够AJAX提交,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load设置需要在AJAX需要更新的Asp.net控件了。 -在Page_Load设置了哪些需要在AJAX更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。 -示例在aspnet\fckeditor_run.aspx和aspnet\aspnet_run.aspx。 -FCKEditor和上传控件兼容。示例在aspnet\fileupload_run.aspx。 -修正ToolbarText的文本在AJAX下更新的BUG。 -Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。 -更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。 +2009-08-02 v2.0 beta4 +和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。 -采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。 -现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.PageContext.Redirect重定向面,两者效果一样。 -支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。 -Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。 -修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。 -修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。 -增加Menu和Accordion的示例。 -修正Window控件的IconUrl有时不显示(Target="_parent")的BUG[feedback:xmq&mgzhenhong]。 +2009-07-22 v2.0 beta3 -兼容FCKEditor。 -在IE8.0,Firefox3.5下测试通过。以后ExtAspNet将不会对IE6.0提供支持。 +2009-07-13 v2.0 beta2 -集成extjs最新版本v3.0。 +兼容IE6.0-7.0-8.0。 -这应该是Extjs3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新extjs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。 -ExtAspNet自身的CSS会紧挨着标签引入,这样在<head><em>中</em>自定义的样式可以覆盖<em>Ext</em>AspNet缺省样式。 +Alert对话框会遮挡所有的Window窗口。 -使用一个变通的方法解决,因为无法改变<em>Ext</em>.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选<em>中</em>第一项。 -重新绑定模拟树的下拉列表后,选<em>中</em>项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件<em>Ext</em>.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed] -Window<em>中</em>的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed] -<em>页</em>面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例aspnet/fileupload.aspx)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(<em>Ext</em>-Window)含有ASP.NET控件FileUpload,则此弹出窗口在关闭时出现JS错误(http://<em>ext</em>js.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果<em>页</em>面<em>中</em>存在ASP.NET控件(T<em>ext</em>Box),则第二次<em>提交</em>表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed] -<em>页</em>面上放置<em>Ext</em>AspNet-Button和ASP.NET-Button,则点击<em>Ext</em>AspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和<em>Ext</em>js2.2.1<em>中</em><em>Ext</em>.Ajax.serialize<em>Form</em>的实现有关。[fixed] -<em>Ext</em>AspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added] +如果以前你听过不要在<em>Ext</em>AspNet工程<em>中</em>使用ASP.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在<em>Ext</em>AspNet控件和ASP.NET标准控件和平共处了。[fixed] -如果一个ASP.NET按钮控件要使用<em>Ext</em>AspNet的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次<em>Ext</em>AspNet的原生AJAX回发时更新ASP.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet/aspnet.aspx)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新<em>页</em>面重试。”。[fixed] -自动测试功能会在以后版本<em>中</em>逐步完善。这个版本完成测试框架,采用<em>Ext</em>js<em>中</em>JS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。 -PageCont<em>ext</em>静态类<em>中</em>的GetPageStateChangedFunction改名为GetConfirm<em>Form</em>ModifiedReference,底层代码优化。表示“获取当前<em>页</em>面<em>中</em>表单修改的确认提示框的脚本”。 ---[updated]删除PageCont<em>ext</em><em>中</em>的GetConfirm<em>Form</em>ModifiedReference,使用CurrentActiveWindow<em>中</em>的GetConfirm<em>Form</em>ModifiedCloseReference/GetConfirm<em>Form</em>ModifiedCloseRefreshReference/GetConfirm<em>Form</em>ModifiedClosePostBackReference三个方法代替。 -不会修改弹出<em>页</em>面的URL(<em>Ext</em>-Window<em>中</em>的IFrame),以前为了实现功能为每个弹出<em>页</em>面添加box_parent_client_id查询字符串 -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageCont<em>ext</em>.Get<em>Form</em>ModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的ASPX<em>页</em>面<em>中</em>查找RegisterPageStateChangedScript属性,并删除,否则会运行错误! -A<em>页</em>面有<em>Ext</em>-Window控件弹出B<em>页</em>面,B<em>页</em>面有<em>Ext</em>-Window控件弹出C<em>页</em>面,B<em>页</em>面的<em>Ext</em>-Window控件设置Target='_parent',则弹出的<em>Ext</em>-Window(C<em>页</em>面)会覆盖整个A<em>页</em>面,这是正确的。 ---当时如果用户直接访问B<em>页</em>面,就会报JS错误,因为此时找不到B<em>页</em>面的父<em>页</em>面A了。现在的版本修正为如果找不到父<em>页</em>面,则就在当前<em>页</em>面弹出窗口,这样用户直接访问B<em>页</em>面也不会出错了。 -Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirm<em>Form</em>ModifiedCloseReference,表示“获取先确认IFrame的<em>页</em>面<em>中</em>表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window控件增加如下两个方法GetConfirm<em>Form</em>ModifiedCloseRefreshReference和GetConfirm<em>Form</em>ModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出<em>Ext</em>-Window,再然后刷新父<em>页</em>面或回发父<em>页</em>面”。 ---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirm<em>Form</em>ModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父<em>页</em>面或者关闭后回发父<em>页</em>面的行为。 -如果弹出窗口(Window控件)<em>中</em>IFrame的<em>页</em>面不能正常加载(网络暂时出错或<em>页</em>面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时<em>页</em>面尚未加载完毕。 ---此版本修正了这个BUG,即时<em>页</em>面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window控件的IFrameName属性是自动生成的,只读属性。(因为有可能所有的<em>Ext</em>-Window最终都渲染到最外层的<em>页</em>面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部<em>处理</em>)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel<em>中</em>内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed] -DropDownList在<em>页</em>面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed] -升级底层<em>Ext</em>JS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed] -<em>页</em>面加载过程<em>中</em>的时间信息保存在Javascript变量window.box.timeInfo<em>中</em>。[added] +增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选<em>中</em>任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageCont<em>ext</em>优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageCont<em>ext</em>.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其<em>中</em>target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image控件增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包<em>中</em>增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +<em>Tab</em>Strip的<em>Tab</em>控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此<em>Tab</em>都会回发)。[fixed] -有这样一个效果,如果<em>Tab</em>1默认显示,<em>Tab</em>1的EnablePostBack=true,则<em>页</em>面加载完毕后会回发<em>Tab</em>1一次。 +2008-10-20 v1.2 beta6 +使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-aspnet-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemT<em>ext</em>/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new <em>Ext</em>AspNet.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选<em>中</em>[feedback:jqpeng]。 -和Asp.net<em>中</em>的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string t<em>ext</em>, string value),这样方便后台添加列表项。 -处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed] -注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS<em>中</em>的height不同,CSS<em>中</em>的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有控件属性增加在VS<em>中</em>的智能提示。[fixed] -需要将<em>Ext</em>AspNet.XML和<em>Ext</em>AspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。 +控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:一个属性可以拥有<em>多个</em>值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如Validate<em>Form</em>s,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为控件。[fixed] -可以方便的在子<em>页</em>面(iframe)<em>中</em>通过js切换父<em>页</em>面<em>中</em>选<em>中</em>的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.aspx,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的动态添加控件,并且可以给控件添加服务器端事件(示例在<em>form</em>/<em>form</em>_dynamic_run.aspx)。[fixed] +2008-10-15 v1.2 beta5 -验证表单字段的ValueToCompare属性,为字符串时会出错的BUG。[fixed] +优化下拉列表。[fixed] -验证下拉列表时,应该取ListItem的Value属性进行验证,而不是T<em>ext</em>属性。 -DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。 -DropDownList不支持EmptyT<em>ext</em>属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)<em>中</em>设置哪些项不可选择,以及创建模拟下拉树。 -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<em>中</em>的容器,比如ContentPanel需要在外层加上<Items>标签。 -适当增大AccordionPanel<em>中</em>链接的高度20px->22px,同时对链接的样式也做了微调。 -通过BodyPadding控制链接列表的边距。 -这样能大大减少ASPX<em>中</em>HTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在ASPX<em>页</em>切换到“设计时”,方便属性的更改和事件<em>处理</em>函数的添加)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -<em>Tab</em>Strip/Toolbar -<em>Tab</em>Strip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向<em>Form</em><em>中</em>动态添加控件的BUG,现在<em>form</em>/<em>form</em>_dynamic_run.aspx示例已经能正确运行。[fixed] +大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed] -影响的控件包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/Simple<em>Form</em>/Window等。 -保留<em>Form</em>的Rows(<em>Form</em>RowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留<em>Tab</em>Strip的<em>Tab</em>s(<em>Tab</em>Collection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选<em>中</em>项(SelectedRowIndexArray)在ajax回发过程<em>中</em>存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选<em>中</em>项<em>中</em>会存在当前不存在的行序号,导致服务器端遍历选<em>中</em>项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例<em>中</em>表单控件都已支持设计)。[fixed] -PageManager/Simple<em>Form</em>/Button/HyperLink/Label/Image/LinkButton/T<em>ext</em>Box -TriggerBox/TwinTriggerBox/Window/T<em>ext</em>Area/HtmlEditor/DatePicker/NumberBox -CheckBox/RadioButton/RadioButtonList/DropDownList -Grid +2008-09-19 v1.2 beta1 -Image/LinkButton/HyperLink增加一些Ajax可更新属性。[fixed] +隐藏的方式由HideMode属性控制Visibility/Offsets/Display。[fixed] -修正<em>Form</em>/Simple<em>Form</em><em>中</em>隐藏一个表单字段(Hidden=false)会占据<em>页</em>面空间的BUG。 -ToolbarT<em>ext</em>/ToolbarFill/ToolbarSeparator在ASPX<em>中</em>设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报<em>中</em>可以用自定义样式实现,而不应该写在控件<em>中</em>。[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/<em>Form</em>六种布局,总共有9<em>中</em>布局可供使用。 -其<em>中</em>一些控件默认使用一种布局:Simple<em>Form</em>(<em>Form</em>)/<em>Form</em>(<em>Form</em>)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/<em>Tab</em>Strip(Card),所有布局控件默认的布局是Container。 -经常用到的布局控件:Simple<em>Form</em>/<em>Form</em>/Accordion/<em>Tab</em>Strip/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuT<em>ext</em>增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的<em>Ext</em>AspNet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。 -US的<em>Ext</em>AspNet改造强烈依赖于此属性,这个版本发布后可以继续。 -网报<em>中</em>唯一没有用到<em>Ext</em>AspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageCont<em>ext</em>.Redirect支持普通<em>页</em>面转向和<em>Ext</em>AspNetAjax下<em>页</em>面转向。[fixed] +模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,<em>Tab</em>Strip)。 -解决方法: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后,保持项是否可选状态是最新的(<em>页</em>面第一次加载时,即使没有数据也需要设置DataT<em>ext</em>Field/DataValueField/DataSimulateTreeLevelField/DataEnableSelectField等属性的值,否则Ajax回发时会出错)。[fixed] -UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用AspnetAjax,这个控件已经完成使命)。[fixed] -不要使用Asp.net的控件HiddenField,而是使用<em>Ext</em>AspNet的HiddenField,因为Asp.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList<em>中</em>项如果存在汉字,则会换行的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前<em>Tab</em><em>中</em>如果有ContentPanel,则在<em>页</em>面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢<em>页</em>面的加载速度),现在已经解决这个问题。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(Simple<em>Form</em>/<em>Form</em>)的背景色一致。[fixed] -TwinTriggerBox的第一个Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config<em>中</em>增加配置项<em>Form</em>LabelWidth="80"(默认为80),同时PageManager增加<em>Form</em>LabelWidth属性用来控制<em>页</em>面上所有Simple<em>Form</em>/<em>Form</em>的表单字段标题的宽度。[fixed] +完善Ajax。[fixed] -RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue/SelectedItem)。 -DropDownList增加Ajax可更新属性Enable/SelectedIndex(SelectedValue/SelectedItem)/DataSource。 -Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。 -ToolbarT<em>ext</em>增加Ajax可更新属性T<em>ext</em>。 +2008-08-31 v1.1 beta3 -<em>Tab</em>Strip增加EnableDeferredRender属性(是否启用延迟加载<em>Tab</em>,默认启用)。[fixed] -重定向<em>页</em>面,使用系统的方法 PageCont<em>ext</em>.Redirect(string url),使用Response.Redirect方法会出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。 -基本思<em>想</em>:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。 -整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。 -网报Ajax整合(目前只支持所有的列表<em>页</em>面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window控件是否弹出的状态在回发时维持。[fixed] -控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃Asp.NetAjax,<em>Ext</em>AspNet控件内置Ajax支持。[fixed] -这是一个值得骄傲的设计,可以明显提高<em>页</em>面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager<em>中</em>有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件<em>中</em>设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前<em>Ext</em>AspNetAjax的限制。 -只对<em>Ext</em>AspNet控件起作用,对Asp.net控件不起作用。 -对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。 -对改变控件的Visible属性会有错误。 -Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用<em>页</em>面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个<em>页</em>面都添加PageLoading控件。[fixed] -Grid<em>中</em>的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选<em>中</em>的状态在回发后会得到保持。[fixed] -Grid选<em>中</em>行的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。 -主要是父<em>页</em>面加载一个比较大的css文件(~100k),则每次打开iframe<em>页</em>面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹出窗口<em>中</em>IFrame的显示速度。[fixed] -在当前<em>页</em>面弹出窗口需要~20ms,在父<em>页</em>面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报<em>中</em>需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、<em>Form</em>MessageTarget、<em>Form</em>OffsetRight等属性,这些属性可以在Web.config<em>中</em>设置(推荐方法),也可以为每个<em>页</em>面设置。[fixed] -一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器<em>中</em>Cookie设置的值)(示例在default.aspx)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +<em>Tab</em>Strip<em>中</em>非当前<em>Tab</em>会延迟渲染。[fixed] -这会明显加快<em>页</em>面的渲染速度,网报<em>中</em>一个典型的费用审批<em>页</em>面可以减少200ms的渲染时间。 -由于非当前<em>Tab</em>不会在<em>页</em>面加载时渲染,所以那些<em>Tab</em><em>中</em>的节点在<em>页</em>面加载后也是不可见的,需要将相关的脚本移动到控件的render事件<em>中</em>。 -不能比较两个DataPicker大小的BUG。[fixed] -<em>Tab</em>Strip延迟加载引起的BUG(非当前<em>Tab</em><em>中</em>的ContentPanel会占据<em>页</em>面空间,已修正)。[fixed] -全新的<em>Ext</em>AspNet.Examples(基础知识/表单控件/数据绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame<em>页</em>面<em>中</em>使用父<em>页</em>面的脚本和样式(示例在iframe/default.aspx和iframe/page3.aspx)。[fixed] -测试发现,IFrame<em>页</em>面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout<em>中</em>显示不了的BUG [feedback:zgjiang2]。[fixed] +<em>ext</em>js的BUG,当<em>页</em>面<em>中</em>含有iframe时,<em>Ext</em>.onReady会被调用两次(IE6/IE7)(http://www.<em>ext</em>js.net/forum/showthread.php?t=43246)(示例在test.aspx)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发<em>页</em>面再弹出IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种做法(推荐):PageCont<em>ext</em>.RegisterStartupScript(Window99.GetShowReference("./simple<em>form</em>.aspx"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下会有JS错误。[fixed] -增加BorderLayout控件,示例在iframe/borderlayout.aspx。[fixed] +Radiobuttonlist显示有重影(示例在radio.aspx)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -动态向<em>Form</em><em>中</em>添加<em>Form</em>Row,并动态的向<em>Form</em>Row<em>中</em>添加表单字段,以及如何取得表单字段的值。(示例在<em>form</em>_dynamic.aspx)[fixed] +IFrame弹出窗口关闭后回发父<em>页</em>面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是一个重要的BUG,会严重影响<em>页</em>面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父<em>页</em>面后Window<em>中</em>的IFrame被添加到<em>页</em>面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.aspx) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下会有JS错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正一个的内存泄漏。[fixed] -IE7下测试,打开iframe/default.aspx<em>页</em>面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.aspx<em>页</em>面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.aspx<em>页</em>面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE会自动进行垃圾回收。 +2008-08-12 v0.4 beta3 -底层的javascript框架<em>Ext</em>js升级为v2.2,Grid的渲染速度有很大提升。[fixed] -Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight="true"解决)。[fixed] +<em>页</em>面正在加载的提示尽早的显示出来。[fixed] -首先在执行js来完成<em>页</em>面渲染之前延迟5ms,以便浏览器把当前<em>页</em>面内容显示出来。 -加载js脚本的script标签放置在<em>页</em>面的最后,放置加载js而阻塞PageLoading的显示。 +2008-08-08 v0.4 beta2 -<em>Tab</em>Strip延时加载出错。[fixed] -Window的IFrameUrl<em>处理</em>的BUG,比如Pages_<em>Ext</em>AspNet目录下的<em>页</em>面应该为./FE_ApplyEditor.aspx或~/Pages_<em>Ext</em>AspNet/FE_ApplyEditor.aspx。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则会JS错误。[fixed] -实现网报首<em>页</em>下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在<em>页</em>面显示后进行,不计算在js渲染时间内。[fixed] -优化费用申请<em>页</em>面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.aspx默认会加载<em>form</em>.aspx<em>页</em>面(Window控件的BUG)。[fixed] -Window<em>中</em>的保存并关闭按钮和Asp.netAjax冲突。[fixed] -优化关闭Window的js脚本,减少写到<em>页</em>面的js大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageCont<em>ext</em>.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simple<em>form</em>.aspx)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的Asp.net控件一样不可编辑。[fixed] -DropDownList增加SelectedT<em>ext</em>属性(去除了模拟树时通过SelectedItem.T<em>ext</em>的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的js对象的名称简单化,这样可以减少生成的js内容,加快<em>页</em>面加载速度(一个典型<em>页</em>面的js由原来的33.0k降低为21.4k)。[fixed] +弹出窗口<em>中</em>,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed] -因为在<em>页</em>面的Page_Load<em>中</em>,if (!IsPostBack){PageCont<em>ext</em>.RegisterPageStateChangedStartupScript();}通过这样方法向<em>页</em>面注册了一段脚本,但是这段脚本在回发时没有注册到<em>页</em>面,因为js调用此脚本时报错。 -一种解决方法是将向<em>页</em>面注册脚本的函数移动到if语句的外面,即每次都向<em>页</em>面注册此脚本。 -另一种办法就是在PageManager控件<em>中</em>增加RegisterPageStateChangedScript(向<em>页</em>面注册监视<em>页</em>面<em>中</em>表单内容改变的脚本)的属性(会在每次<em>页</em>面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx/simple<em>form</em>.aspx)。 +PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed] -这个手工添加onReady函数能够在每次<em>页</em>面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报<em>中</em>遇到这种情况)。 -每个<em>页</em>面必须添加一个PageManager控件,否则会出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed] -T<em>ext</em>Field等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed] -最大的好处是可以减少<em>页</em>面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父<em>页</em>面,也可在关闭后刷新或回发父<em>页</em>面。(default.aspx/page2.aspx/simple<em>form</em>.aspx) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加一个属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,控件本身封装了大量的代码,简单来看现在有三个<em>页</em>面(default.aspx(A)/page2.aspx(B)/simple<em>form</em>.aspx(C)),其<em>中</em>A包含B<em>页</em>面,当你在B<em>中</em>打开包含有<em>页</em>面C的窗口时,窗口不是在B<em>中</em>打开,而是在A<em>中</em>打开,这样才能保证窗口覆盖整个<em>页</em>面,当你从C<em>中</em>返回需要回发<em>页</em>面B时,却发现取得的是A<em>页</em>面,因为我们窗口是在A<em>页</em>面<em>中</em>创建的。我会通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid<em>中</em>弹出窗口。(default.aspx/page3.aspx/simple<em>form</em>.aspx) +示例3,TriggerBox弹出窗口。(default.aspx/triggerbox.aspx/simple<em>form</em>.aspx) -在整个<em>页</em>面弹出窗口或者在当前<em>页</em>面弹出窗口,仅仅设置Window的Target属性即可。 -示例4,弹出窗口<em>中</em>的弹出窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下<em>Tab</em>Strip在Ajax回发后不会去掉x-hide-display样式,导致<em>Tab</em>显示为空的BUG。[fixed] -对<em>Tab</em>Strip/Panel/Window<em>中</em>的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到<em>页</em>面节点,同时第二次打开Window<em>中</em>的IFrame不会有残影出现。[fixed] -如果<em>Tab</em>Strip的<em>Tab</em>不是激活<em>Tab</em>并且设置了IFrameUrl,则会延迟加载(示例在<em>tab</em>strip_iframe.aspx)。[fixed] -Tree控件,点击一个节点自动回发,则当前点击的那个节点的选<em>中</em>状态不会保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe<em>中</em>关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx/simple<em>form</em>.aspx)。[fixed] -内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simple<em>form</em>.aspx,PageCont<em>ext</em>.RegisterStartupScript增加重载函数),而不是原来的先创建整个<em>页</em>面UI,再关闭窗口。 -参照Yslow的评分规则,将JS文件引用由head移动到body<em>中</em>。[fixed] -Firefox下,如果<em>页</em>面太长会出滚动条,原来在ViewPort样式<em>中</em>有body{overflow:hidden;}。[fixed] +IFrame内的<em>页</em>面宽度和高度会自动设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx/simple<em>form</em>.aspx/simple<em>form</em>2.aspx)[fixed] -增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个<em>页</em>面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息<em>中</em>MessageTarget改名为<em>Form</em>MessageTarget,增加<em>Form</em>OffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image控件 [feedback:jima]。[fixed] -Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起<em>页</em>面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed] -去掉DropDownList控件的T<em>ext</em>属性(强制性),可以通过设置SelectedValue来设置选<em>中</em>哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息<em>中</em>的换行符(转换为<br/>),否则提示信息可能导致<em>页</em>面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree控件。[fixed] -如何将数据库<em>中</em>的数据绑定到Tree(示例在tree2_bind_da<em>tab</em>ase.aspx)。 -ajax加载树节点,放在UpdatePanel<em>中</em>才有ajax的效果(示例在tree2_ajax.aspx)。 -更改TreeNode的ID为NodeId,否则两个树<em>中</em>不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同一个<em>页</em>面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltip<em>Form</em>atString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选<em>中</em>样式,以及鼠标移上去和移开的样式不对。[fixed] -发现原来ie6不能正确解析li的高度,必须手工设置才行(style="height:20px;")。 +IE6/IE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed] -虽然最后未能解决<div style="width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;"><div style="width: 16px; height: 18px; float: left;">##</div>差旅交通费</div>在IE和Firefox下显示的不同效果。 -但是通过用<img src="##" />来代替<div style="background:url(##)" />,从而实现FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“<span style="margin-right: -1000px;">差旅交通费</span>”,在IE下和FF下的都不换行,:-) -LinkButton增加OnClick事件 [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树控件(Tree)(示例在tree2.aspx)。[fixed] -可以在回发时维持树的状态(选<em>中</em>行,折叠/展开,CheckBox)。 -可以通过Inline的方式添加树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到<em>页</em>面,也可以引发PostBack事件,可以添加自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel<em>中</em>放置<em>Ext</em>AspNet控件,则渲染时会出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel<em>中</em>渲染<em>Ext</em>AspNet控件,如果容器的display='none',则会出现各种问题(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。 +IE6下,在应用Asp.NetAjax后,<em>Form</em><em>中</em>字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。 -最后发现IE6下应用Asp.NetAjax后不仅<em>Form</em><em>中</em>列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数<em>中</em>,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正<em>页</em>面<em>中</em>所有表单的宽度(box_fix<em>Form</em>WidthInIE6();): 示例在 Site.Master <em>页</em>面。 +集成的AspNetAjax有一个很大的BUG,只要你在<em>页</em>面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我<em>想</em>起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject控件。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选<em>中</em>样式微调。[fixed] -预加载<em>Form</em>表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快<em>页</em>面的渲染速度(一个典型的20个记录的<em>页</em>面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid<em>中</em>静态的CheckBoxField图片。[fixed] -<em>Tab</em>Strip增加<em>Tab</em>IndexChanged事件,同时<em>Tab</em>增加EnablePostBack,可以在点击一个<em>Tab</em>时引起回发事件。这在延迟加载<em>Tab</em>的内容非常有用。(示例在<em>tab</em>strip.aspx)[fixed] +2008-07-12 v0.3 beta5 -<em>页</em>面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在<em>form</em>_compare.aspx)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和T<em>ext</em>Box比较大小需要指定CompareType。 +如果在编辑<em>页</em>面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx/ajax_editor.aspx)。[fixed] -这是由于ajax后执行的javascript<em>中</em>不能有return false语句。 +在文本框失去焦点时,执行一些Javascript脚本(示例在t<em>ext</em>box_blur.aspx) [feedback:xmzhu]。[fixed] -在<em>页</em>面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。 -弹出Window默认显示的错误<em>页</em>面,解决方法在当前目录添加一个空的html<em>页</em>面,然后把Window控件的IFrameUrl指向这个<em>页</em>面而不是"#"。[fixed] +弹出的窗口<em>中</em>的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例<em>中</em>alert\alert_1.aspx和alert\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。 -点击<em>提交</em>按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed] +增加Menu、MenuT<em>ext</em>、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed] -增加SplitButton控件。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +<em>Form</em>表单字段(T<em>ext</em>Box,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在<em>form</em>_compare.aspx。 +<em>Tab</em>Strip<em>中</em>放置IFrame会出现渲染错误 (示例在<em>tab</em>strip_iframe.aspx)[feedback:jima]。[fixed] -特殊<em>处理</em>,拥有IFrame的<em>Tab</em>如果不是激活<em>Tab</em>,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed] -<em>Form</em>Row可以设置各列的宽度百分比 (示例在<em>form</em>_columnwidths.aspx)[feedback:jima]。[fixed] +表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有数据,向后翻<em>页</em>按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField控件。[fixed] -其实用T<em>ext</em>Box也能模拟HiddenField的行为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableT<em>ext</em>Box = true,则不能将T<em>ext</em>回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在t<em>ext</em>box2.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有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。 -示例在ajax3.aspx/content_page4.aspx。 -示例content_page3.aspx<em>中</em>,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器控件的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<em>中</em>使用,示例在ajax1.aspx/content_ajax2.aspx<em>中</em>。 -对于使用布局构建的<em>页</em>面(比如content_page1.aspx)还不能使用Asp.net ajax,因为<em>页</em>面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前<em>页</em>面已经被修改(示例在content_page1.aspx/simple<em>form</em>.aspx)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe<em>中</em>做法一致)。 +iframe<em>中</em>的alert/confirm要覆盖整个父<em>页</em>面,而不仅仅是iframe<em>页</em>面。[fixed] -在Firefox下还有问题。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.aspx)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.aspx)。[fixed] -<em>Tab</em>Strip的<em>Tab</em><em>中</em>如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel<em>中</em>放置用户控件(示例在page_usercontrol.aspx)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox控件(示例在twintriggerbox.aspx)。[fixed] -Grid的数据库分<em>页</em>需要增加属性IsDa<em>tab</em>asePaging=true,以便普通分<em>页</em>和数据库分<em>页</em>,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的<em>tab</em>)。[fixed] +<em>页</em>面<em>中</em>任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx/simple<em>form</em>.aspx)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容<em>页</em><em>中</em>Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid<em>中</em>的LinkButtonField设置ConfirmT<em>ext</em>会出错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.aspx示例)。 -Grid<em>中</em>模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。 -切换分<em>页</em>时清空选<em>中</em>的值 [feedback:jqpeng]。 -增加PreRowDa<em>taB</em>ound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowda<em>tab</em>ound.aspx)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.aspx)。 +2008-06-25 v0.2 beta9 +Window窗体<em>中</em>的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.aspx/simple<em>form</em>.aspx)[fixed] -在simple<em>form</em>.aspx<em>中</em>:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](Simple<em>Form</em>[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其<em>中</em>26是Toolbar的高度,32是窗口的标题栏和下边框的高度。 +关闭Iframe的LoadMask,所以需要Iframe<em>页</em>面添加PageLoading控件,这样效果统一。[fixed] +Grid完善。 -去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分<em>页</em>在ASP.NET应用<em>中</em>会有很多问题(主要是状态保持的问题)。 +EnableServerSort改名AllowSorting。(示例在grid_sorting.aspx) -使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件<em>处理</em>函数<em>中</em>重新绑定数据。 +增加AllowPaging属性。(示例在grid_paging.aspx) -使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件<em>处理</em>函数<em>中</em>Grid1.PageIndex = e.NewPageIndex;OK。 +数据库分<em>页</em>支持。(示例在grid_da<em>tab</em>ase_paging.aspx) -使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件<em>处理</em>函数<em>中</em>Grid1.PageIn</a></div></div></div></div> <div class="public_pc_right_footer2020" style="display:none;" data-v-4a5a7f56></div></div> <div id="right-floor-user-content_562" data-editor="{"type":"floor","pageId":143,"floorId":562}" class="user-right-floor right-box main-box detail-user-right" data-v-229a00b0><div class="__vuescroll" style="height:100%;width:100%;padding:0;position:relative;overflow:hidden;"><div class="__panel __hidebar" style="position:relative;box-sizing:border-box;height:100%;overflow-y:hidden;overflow-x:hidden;transform-origin:;transform:;"><div class="__view" style="position:relative;box-sizing:border-box;min-width:100%;min-height:100%;"><!----><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="introduce" data-v-4722a3ae><div class="introduce-title" data-v-4722a3ae><div class="img-info" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/JavaScript" class="community-img" data-v-4722a3ae><img src="https://img-community.csdnimg.cn/avatar/ca46c476a908476d9927eaee4b0afc10.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt data-v-4722a3ae> <div title="JavaScript" class="community-name" data-v-4722a3ae> JavaScript </div></a></div></div> <div class="content" data-v-4722a3ae><div class="detail" data-v-4722a3ae><div title="87888" class="item" data-v-4722a3ae><p class="num" data-v-4722a3ae> 87,888 </p> <p class="desc" data-v-4722a3ae> 社区成员 </p></div> <div title="224612" class="item" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/JavaScript" target="_blank" data-v-4722a3ae><p class="num" data-v-4722a3ae> 224,612 </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-3861" 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/shareBg1.98114ddf.png" alt="" class="share-bg" data-v-ca030a68> <div class="share-bg-box" data-v-ca030a68><div class="share-content" data-v-ca030a68><img src="https://img-community.csdnimg.cn/avatar/ca46c476a908476d9927eaee4b0afc10.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt="" class="share-avatar" data-v-ca030a68> <div class="share-tit" data-v-ca030a68>JavaScript</div> <div class="share-dec" data-v-ca030a68>Web 开发 JavaScript</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> Web 开发 JavaScript </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_91" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/default.jpg!1" alt="JavaScript" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li><li data-v-4722a3ae><a href="https://blog.csdn.net/sysdzw" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/45dcec50fd694b578374e7167ff7914a_sysdzw.jpg!1" alt="无·法" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li></ul></div></div> <div class="actions" data-v-4722a3ae><!----> <div style="flex:1;" data-v-4722a3ae><div class="join-btn" data-v-4722a3ae> 加入社区 </div></div> <!----> <!----></div> <div class="el-dialog__wrapper" style="display:none;" data-v-38c57799 data-v-4722a3ae><div role="dialog" aria-modal="true" aria-label="获取链接或二维码" class="el-dialog join-qrcode-dialog" style="margin-top:15vh;width:600px;"><div class="el-dialog__header"><span class="el-dialog__title">获取链接或二维码</span><button type="button" aria-label="Close" class="el-dialog__headerbtn"><i class="el-dialog__close el-icon el-icon-close"></i></button></div><!----><div class="el-dialog__footer"><span class="dialog-footer" data-v-38c57799></span></div></div></div> <div class="collapse-btn" data-v-4722a3ae><img src="" 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:///JavaScript/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":"cKKF6ytH-iD_qtGZWsRAH78UrOzRMXfiW9k8","origin":"http:\u002F\u002Fbbs.csdn.net","isMobile":false,"cookie":"uuid_tt_dd=10_657698360-1709122695395-330207;","ip":"3.235.145.108","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":"JavaScript","communityHomePage":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FJavaScript","owner":{"userName":"community_91","nickName":"JavaScript","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":"JavaScript","description":"Web 开发 JavaScript","avatarUrl":"https:\u002F\u002Fimg-community.csdnimg.cn\u002Favatar\u002Fca46c476a908476d9927eaee4b0afc10.png?x-oss-process=image\u002Fresize,m_fixed,h_88,w_88","qrCode":"","createTime":"2007-09-28","communityAvatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","communityNotice":null,"userCount":87888,"contentCount":224612,"followersCount":53221,"communityRule":"","communityId":209,"bgImage":"","hashId":"y3w0yonz","domain":"","uriName":"JavaScript","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_91","tagNameInfo":{"provinceTag":null,"areaTag":null,"technologyTags":null,"customTags":null}},"tabList":[{"tabId":1368,"tabName":"全部","tabUrl":"","tabSwitch":1,"tabType":4,"tabContribute":0,"cardType":0,"indexOrder":-1,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FJavaScript?typeId=1368","iframe":false,"sortType":1},{"tabId":873,"tabName":"问答","tabUrl":"https:\u002F\u002Fask.csdn.net\u002Flist\u002F11\u002Ftag\u002F190","tabSwitch":1,"tabType":0,"tabContribute":0,"indexOrder":0,"iframe":true,"sortType":1},{"tabId":4055678,"tabName":"博文收录","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":19,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FJavaScript?typeId=4055678","iframe":false,"sortType":1},{"tabId":1620032,"tabName":"Ada助手","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":20,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FJavaScript?typeId=1620032","iframe":false,"sortType":1}],"dataResource":{"mediaType":"c_cloud","subResourceType":"8_c_cloud_long_text","showType":"long_text","tabId":0,"communityName":"JavaScript","communityHomePageUrl":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FJavaScript","communityType":1,"content":{"id":"330018749","contentId":330018749,"cateId":0,"cateName":null,"url":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F330018749","shareUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F330018749","createTime":"2009-12-30 05:34:22","updateTime":"2021-05-28 16:40:01","resourceUsername":"bug_zone","best":0,"top":0,"text":null,"publishDate":"2009-12-30","lastReplyDate":"2011-06-02","type":"13","nickname":"萧学森","avatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F299f3d6a83d445839432654cff86c3e1_bug_zone.jpg!1","username":"bug_zone","commentCount":8,"diggNum":0,"digg":false,"viewCount":301,"hit":false,"resourceSource":6,"status":10,"taskStatus":null,"expired":false,"taskCate":0,"taskAward":0,"taskExpired":null,"checkRedPacket":null,"avgScore":0,"totalScore":0,"topicTitle":"Ext中.多个tab页中的Form想同时提交怎么处理???","insertFirst":false,"likeInfo":null,"description":"急急急~~~~~","coverImg":"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221109053740.png","content":"急急急~~~~~","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":"bug_zone","roleId":214,"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\u002F15.png","avatarurl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F299f3d6a83d445839432654cff86c3e1_bug_zone.jpg!1","nickname":"萧学森","selfdesc":"自我提高","createdate":"2008-10-13 08:35:00","days":"5617","years":"15","username":"bug_zone","school":null,"company":null,"job":null},"userName":"bug_zone","event":"创建了帖子","body":"2009-12-30 05:34","editId":null}],"resourceExt":{}},"contentReply":{"pageNo":1,"pageSize":20,"totalPages":1,"totalCount":8,"total":0,"list":[{"hit":null,"hitMsg":null,"content":"form1.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\n url:'aaa.do',\u003Cbr \u002F\u003E\n ...\u003Cbr \u002F\u003E\n });\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n form2.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\n url:'bbb.do',\u003Cbr \u002F\u003E\n ...\u003Cbr \u002F\u003E\n });\u003Cbr \u002F\u003E\n \u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n这样写可吗?为什么我的只执行第一个,也就是form1.submit呢?","topicTitle":null,"description":"form1.submit({ url:'aaa.do', ... }); form2.submit({ url:'bbb.do', ... }); 这样写可吗?为什么我的只执行第一个,也就是form1.submit呢?","id":371484648,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"jr1234","userNickName":"DearJr","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fce836a24806045c2aef098f94de84f58_jr1234.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2093871630,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2011-06-02 12:11:41","updateTime":"2011-06-02 12:11:12","formatTime":"2011-06-02","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":"你调用form1.submit()当然只提交第一个...\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n我都忘了我这个贴子的事了..不好意思啊...09年的..汗...","topicTitle":null,"description":"你调用form1.submit()当然只提交第一个... 我都忘了我这个贴子的事了..不好意思啊...09年的..汗...","id":371491245,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"bug_zone","userNickName":"萧学森","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F299f3d6a83d445839432654cff86c3e1_bug_zone.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":1031890770,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2011-06-02 04:34:22","updateTime":"2011-06-02 04:33:53","formatTime":"2011-06-02","userRoleHonorary":{"userName":"bug_zone","roleId":214,"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":"3q.. 我已经解决了.....","topicTitle":null,"description":"3q.. 我已经解决了.....","id":330425578,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"bug_zone","userNickName":"萧学森","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F299f3d6a83d445839432654cff86c3e1_bug_zone.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3662838029,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2009-12-31 05:21:09","updateTime":"2009-12-31 05:20:22","formatTime":"2009-12-31","userRoleHonorary":{"userName":"bug_zone","roleId":214,"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":"学习。","topicTitle":null,"description":"学习。","id":330393615,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"woshifou","userNickName":"woshifou","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fa28a226969984bf29d1f2450614655c6_woshifou.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":1007421606,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2009-12-30 10:42:03","updateTime":"2009-12-30 10:41:17","formatTime":"2009-12-30","userRoleHonorary":{"userName":"woshifou","roleId":214,"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":"N个tab都是一样提交的,只要拿到每个form对象,想怎么操作就这么操作!!","topicTitle":null,"description":"N个tab都是一样提交的,只要拿到每个form对象,想怎么操作就这么操作!!","id":330392574,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"czpae86","userNickName":"21世纪如来神掌","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F5058f51576cb42b1881b1b31c6562c47_czpae86.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3664446521,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2009-12-30 09:52:44","updateTime":"2009-12-30 09:51:57","formatTime":"2009-12-30","userRoleHonorary":{"userName":"czpae86","roleId":214,"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":"[Quote=引用 2 楼 xiuyouxu 的回复:]\u003Cbr \u002F\u003E\n在一个函数里写,给两个form定义变量名,不就可以提交了吗,每个form可以独立提交的\u003Cbr \u002F\u003E\n form1.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\n url:'aaa.do',\u003Cbr \u002F\u003E\n ...\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n form2.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\n url:'bbb.do',\u003Cbr \u002F\u003E\n ...\u003Cbr \u002F\u003E\n }\u003Cbr \u002F\u003E\n[\u002FQuote]\u003Cbr \u002F\u003E\n改成\u003Cbr \u002F\u003E\nform1.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\n url:'aaa.do',\u003Cbr \u002F\u003E\n ...\u003Cbr \u002F\u003E\n });\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n form2.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\n url:'bbb.do',\u003Cbr \u002F\u003E\n ...\u003Cbr \u002F\u003E\n });\u003Cbr \u002F\u003E\n忘了括号了...","topicTitle":null,"description":"[Quote=引用 2 楼 xiuyouxu 的回复:] 在一个函数里写,给两个form定义变量名,不就可以提交了吗,每个form可以独立提交的 form1.submit({ url:'aaa.do', ... } form2.submit({ url:'bbb.do', ... } [\u002FQuote] 改成 form1.submit({ url:'aaa.do', ... }); form2.submit({ url:'bbb.do', ... }); 忘了括号了...","id":330388105,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"xiuyouxu","userNickName":"xiuyouxu","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fcf8cc99091144b628e09beea672ecb7b_xiuyouxu.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3702659202,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2009-12-30 05:56:54","updateTime":"2009-12-30 05:56:08","formatTime":"2009-12-30","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":"在一个函数里写,给两个form定义变量名,不就可以提交了吗,每个form可以独立提交的\u003Cbr \u002F\u003E\nform1.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\nurl:'aaa.do',\u003Cbr \u002F\u003E\n...\u003Cbr \u002F\u003E\n}\u003Cbr \u002F\u003E\nform2.submit({\u003C!-- --\u003E\u003Cbr \u002F\u003E\nurl:'bbb.do',\u003Cbr \u002F\u003E\n...\u003Cbr \u002F\u003E\n}","topicTitle":null,"description":"在一个函数里写,给两个form定义变量名,不就可以提交了吗,每个form可以独立提交的 form1.submit({ url:'aaa.do', ... } form2.submit({ url:'bbb.do', ... }","id":330388035,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"xiuyouxu","userNickName":"xiuyouxu","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fcf8cc99091144b628e09beea672ecb7b_xiuyouxu.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3702659202,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2009-12-30 05:54:48","updateTime":"2009-12-30 05:54:01","formatTime":"2009-12-30","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":"补充一下...两个TAb的From提交表单的路径不一样....","topicTitle":null,"description":"补充一下...两个TAb的From提交表单的路径不一样....","id":330387526,"contentResourceId":330018749,"bindContentResourceId":0,"communityId":209,"username":"bug_zone","userNickName":"萧学森","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F299f3d6a83d445839432654cff86c3e1_bug_zone.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":3662837483,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2009-12-30 05:35:48","updateTime":"2009-12-30 05:35:02","formatTime":"2009-12-30","userRoleHonorary":{"userName":"bug_zone","roleId":214,"roleType":0,"roleStatus":1,"honoraryId":0,"roleName":"","honoraryName":null,"communityNickname":"","communitySignature":""},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null}],"maxPageSize":3000},"defaultActiveTab":1368,"recommends":[{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fu012807534\u002F7975995","title":"\u003Cem\u003EExt\u003C\u002Fem\u003E Js权威指南(.zip.001","desc":"Ex4.0共2个压缩包特性,《\u003Cem\u003Eext\u003C\u002Fem\u003E js权威指南》\n前 言\n第1章 \u003Cem\u003Eext\u003C\u002Fem\u003E js 4开发入门 \u002F 1\n1.1 学习\u003Cem\u003Eext\u003C\u002Fem\u003E js必需的基础知识 \u002F 1\n1.2 json概述 \u002F 3\n1.2.1 认识json \u002F 3\n1.2.2 json的结构 \u002F 3\n1.2.3 json的例子 \u002F 4\n1.2.4 在javascript\u003Cem\u003E中\u003C\u002Fem\u003E使用json \u002F 4\n1.2.5 在.net\u003Cem\u003E中\u003C\u002Fem\u003E使用json \u002F 8\n1.2.6 在java\u003Cem\u003E中\u003C\u002Fem\u003E使用json \u002F 12\n1.2.7 更多有关json的信息 \u002F 15\n1.3 \u003Cem\u003Eext\u003C\u002Fem\u003E js 4概述 \u002F 15\n1.4 \u003Cem\u003Eext\u003C\u002Fem\u003E js的开发工具的获取、安装与配置介绍 \u002F 18\n1.4.1 \u003Cem\u003Eext\u003C\u002Fem\u003E designer \u002F 18\n1.4.2 在visual studio\u003Cem\u003E中\u003C\u002Fem\u003E实现智能提示 \u002F 23\n1.4.3 spket \u002F 28\n1.4.4 在eclipse\u003Cem\u003E中\u003C\u002Fem\u003E实现智能提示 \u002F 32\n1.5 如何获得帮助 \u002F 32\n1.6 本章小结 \u002F 33\n.第2章 从“hello world”开始 \u002F 34\n2.1 获取\u003Cem\u003Eext\u003C\u002Fem\u003E js 4 \u002F 34\n2.2 配置使用\u003Cem\u003Eext\u003C\u002Fem\u003E js库 \u002F 35\n2.3 编写“hello world”程序 \u002F 37\n2.4 关于\u003Cem\u003Eext\u003C\u002Fem\u003E.onready \u002F 38\n2.5 关于\u003Cem\u003Eext\u003C\u002Fem\u003E.blank_image_url \u002F 40\n2.6 关于字体 \u002F 42\n2.7 \u003Cem\u003Eext\u003C\u002Fem\u003E js 4语法 \u002F 42\n2.8 本地化 \u002F 60\n2.9 为本书示例准备一个模板 \u002F 60\n2.10 本章小结 \u002F 61\n第3章 调试工具及技巧 \u002F 62\n3.1 使用firebug进行调试 \u002F 62\n3.2 在ie\u003Cem\u003E中\u003C\u002Fem\u003E调试 \u002F 76\n3.2.1 使用debugbar和companion.js调试 \u002F 76\n3.2.2 使用ietester测试 \u002F 80\n3.2.3 在ie 8或ie 9\u003Cem\u003E中\u003C\u002Fem\u003E调试 \u002F 83\n3.3 在chrome\u003Cem\u003E中\u003C\u002Fem\u003E调试 \u002F 84\n3.4 调试工具的总结 \u002F 84\n3.5 调试技巧 \u002F 85\n3.6 本章小结 \u002F 89\n第4章 \u003Cem\u003Eext\u003C\u002Fem\u003E js的基础架构 \u002F 90\n4.1 \u003Cem\u003Eext\u003C\u002Fem\u003E js框架的命名空间:\u003Cem\u003Eext\u003C\u002Fem\u003E \u002F 90\n4.1.1 概述 \u002F 90\n4.1.2 apply和applyif方法 \u002F 90\n4.1.3 不推荐的\u003Cem\u003Eext\u003C\u002Fem\u003Eend方法 \u002F 92\n4.1.4 数据及其类型检测 \u002F 95\n4.1.5 其他的基础方法 \u002F 99\n4.2 为框架顺利运行提供支持 \u002F 107\n4.2.1 平台检测工具:\u003Cem\u003Eext\u003C\u002Fem\u003E.is \u002F 107\n4.2.2 当前运行环境检测工具:\u003Cem\u003Eext\u003C\u002Fem\u003E.supports \u002F 109\n4.3 \u003Cem\u003Eext\u003C\u002Fem\u003E js的静态方法 \u002F 112\n4.3.1 概述 \u002F 112\n4.3.2 \u003Cem\u003Eext\u003C\u002Fem\u003E.object\u003Cem\u003E中\u003C\u002Fem\u003E的静态方法 \u002F 113\n4.3.3 \u003Cem\u003Eext\u003C\u002Fem\u003E.function\u003Cem\u003E中\u003C\u002Fem\u003E的静态方法 \u002F 120\n4.3.4 \u003Cem\u003Eext\u003C\u002Fem\u003E.array\u003Cem\u003E中\u003C\u002Fem\u003E的静态方法 \u002F 127\n4.3.5 \u003Cem\u003Eext\u003C\u002Fem\u003E.error\u003Cem\u003E中\u003C\u002Fem\u003E的静态方法 \u002F 133\n4.4 深入了解类的创建及管理 \u002F 135\n4.4.1 开始创建类 \u002F 135\n4.4.2 创建类的类:\u003Cem\u003Eext\u003C\u002Fem\u003E.class \u002F 137\n4.4.3 所有继承类的基类:\u003Cem\u003Eext\u003C\u002Fem\u003E.base \u002F 151\n4.4.4 实现动态加载:\u003Cem\u003Eext\u003C\u002Fem\u003E.loader \u002F 151\n4.4.5 管理类的类:\u003Cem\u003Eext\u003C\u002Fem\u003E.classmanager \u002F 159\n4.4.6 类创建的总结 \u002F 161\n4.5 动态加载的路径设置 \u002F 163\n4.6 综合实例:\u003Cem\u003E页\u003C\u002Fem\u003E面计算器 \u002F 165\n4.7 本章小结 \u002F 169\n第5章 \u003Cem\u003Eext\u003C\u002Fem\u003E js的事件及其应用 \u002F 170\n5.1 概述 \u002F 170\n5.2 浏览器事件 \u002F 170\n5.2.1 绑定浏览器事件的过程:\u003Cem\u003Eext\u003C\u002Fem\u003E.eventmanager \u002F 170\n5.2.2 封装浏览器事件:\u003Cem\u003Eext\u003C\u002Fem\u003E.eventobject \u002F 179\n5.2.3 移除浏览器事件 \u002F 181\n5.3 内部事件 \u002F 184\n5.3.1 内部事件对象:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.event \u002F 184\n5.3.2 为组件添加事件接口:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.observable \u002F 188\n5.3.3 为组件绑定事件 \u002F 189\n5.3.4 内部事件的触发过程 \u002F 192\n5.3.5 移除事件 \u002F 194\n5.4 特定功能的事件对象 \u002F 196\n5.4.1 延时任务:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.delayedtask \u002F 196\n5.4.2 一般任务:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.taskrunner与\u003Cem\u003Eext\u003C\u002Fem\u003E.taskmanager \u002F 198\n5.4.3 封装好的单击事件:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.clickrepeater \u002F 200\n5.5 键盘事件 \u002F 201\n5.5.1 为元素绑定键盘事件:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.keymap \u002F 201\n5.5.2 键盘导航:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.keynav \u002F 204\n5.6 综合实例:股票数据的实时更新 \u002F 205\n5.7 本章小结 \u002F 214\n第6章 选择器与dom操作 \u002F 215\n6.1 \u003Cem\u003Eext\u003C\u002Fem\u003E js的选择器:\u003Cem\u003Eext\u003C\u002Fem\u003E.domquery \u002F 215\n6.1.1 选择器的作用 \u002F 215\n6.1.2 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.query选择\u003Cem\u003E页\u003C\u002Fem\u003E面元素 \u002F 215\n6.1.3 基本选择符 \u002F 223\n6.1.4 属性选择符 \u002F 229\n6.1.5 css属性值选择符 \u002F 234\n6.1.6 伪类选择符 \u002F 235\n6.1.7 扩展选择器 \u002F 248\n6.1.8 \u003Cem\u003Eext\u003C\u002Fem\u003E.domquery的使用方法 \u002F 249\n6.1.9 \u003Cem\u003Eext\u003C\u002Fem\u003E js选择器的总结 \u002F 252\n6.2 获取单一元素:\u003Cem\u003Eext\u003C\u002Fem\u003E.dom.element \u002F 252\n6.2.1 从错误开始 \u002F 252\n6.2.2 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.get获取元素 \u002F 253\n6.2.3 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.fly获取元素 \u002F 256\n6.2.4 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.getdom获取元素 \u002F 257\n6.2.5 获取元素的总结 \u002F 258\n6.3 元素生成器:\u003Cem\u003Eext\u003C\u002Fem\u003E.dom.helper \u002F 258\n6.3.1 概述 \u002F 258\n6.3.2 使用createhtml或markup方法生成html代码 \u002F 258\n6.3.3 使用createdom方法生成dom对象 \u002F 261\n6.3.4 使用createtemplate方法创建模板 \u002F 263\n6.3.5 helper对象的使用方法 \u002F 263\n6.4 元素的操作 \u002F 273\n6.5 获取元素集合:\u003Cem\u003Eext\u003C\u002Fem\u003E.compositeelementlite与\u003Cem\u003Eext\u003C\u002Fem\u003E.compositeelement \u002F 277\n6.5.1 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.select获取元素集合 \u002F 277\n6.5.2 \u003Cem\u003Eext\u003C\u002Fem\u003E.dom.compositeelement与\u003Cem\u003Eext\u003C\u002Fem\u003E.dom.compositeelementlite的区别 \u002F 279\n6.5.3 操作元素集合 \u002F 279\n6.6 综合实例:可折叠的面板accordion \u002F 280\n6.7 本章小结 \u002F 283\n第7章 数据交互 \u002F 284\n7.1 数据交互基础 \u002F 284\n7.1.1 ajax概述 \u002F 284\n7.1.2 封装ajax:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.connection与\u003Cem\u003Eext\u003C\u002Fem\u003E.ajax \u002F 284\n7.1.3 使用ajax \u002F 291\n7.1.4 跨域获取数据:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.jsonp \u002F 295\n7.1.5 为element对象提供加载功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.elementloader \u002F 295\n7.1.6 为组件提供加载功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.componentloader \u002F 296\n7.2 代理 \u002F 299\n7.2.1 代理概述 \u002F 299\n7.2.2 基本的代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.proxy \u002F 300\n7.2.3 进行批量操作:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.batch与\u003Cem\u003Eext\u003C\u002Fem\u003E.data.operation \u002F 303\n7.2.4 服务器端代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.server \u002F 305\n7.2.5 使用ajax\u003Cem\u003E处理\u003C\u002Fem\u003E数据的代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.ajax与\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.rest \u002F 308\n7.2.6 跨域\u003Cem\u003E处理\u003C\u002Fem\u003E数据的代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.jsonp \u002F 312\n7.2.7 为\u003Cem\u003Eext\u003C\u002Fem\u003E.direct服务的代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.direct \u002F 312\n7.2.8 客户端代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.client \u002F 314\n7.2.9 从变量\u003Cem\u003E中\u003C\u002Fem\u003E提取数据的代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.memory \u002F 314\n7.2.10 使用浏览器存储的代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.webstorageproxy、\u003Cem\u003Eext\u003C\u002Fem\u003E.data. sessionstorageproxy和\u003Cem\u003Eext\u003C\u002Fem\u003E.data.proxy.localstorage \u002F 314\n7.3 读取和格式化数据 \u002F 315\n7.3.1 概述 \u002F 315\n7.3.2 数据的转换过程:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.reader.xml、\u003Cem\u003Eext\u003C\u002Fem\u003E.data.reader.json和\u003Cem\u003Eext\u003C\u002Fem\u003E.data.reader.array \u002F 315\n7.3.3 reader对象的配置项 \u002F 321\n7.3.4 格式化\u003Cem\u003E提交\u003C\u002Fem\u003E数据:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.writer.writer、\u003Cem\u003Eext\u003C\u002Fem\u003E.data.writer.json和\u003Cem\u003Eext\u003C\u002Fem\u003E.data. writer.xml \u002F 322\n7.3.5 writer对象的配置项 \u002F 325\n7.4 数据模型 \u002F 326\n7.4.1 概述 \u002F 326\n7.4.2 数据类型及排序类型:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.types与\u003Cem\u003Eext\u003C\u002Fem\u003E.data.sorttypes \u002F 326\n7.4.3 数据模型的骨架——字段:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.field \u002F 330\n7.4.4 数据集:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.abstractmixedcollection与\u003Cem\u003Eext\u003C\u002Fem\u003E.util.mixedcollection \u002F 330\n7.4.5 数据验证及错误\u003Cem\u003E处理\u003C\u002Fem\u003E:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.validations与\u003Cem\u003Eext\u003C\u002Fem\u003E.data.errors \u002F 332\n7.4.6 模型的关系:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.association、\u003Cem\u003Eext\u003C\u002Fem\u003E.data.hasmanyassociation和\u003Cem\u003Eext\u003C\u002Fem\u003E.data.belongstoassociation \u002F 334\n7.4.7 管理数据模型:\u003Cem\u003Eext\u003C\u002Fem\u003E.abstractmanager与\u003Cem\u003Eext\u003C\u002Fem\u003E.modelmanager \u002F 336\n7.4.8 定义数据模型:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.model \u002F 336\n7.4.9 数据模型的定义过程 \u002F 337\n7.4.10 数据模型的创建 \u002F 340\n7.4.11 数据模型的配置项、属性和方法 \u002F 343\n7.5 store \u002F 344\n7.5.1 概述 \u002F 344\n7.5.2 store对象的实例化过程 \u002F 345\n7.5.3 treestore对象的实例化过程 \u002F 348\n7.5.4 \u003Cem\u003Eext\u003C\u002Fem\u003E.data.store加载数据的方法 \u002F 350\n7.5.5 \u003Cem\u003Eext\u003C\u002Fem\u003E.data.treestore加载数据的方法 \u002F 354\n7.5.6 store的配置项 \u002F 358\n7.5.7 store的分\u003Cem\u003E页\u003C\u002Fem\u003E \u002F 359\n7.5.8 store的排序:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.sorter与\u003Cem\u003Eext\u003C\u002Fem\u003E.util.sor\u003Cem\u003Etab\u003C\u002Fem\u003Ele \u002F 360\n7.5.9 store的过滤:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.filter \u002F 363\n7.5.10 store的分组:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.grouper \u002F 363\n7.5.11 树节点:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.nodeinterface与\u003Cem\u003Eext\u003C\u002Fem\u003E.data.tree \u002F 364\n7.5.12 store的方法 \u002F 366\n7.5.13 store的事件 \u002F 368\n7.5.14 store管理器:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.storemanager \u002F 369\n7.6 综合实例 \u002F 369\n7.6.1 远程读取json数据 \u002F 369\n7.6.2 读取xml数据 \u002F 378\n7.6.3 store的数据操作 \u002F 379\n7.7 本章小结 \u002F 384\n第8章 模板与组件基础 \u002F 385\n8.1 模板 \u002F 385\n8.1.1 模板概述 \u002F 385\n8.1.2 \u003Cem\u003Eext\u003C\u002Fem\u003E.template的创建与编译 \u002F 385\n8.1.3 格式化输出数据:\u003Cem\u003Eext\u003C\u002Fem\u003E.string、\u003Cem\u003Eext\u003C\u002Fem\u003E.number、\u003Cem\u003Eext\u003C\u002Fem\u003E.date和\u003Cem\u003Eext\u003C\u002Fem\u003E.util.\u003Cem\u003Eform\u003C\u002Fem\u003Eat \u002F 389\n8.1.4 超级模板:\u003Cem\u003Eext\u003C\u002Fem\u003E.xtemplate(包括\u003Cem\u003Eext\u003C\u002Fem\u003E.xtemplateparser和\u003Cem\u003Eext\u003C\u002Fem\u003E.xtemplatecompiler) \u002F 393\n8.1.5 模板的方法 \u002F 396\n8.2 组件的基础知识 \u002F 396\n8.2.1 概述 \u002F 396\n8.2.2 组件类的整体架构 \u002F 397\n8.2.3 布局类的整体架构 \u002F 402\n8.2.4 组件的创建流程 \u002F 403\n8.2.5 常用的组件配置项、属性、方法和事件 \u002F 415\n8.3 为组件添加功能 \u002F 418\n8.3.1 为元素添加阴影:\u003Cem\u003Eext\u003C\u002Fem\u003E.shadow与\u003Cem\u003Eext\u003C\u002Fem\u003E.shadowpool \u002F 418\n8.3.2 为组件提供阴影和shim功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.layer \u002F 419\n8.3.3 让组件实现浮动功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.floating \u002F 420\n8.3.4 记录组件状态:\u003Cem\u003Eext\u003C\u002Fem\u003E.state.stateful \u002F 420\n8.3.5 实现调整大小功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.resizer.resizer与\u003Cem\u003Eext\u003C\u002Fem\u003E.resizer.resizetracker \u002F 420\n8.3.6 为组件提供拖动功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.componentdragger \u002F 421\n8.3.7 为组件实现动画功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.animate \u002F 422\n8.3.8 其他的组件辅助功能类 \u002F 423\n8.4 组件的管理 \u002F 423\n8.4.1 组件管理及查询:\u003Cem\u003Eext\u003C\u002Fem\u003E.componentmanager与\u003Cem\u003Eext\u003C\u002Fem\u003E.componentquery \u002F 423\n8.4.2 焦点管理:\u003Cem\u003Eext\u003C\u002Fem\u003E.focusmanager \u002F 424\n8.4.3 z-order管理:\u003Cem\u003Eext\u003C\u002Fem\u003E.zindexmanager与\u003Cem\u003Eext\u003C\u002Fem\u003E.windowmanager \u002F 425\n8.4.4 状态管理:\u003Cem\u003Eext\u003C\u002Fem\u003E.state.manager、\u003Cem\u003Eext\u003C\u002Fem\u003E.state.provider、\u003Cem\u003Eext\u003C\u002Fem\u003E.state.local-storageprovider和\u003Cem\u003Eext\u003C\u002Fem\u003E.state.cookieprovider \u002F 426\n8.5 综合实例 \u002F 426\n8.5.1 使用子模板 \u002F 426\n8.5.2 递归调用模板 \u002F 428\n8.6 本章小结 \u002F 429\n第9章 容器、面板、布局和视图 \u002F 430\n9.1 容器与布局的关系 \u002F 430\n9.2 容器 \u002F 431\n9.2.1 容器的创建过程:\u003Cem\u003Eext\u003C\u002Fem\u003E.container.abstractcontainer与\u003Cem\u003Eext\u003C\u002Fem\u003E.container.container \u002F 431\n9.2.2  \u003Cem\u003Eext\u003C\u002Fem\u003E.container.abstractcontainer和\u003Cem\u003Eext\u003C\u002Fem\u003E.container.container的配置项、属性、方法和事件 \u002F 434\n9.2.3 将body元素作为容器:\u003Cem\u003Eext\u003C\u002Fem\u003E.container.viewport \u002F 435\n9.3 面板 \u002F 436\n9.3.1 面板的结构 \u002F 436\n9.3.2 构件的放置:dockeditems \u002F 438\n9.3.3 面板标题栏构件:\u003Cem\u003Eext\u003C\u002Fem\u003E.panel.header与\u003Cem\u003Eext\u003C\u002Fem\u003E.panel.tool \u002F 438\n9.3.4 记录和恢复面板属性:\u003Cem\u003Eext\u003C\u002Fem\u003E.util.memento \u002F 439\n9.3.5 面板常用的配置项、方法和事件 \u002F 439\n9.4 布局 \u002F 441\n9.4.1 布局概述 \u002F 441\n9.4.2 布局的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.layout \u002F 441\n9.4.3 容器类布局基类:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.container \u002F 442\n9.4.4 盒子布局、垂直布局与水平布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.box、\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.vbox与\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.hbox \u002F 442\n9.4.5 为盒子模型提供调整大小的功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.resizer.splitter \u002F 445\n9.4.6 手风琴布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.accordion \u002F 447\n9.4.7 锚固布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.anchor \u002F 448\n9.4.8 绝对定位布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.absolute \u002F 450\n9.4.9 边框布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.border \u002F 451\n9.4.10 自动布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.auto \u002F 453\n9.4.11 表格布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.\u003Cem\u003Etab\u003C\u002Fem\u003Ele \u002F 454\n9.4.12 列布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.column \u002F 455\n9.4.13 自适应布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.abstractfit与\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.fit \u002F 456\n9.4.14 卡片布局:\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.abstractcard与\u003Cem\u003Eext\u003C\u002Fem\u003E.layout.container.card \u002F 456\n9.5 标签面板 \u002F 458\n9.5.1 标签面板的构成及其运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Etab\u003C\u002Fem\u003E.panel、\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Etab\u003C\u002Fem\u003E.bar与\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Etab\u003C\u002Fem\u003E.\u003Cem\u003Etab\u003C\u002Fem\u003E \u002F 458\n9.5.2 标签面板的配置项、属性、方法和事件 \u002F 462\n9.5.3 使用标签\u003Cem\u003E页\u003C\u002Fem\u003E \u002F 463\n9.5.4 可重用的标签\u003Cem\u003E页\u003C\u002Fem\u003E \u002F 465\n9.6 视图与选择模型 \u002F 465\n9.6.1 视图与选择模型概述 \u002F 465\n9.6.2 视图的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.view.abstractview与\u003Cem\u003Eext\u003C\u002Fem\u003E.view.view \u002F 466\n9.6.3 选择模型的工作流程 \u002F 475\n9.6.4 选择模型的配置项、属性、方法和事件 \u002F 480\n9.6.5 视图的配置项、属性、方法和事件 \u002F 482\n9.6.6 使用视图 \u002F 484\n9.7 \u003Cem\u003E页\u003C\u002Fem\u003E面布局设计 \u002F 491\n9.8 综合实例 \u002F 492\n9.8.1 布局设计实例:仿eclipse界面 \u002F 492\n9.8.2 在单\u003Cem\u003E页\u003C\u002Fem\u003E面应用\u003Cem\u003E中\u003C\u002Fem\u003E使用卡片布局实现“\u003Cem\u003E页\u003C\u002Fem\u003E面”切换 \u002F 496\n9.9 本章小结 \u002F 498\n第10章 重构后的grid \u002F 500\n10.1 grid的基类及其构成 \u002F 500\n10.1.1 概述 \u002F 500\n10.1.2 表格面板的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.panel.\u003Cem\u003Etab\u003C\u002Fem\u003Ele \u002F 500\n10.1.3 表格视图的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.view.\u003Cem\u003Etab\u003C\u002Fem\u003Ele与\u003Cem\u003Eext\u003C\u002Fem\u003E.view.\u003Cem\u003Etab\u003C\u002Fem\u003Elechunker \u002F 505\n10.1.4 列标题容器的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.header.container \u002F 508\n10.1.5 列标题的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.column.column \u002F 510\n10.1.6 虚拟滚动条的工作原理:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.pagingscroller \u002F 511\n10.1.7 锁定列的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.lockable与\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.lockingview \u002F 516\n10.2 使用grid \u002F 520\n10.2.1 最简单的grid \u002F 520\n10.2.2 列的配置项 \u002F 521\n10.2.3 自定义单元格的显示格式 \u002F 523\n10.2.4 通过列对象定义单元格的显示格式 \u002F 525\n10.2.5 设置行的背景颜色 \u002F 532\n10.2.6 列标题的分组 \u002F 533\n10.2.7 使用锁定列 \u002F 534\n10.2.8 grid的配置项、属性、方法和事件 \u002F 535\n10.3 grid的附加功能 \u002F 537\n10.3.1 概述 \u002F 537\n10.3.2 附加功能基类:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.featrue.featrue \u002F 537\n10.3.3 为行添加附加信息:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.featrue.rowbody \u002F 538\n10.3.4 数据汇总功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.featrue.abstractsummary与\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.featrue. summary \u002F 539\n10.3.5 分组功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.featrue.grouping \u002F 543\n10.3.6 分组汇总功能:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.featrue.groupingsummary \u002F 545\n10.4 可编辑的grid \u002F 546\n10.4.1 概述 \u002F 546\n10.4.2 grid实现可编辑功能的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.plugin.editing \u002F 547\n10.4.3 单元格编辑的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.plugin.cellediting、\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.celleditor与\u003Cem\u003Eext\u003C\u002Fem\u003E.editor \u002F 550\n10.4.4 行编辑的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.plugin.rowediting与\u003Cem\u003Eext\u003C\u002Fem\u003E.grid.roweditor \u002F 556\n10.4.5 在grid\u003Cem\u003E中\u003C\u002Fem\u003E使用单元格编辑模式 \u002F 561\n10.4.6 在grid\u003Cem\u003E中\u003C\u002Fem\u003E使用行编辑模式 \u002F 562\n10.4.7 grid编辑插件的配置项、属性、方法和事件 \u002F 563\n10.5 关于列表视图:listview \u002F 564\n10.6 属性grid \u002F 564\n10.6.1 概述 \u002F 564\n10.6.2 使用属性grid \u002F 564\n10.6.3 自定义编辑组件 \u002F 565\n10.6.4 propertygrid的配置项、属性、方法和事件 \u002F 566\n10.7 综合实例 \u002F 567\n10.7.1 使用不同选择模型的grid以及设置默认选择行 \u002F 567\n10.7.2 grid的本地排序和过滤 \u002F 569\n10.7.3 使用分\u003Cem\u003E页\u003C\u002Fem\u003E工具条(pagingtoolbar)实现远程分\u003Cem\u003E页\u003C\u002Fem\u003E、排序和过滤 \u002F 570\n10.7.4 使用分\u003Cem\u003E页\u003C\u002Fem\u003E滚动条(pagingscroller)实现远程分\u003Cem\u003E页\u003C\u002Fem\u003E、排序和过滤 \u002F 574\n10.7.5 使用cellediting实现数据的增删改 \u002F 578\n10.7.6 使用rowediting实现数据的增删改 \u002F 587\n10.7.7 主从表的显示 \u002F 589\n10.8 本章小结 \u002F 595\n第11章 与grid同源的树 \u002F 597\n11.1 树的构成 \u002F 597\n11.1.1 概述 \u002F 597\n11.1.2 树面板的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.tree.panel \u002F 597\n11.1.3 treestore的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.data.treestore \u002F 600\n11.1.4 treecolumn的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.tree.column \u002F 602\n11.1.5 视图的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.tree.view与\u003Cem\u003Eext\u003C\u002Fem\u003E.data.nodestore \u002F 602\n11.1.6 树的选择模型:\u003Cem\u003Eext\u003C\u002Fem\u003E.selection.treemodel \u002F 603\n11.2 树的使用 \u002F 603\n11.2.1 一个最简单的树 \u002F 603\n11.2.2 树节点的默认字段 \u002F 603\n11.2.3 为树节点添加附加字段 \u002F 604\n11.2.4 显示多列数据(treegrid效果) \u002F 605\n11.2.5 在树\u003Cem\u003E中\u003C\u002Fem\u003E使用复选框 \u002F 605\n11.2.6 树的配置项、属性、方法和事件 \u002F 607\n11.3 综合实例 \u002F 608\n11.3.1 树的远程加载 \u002F 608\n11.3.2 树的动态加载及节点维护 \u002F 610\n11.3.3 xml树及节点维护 \u002F 617\n11.3.4 使用树动态控制grid的显示 \u002F 622\n11.4 本章小结 \u002F 625\n第12章 表单 \u002F 626\n12.1 表单的构成及操作 \u002F 626\n12.1.1 表单面板的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.panel与\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.fieldancestor \u002F 626\n12.1.2 表单面板的配置项、属性、方法和事件 \u002F 628\n12.1.3 表单的管理:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.basic \u002F 629\n12.1.4 basic\u003Cem\u003Eform\u003C\u002Fem\u003E的配置项、属性、方法和事件 \u002F 635\n12.1.5 表单的操作:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.action \u002F 636\n12.1.6 加载操作的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.load与\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.directload \u002F 637\n12.1.7 \u003Cem\u003E提交\u003C\u002Fem\u003E操作的运行流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.submit、\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.directsubmit与\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.standardsubmit \u002F 641\n12.1.8 字段的构成 \u002F 643\n12.1.9 basefield的配置项、属性、方法和事件 \u002F 643\n12.1.10 常用的验证函数:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.vtypes \u002F 647\n12.2 使用字段 \u002F 647\n12.3 使用trigger类字段 \u002F 664\n12.3.1 具有单击功能的字段:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.trigger \u002F 664\n12.3.2 实现微调功能的spinner字段 \u002F 665\n12.3.3 使用numberfield字段 \u002F 666\n12.3.4 下拉选择类字段的基类:\u003Cem\u003Eext\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.picker \u002F 667\n12.3.5 使用datefield字段 \u002F 667\n12.3.6 使用timefield字段 \u002F 669\n12.4 使用combobox字段 \u002F 669\n12.4.1 概述 \u002F 669\n12.4.2 boundlist对象的运行流程 \u002F 670\n12.4.3 combobox字段的配置项、属性、方法和事件 \u002F 671\n12.4.4 最简单的combobox \u002F 672\n12.4.5 自定义列表显示格式的combobox \u002F 673\n12.4.6 动态调整combobox的列表数据 \u002F 674\n12.4.7 实现combobox的联动 \u002F 676\n12.4.8 使用combobox的查询功能 \u002F 684\n12.4.9 设置combobox的默认值 \u002F 688\n12.5 表单的验证和加载数据 \u002F 690\n12.5.1 表单的验证及错误显示方式 \u002F 690\n12.5.2 为表单加载数据 \u002F 695\n12.6 在表单\u003Cem\u003E中\u003C\u002Fem\u003E使用布局 \u002F 701\n12.6.1 分列显示表单的字段 \u002F 701\n12.6.2 使用fieldset作为列容器 \u002F 703\n12.6.3 使用两列布局加htmleditor的表单 \u002F 704\n12.6.4 在表单\u003Cem\u003E中\u003C\u002Fem\u003E使用标签\u003Cem\u003E页\u003C\u002Fem\u003E \u002F 705\n12.7 综合实例:实现products表的管理功能 \u002F 706\n12.8 本章小结 \u002F 715\n第13章 窗口 \u002F 716\n13.1 窗口:\u003Cem\u003Eext\u003C\u002Fem\u003E.window.window. \u002F 716\n13.1.1 窗口的构成 \u002F 716\n13.1.2 窗口的配置项、属性、方法和事件 \u002F 716\n13.1.3 使用窗口 \u002F 718\n13.1.4 在窗口内使用布局 \u002F 719\n13.2 信息提示窗口:\u003Cem\u003Eext\u003C\u002Fem\u003E.window.messagebox \u002F 720\n13.2.1 概述 \u002F 720\n13.2.2 信息提示窗口的构成 \u002F 720\n13.2.3 使用信息提示窗口 \u002F 722\n13.2.4 信息提示窗口按钮的本地化 \u002F 723\n13.2.5 使用alert方法 \u002F 724\n13.2.6 使用confirm方法 \u002F 724\n13.2.7 使用progress方法 \u002F 725\n13.2.8 使用prompt方法 \u002F 726\n13.2.9 使用wait方法 \u002F 727\n13.2.10 使用信息提示窗口要注意的问题 \u002F 727\n13.3 综合实例:实现登录窗口 \u002F 729\n13.4 本章小结 \u002F 733\n第14章 按钮、菜单与工具条 \u002F 734\n14.1 按钮 \u002F 734\n14.1.1 按钮的构成:\u003Cem\u003Eext\u003C\u002Fem\u003E.button.button \u002F 734\n14.1.2 按钮的配置项、属性、方法和事件 \u002F 734\n14.1.3 使用按钮 \u002F 736\n14.1.4 带分割线的按钮:\u003Cem\u003Eext\u003C\u002Fem\u003E.button.split \u002F 737\n14.1.5 多状态按钮:\u003Cem\u003Eext\u003C\u002Fem\u003E.button.cycle \u002F 737\n14.1.6 按钮组:\u003Cem\u003Eext\u003C\u002Fem\u003E.container.buttongroup \u002F 738\n14.2 菜单及菜单项 \u002F 739\n14.2.1 \u003Cem\u003Eext\u003C\u002Fem\u003E js的菜单(menu对象)是什么 \u002F 739\n14.2.2 菜单管理器:\u003Cem\u003Eext\u003C\u002Fem\u003E.menu.manager \u002F 740\n14.2.3 菜单项:\u003Cem\u003Eext\u003C\u002Fem\u003E.menu.item \u002F 740\n14.2.4 可复选的菜单项:\u003Cem\u003Eext\u003C\u002Fem\u003E.menu.checkitem \u002F 741\n14.2.5 菜单分隔条:\u003Cem\u003Eext\u003C\u002Fem\u003E.menu.separator \u002F 741\n14.2.6 颜色选择器菜单:\u003Cem\u003Eext\u003C\u002Fem\u003E.menu.colorpicker \u002F 742\n14.2.7 日期选择菜单:\u003Cem\u003Eext\u003C\u002Fem\u003E.menu.datepicker \u002F 742\n14.2.8 使用菜单 \u002F 742\n14.3 工具栏及工具栏组件 \u002F 743\n14.3.1 工具栏:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.toolbar \u002F 743\n14.3.2 非交互式工具栏条目的基类:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.item \u002F 743\n14.3.3 文本项:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.t\u003Cem\u003Eext\u003C\u002Fem\u003Eitem \u002F 744\n14.3.4 填充项:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.fill \u002F 744\n14.3.5 工具栏分隔条:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.separator \u002F 744\n14.3.6 空白项:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.spacer \u002F 744\n14.3.7 分\u003Cem\u003E页\u003C\u002Fem\u003E工具栏:\u003Cem\u003Eext\u003C\u002Fem\u003E.toolbar.paging \u002F 744\n14.3.8 使用工具栏 \u002F 747\n14.4 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.action \u002F 747\n14.4.1 概述 \u002F 747\n14.4.2 action对象配置项和方法 \u002F 748\n14.4.3 使用示例 \u002F 748\n14.5 综合实例:在grid\u003Cem\u003E中\u003C\u002Fem\u003E使用右键菜单 \u002F 750\n14.6 本章小结 \u002F 752\n第15章 图形与图表 \u002F 753\n15.1 基础知识 \u002F 753\n15.1.1 svg简介 \u002F 753\n15.1.2 vml简介 \u002F 754\n15.2 图形介绍 \u002F 755\n15.2.1 概述 \u002F 755\n15.2.2 画布的工作流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.component \u002F 755\n15.2.3 图形引擎及接口:\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.surface、\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.engine.svg和\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.engine.vml \u002F 757\n15.2.4 画笔:\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.sprite \u002F 760\n15.2.5 图层:\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.compositesprite \u002F 760\n15.2.6 调色板:\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.color \u002F 760\n15.2.7 辅助对象:\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.draw与\u003Cem\u003Eext\u003C\u002Fem\u003E.draw.matrix \u002F 760\n15.3 使用图形功能 \u002F 760\n15.3.1 简单的开始 \u002F 760\n15.3.2 drawcomponent对象的配置项、属性、方法和事件 \u002F 761\n15.3.3 surface对象的配置项、属性、方法和事件 \u002F 761\n15.3.4 drawsprite对象的配置项、属性、方法和事件 \u002F 762\n15.3.5 compositesprite对象的配置项、属性、方法和事件 \u002F 763\n15.3.6 使用基本图形 \u002F 764\n15.3.7 使用图片 \u002F 765\n15.3.8 使用路径 \u002F 766\n15.3.9 移动、旋转和缩放图形 \u002F 767\n15.3.10 使用渐变效果 \u002F 770\n15.3.11 使用图层 \u002F 771\n15.4 图表介绍 \u002F 772\n15.4.1 概述 \u002F 772\n15.4.2 图表的工作流程 \u002F 773\n15.5 使用图表 \u002F 776\n15.5.1 从一个简单例子开始 \u002F 776\n15.5.2 坐标轴的配置项 \u002F 777\n15.5.3 series对象的配置项、属性、方法和事件 \u002F 779\n15.5.4 折线图的配置项 \u002F 780\n15.5.5 显示\u003Cem\u003E多个\u003C\u002Fem\u003E折线图及使用图例 \u002F 782\n15.5.6 使用面积图 \u002F 783\n15.5.7 简单条形图(bar和column chart)及使用标签(label对象) \u002F 785\n15.5.8 堆积条形图 \u002F 787\n15.5.9 分组条形图 \u002F 788\n15.5.10 自定义条形颜色 \u002F 789\n15.5.11 使用散点图 \u002F 789\n15.5.12 使用饼图 \u002F 791\n15.5.13 自定义饼块颜色 \u002F 792\n15.5.14 使用表盘图 \u002F 792\n15.5.15 使用雷达图 \u002F 795\n15.5.16 使用时间轴 \u002F 796\n15.5.17 实现实时动态的图表 \u002F 797\n15.5.18 使用组合图 \u002F 800\n15.5.19 在图表\u003Cem\u003E中\u003C\u002Fem\u003E使用背景 \u002F 801\n15.5.20 在图表\u003Cem\u003E中\u003C\u002Fem\u003E自定义主题 \u002F 803\n15.6 本章小结 \u002F 805\n第16章 其他组件及实用功能 \u002F 806\n16.1 其他组件 \u002F 806\n16.2 使用滑块 \u002F 812\n16.3 使用提示信息 \u002F 814\n16.4 实用功能 \u002F 822\n16.5 本章小结 \u002F 826\n第17章 可简化通信的\u003Cem\u003Eext\u003C\u002Fem\u003E.direct \u002F 827\n17.1 准备工作 \u002F 827\n17.2 \u003Cem\u003Eext\u003C\u002Fem\u003E.direct的工作原理及构成 \u002F 827\n17.2.1 工作原理 \u002F 827\n17.2.2 \u003Cem\u003Eext\u003C\u002Fem\u003E.direct的构成 \u002F 828\n17.2.3 remotingprovider对象的具体工作流程 \u002F 829\n17.2.4 pollingprovider对象的具体工作流程 \u002F 838\n17.3 配置\u003Cem\u003Eext\u003C\u002Fem\u003E.direct的使用环境 \u002F 839\n17.3.1 概述 \u002F 839\n17.3.2 .net环境的配置 \u002F 839\n17.3.3 java环境的配置 \u002F 842\n17.4 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.direct \u002F 846\n17.4.1 概述 \u002F 846\n17.4.2 使用directproxy及进行curd操作 \u002F 846\n17.4.3 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.direct实现树的动态加载及节点维护 \u002F 854\n17.4.4 使用directload为表单加载数据 \u002F 858\n17.4.5 使用directsubmit\u003Cem\u003E提交\u003C\u002Fem\u003E表单及使用session \u002F 863\n17.4.6 使用\u003Cem\u003Eext\u003C\u002Fem\u003E.direct上传文件 \u002F 866\n17.4.7 使用pollingprovider对象 \u002F 868\n17.4.8 错误\u003Cem\u003E处理\u003C\u002Fem\u003E \u002F 871\n17.5 本章小结 \u002F 872\n第18章 动画功能 \u002F 873\n18.1 动画功能的构成及工作流程 \u002F 873\n18.1.1 概述 \u002F 873\n18.1.2 动画功能的工作流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.fx.anim \u002F 874\n18.1.3 分步动画的工作流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.fx.animator \u002F 877\n18.2 使用动画 \u002F 880\n18.2.1 由最简单的动画开始 \u002F 880\n18.2.2 过渡效果使用的功能函数介绍 \u002F 880\n18.2.3 使用分步动画 \u002F 882\n18.2.4 注意的问题 \u002F 883\n18.3 在element对象\u003Cem\u003E中\u003C\u002Fem\u003E使用动画 \u002F 883\n18.4 本章小结 \u002F 888\n第19章 拖放功能 \u002F 889\n19.1 拖放功能的构成及工作流程 \u002F 889\n19.1.1 概述 \u002F 889\n19.1.2 dragdropmanager对象的工作流程 \u002F 891\n19.1.3 注册节点:\u003Cem\u003Eext\u003C\u002Fem\u003E.dd.registry \u002F 893\n19.1.4 一般拖动功能的工作流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.dd.dd \u002F 894\n19.1.5 dragsource对象的工作流程 \u002F 897\n19.1.6 droptarget对象的工作流程 \u002F 898\n19.1.7 dragzone对象的工作流程 \u002F 899\n19.1.8 dropzone对象的工作流程 \u002F 899\n19.2 使用拖放功能 \u002F 899\n19.2.1 最简单的拖动效果 \u002F 899\n19.2.2 使用dragsource对象与droptarget对象 \u002F 900\n19.2.3 使用dragzone对象与dropzone对象(使用registry对象) \u002F 902\n19.2.4 使用dragzone对象与dropzone对象(不使用registry对象) \u002F 903\n19.2.5 通过拖动实现节点排序 \u002F 904\n19.2.6 使用gridviewdropzoneplugin插件 \u002F 905\n19.2.7 使用treeviewdragdropplugin插件 \u002F 907\n19.2.8 关于grid和tree拖动后的数据保存问题 \u002F 910\n19.3 本章小结 \u002F 910\n第20章 扩展与插件 \u002F 911\n20.1 扩展与插件的区别 \u002F 911\n20.2 扩展与插件如何选择 \u002F 911\n20.3 如何编写扩展 \u002F 911\n20.3.1 命名空间 \u002F 911\n20.3.2 定义扩展 \u002F 912\n20.3.3 定义别名 \u002F 912\n20.3.4 定义备用名 \u002F 912\n20.3.5 要求加载的类:requires与uses \u002F 912\n20.3.6 混入功能 \u002F 913\n20.3.7 构造函数与initcomponent方法 \u002F 913\n20.3.8 静态属性和方法与单件模式 \u002F 913\n20.3.9 可自动生成set和get方法的属性与initconfig方法 \u002F 914\n20.3.10 在扩展\u003Cem\u003E中\u003C\u002Fem\u003E常用的方法 \u002F 914\n20.3.11 编写扩展:treecombobox \u002F 914\n20.4 如何编写插件 \u002F 920\n20.4.1 概述 \u002F 920\n20.4.2 abstractplugin对象 \u002F 921\n20.4.3 插件的别名 \u002F 921\n20.4.4 编写插件:rowcolor \u002F 922\n20.5 扩展和插件介绍 \u002F 923\n20.5.1 概述 \u002F 923\n20.5.2 本地分\u003Cem\u003E页\u003C\u002Fem\u003E代理:\u003Cem\u003Eext\u003C\u002Fem\u003E.ux.data.pagingmemoryproxy \u002F 923\n20.5.3 标签滚动菜单:\u003Cem\u003Eext\u003C\u002Fem\u003E.ux.\u003Cem\u003Etab\u003C\u002Fem\u003Escrollermenu \u002F 925\n20.5.4 编辑器tinymce \u002F 926\n20.6 本章小结 \u002F 928\n第21章 主题开发 \u002F 929\n21.1 准备工作 \u002F 929\n21.1.1 安装ruby \u002F 929\n21.1.2 安装compass \u002F 930\n21.1.3 sass介绍 \u002F 931\n21.2 为\u003Cem\u003Eext\u003C\u002Fem\u003E js 4创建新主题 \u002F 933\n21.2.1 概述 \u002F 933\n21.2.2 目录结构 \u002F 933\n21.2.3 修改配置 \u002F 933\n21.2.4 编译 \u002F 935\n21.2.5 测试主题 \u002F 935\n21.3 通过ui配置项设置组件样式 \u002F 937\n21.4 本章小结 \u002F 937\n第22章 mvc应用架构 \u002F 938\n22.1 mvc应用架构的构成及工作流程 \u002F 938\n22.1.1 构成 \u002F 938\n22.1.2 控制器的工作流程:\u003Cem\u003Eext\u003C\u002Fem\u003E.app.controller \u002F 938\n22.1.3 application对象的工作流程 \u002F 940\n22.2 一步一步实现mvc框架 \u002F 942\n22.2.1 概述 \u002F 942\n22.2.2 创建目录 \u002F 942\n22.2.3 创建首\u003Cem\u003E页\u003C\u002Fem\u003E \u002F 942\n22.2.4 创建启动脚本:app.js \u002F 943\n22.2.5 定义登录对话框 \u002F 944\n22.2.6 创建应用脚本:application.js \u002F 948\n22.2.7 创建viewport视图 \u002F 949\n22.2.8 菜单视图及控制器 \u002F 950\n22.2.9 实现订单管理 \u002F 952\n22.2.10 实现产品管理 \u002F 958\n22.2.11 示例效果 \u002F 969\n22.3 本章小结 \u002F 970\n附录 简写类名与\u003Cem\u003Eext\u003C\u002Fem\u003E js类名对照表 \u002F 971","createTime":"2014-09-26 05:57:25","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-7975995-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-7975995-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fu012807534\u002F7975995\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-7975995-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fu012807534\u002F7975995\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-7975995-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fmh942408056\u002F5825091","title":"\u003Cem\u003EExt\u003C\u002Fem\u003EJSWeb应用程序开发指南(第2版)","desc":"前言\n第1章 认识\u003Cem\u003EExt\u003C\u002Fem\u003EJS \n1.1 \u003Cem\u003EExt\u003C\u002Fem\u003EJS的精彩表现 \n1.2 \u003Cem\u003EExt\u003C\u002Fem\u003EJS的前世今生 \n1.3 是否真的需要学习\u003Cem\u003EExt\u003C\u002Fem\u003EJS \n1.4 \u003Cem\u003EExt\u003C\u002Fem\u003EJS4.0新特性 \n1.5 \u003Cem\u003EExt\u003C\u002Fem\u003EJSUI组件基础 \n1.6 了解一下类似技术 \n1.7 本章小结 \n\n第2章 开始\u003Cem\u003EExt\u003C\u002Fem\u003EJS之旅 \n2.1 认识\u003Cem\u003EExt\u003C\u002Fem\u003EJS的开发包 \n2.2 也从Helloworld开始 \n2.3 \u003Cem\u003EExt\u003C\u002Fem\u003EJS\u003Cem\u003E中\u003C\u002Fem\u003E的基本概念 \n2.4 非常有用的开发工具 \n2.4.1 开发插件spket \n2.4.2 FullSource \n2.4.3 MicrosoftScriptDebugger \n2.5 \u003Cem\u003EExt\u003C\u002Fem\u003EJS对原有JavaScript对象的扩展 \n2.5.1 \u003Cem\u003EExt\u003C\u002Fem\u003E.Array \n2.5.2 \u003Cem\u003EExt\u003C\u002Fem\u003E.Date \n2.5.3 \u003Cem\u003EExt\u003C\u002Fem\u003E.Function \n2.5.4 \u003Cem\u003EExt\u003C\u002Fem\u003E.Number \n2.5.5 \u003Cem\u003EExt\u003C\u002Fem\u003E.String \n2.5.6 \u003Cem\u003EExt\u003C\u002Fem\u003E.Object \n2.6 本章小结 \n\n第3章 \u003Cem\u003EExt\u003C\u002Fem\u003EJS4.0的基本功能 \n3.1 \u003Cem\u003EExt\u003C\u002Fem\u003EJS组件配置说明 \n3.1.1 JSON介绍 \n3.1.2 \u003Cem\u003EExt\u003C\u002Fem\u003EJS组件配置方式介绍 \n3.2 信息提示框组件介绍 \n3.2.1 认识\u003Cem\u003EExt\u003C\u002Fem\u003E.window.MessageBox \n3.2.2 \u003Cem\u003EExt\u003C\u002Fem\u003E.MessageBox.alert() \n3.2.3 \u003Cem\u003EExt\u003C\u002Fem\u003E.MessageBox.confirm() \n3.2.4 \u003Cem\u003EExt\u003C\u002Fem\u003E.MessageBox.prompt() \n3.2.5 \u003Cem\u003EExt\u003C\u002Fem\u003E.MessageBox.wait() \n3.2.6 \u003Cem\u003EExt\u003C\u002Fem\u003E.MessageBox.show() \n3.2.7 \u003Cem\u003EExt\u003C\u002Fem\u003E.window.MessageBox的其他功能 \n3.3 进度条组件介绍 \n3.3.1 认识\u003Cem\u003EExt\u003C\u002Fem\u003E.ProgressBar \n3.3.2 手工模式的进度条 \n3.3.3 自动模式的进度条 \n3.3.4 自定义样式的进度条样式 \n3.4 实现工具栏和菜单栏 \n3.4.1 认识\u003Cem\u003EExt\u003C\u002Fem\u003E.toolbar.Toolbar \n3.4.2 只包含按钮的简单工具栏 \n3.4.3 包含多种元素的复杂工具栏 \n3.4.4 启用和禁用工具栏 \n3.4.5 认识\u003Cem\u003EExt\u003C\u002Fem\u003E.menu.Menu菜单 \n3.4.6 最简单的菜单栏 \n3.4.7 创建二级或多级菜单 \n3.4.8 将更多组件加入菜单 \n3.4.9 具有选择框的菜单 \n3.5 本章小结 \n\n第4章 最常用的表单 \n4.1 表单及表单元素 \n4.1.1 了解\u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.Basic基本表单 \n4.1.2 认识\u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.Panel表单面板 \n4.1.3 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Base基础表单字段 \n4.1.4 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.T\u003Cem\u003Eext\u003C\u002Fem\u003E文本域 \n4.1.5 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.T\u003Cem\u003Eext\u003C\u002Fem\u003EArea文本区 \n4.1.6 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Number数字输入框 \n4.1.7 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Checkbox复选框和\u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Radio单选框 \n4.1.8 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.CheckboxGroup和\u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.RadioGroup \n4.1.9 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Trigger触发字段 \n4.1.10 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Spinner微调字段 \n4.1.11 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Picker拾取器字段 \n4.1.12 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.ComboBox组合框 \n4.1.13 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Time时间选择框 \n4.1.14 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Date日期选择框 \n4.1.15 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Hidden隐藏字段 \n4.1.16 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.HtmlEditor编辑器字段 \n4.1.17 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.Display只读文本字段 \n4.1.18 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.Label标签字段 \n4.1.19 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.FieldSet字段集 \n4.1.20 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.FieldContainer容器字段 \n4.1.21 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.field.File文件上传字段 \n4.2 实现表单验证 \n4.2.1 常见的验证类型 \n4.2.2 表单验证(VType) \n4.2.3 自定义VType验证 \n4.3 表单的\u003Cem\u003E提交\u003C\u002Fem\u003E和加载 \n4.3.1 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Eform\u003C\u002Fem\u003E.action.Action基础 \n4.3.2 Ajax模式的表单数据加载 \n4.3.3 Ajax模式的表单数据\u003Cem\u003E提交\u003C\u002Fem\u003E \n4.3.4 标准模式的表单数据\u003Cem\u003E提交\u003C\u002Fem\u003E \n4.3.5 使用Direct技术 \n4.4 本章小结 \n\n第5章 面板及布局类 \n5.1 面板panel \n5.1.1 认识\u003Cem\u003EExt\u003C\u002Fem\u003E.panel.Panel \n5.1.2 \u003Cem\u003EExt\u003C\u002Fem\u003E.panel.Panel的主要功能 \n5.1.3 使用\u003Cem\u003EExt\u003C\u002Fem\u003E.panel.Panel \n5.2 标准布局类 \n5.2.1 Auto自动布局 \n5.2.2 Fit自适应布局 \n5.2.3 Accordion折叠布局 \n5.2.4 Card卡片式布局 \n5.2.5 Anchor锚点布局 \n5.2.6 Absolute绝对位置布局 \n5.2.7 CheckboxGroup复选框组布局 \n5.2.8 Column列布局 \n5.2.9 \u003Cem\u003ETab\u003C\u002Fem\u003Ele表格布局 \n5.2.1 0Border边框布局 \n5.2.1 1Box盒布局 \n5.3 使用ViewPort \n5.4 \u003Cem\u003EExt\u003C\u002Fem\u003E.\u003Cem\u003Etab\u003C\u002Fem\u003E.Panel\u003Cem\u003E页\u003C\u002Fem\u003E签 \n5.5 本章小结 \n\n第6章 常用工具类与函数 \n6.1 非常有用的\u003Cem\u003EExt\u003C\u002Fem\u003E.core.Element \n6.2 \u003Cem\u003EExt\u003C\u002Fem\u003E常用函数 \n6.2.1 \u003Cem\u003EExt\u003C\u002Fem\u003E.onReady() \n6.2.2 \u003Cem\u003EExt\u003C\u002Fem\u003E.get() \n6.2.3 \u003Cem\u003EExt\u003C\u002Fem\u003E.select() \n6.2.4 \u003Cem\u003EExt\u003C\u002Fem\u003E.query() \n6.2.5 \u003Cem\u003EExt\u003C\u002Fem\u003E.getCmp() \n6.2.6 \u003Cem\u003EExt\u003C\u002Fem\u003E.getDom() \n6.2.7 \u003Cem\u003EExt\u003C\u002Fem\u003E.isEmpty() \n6.2.8 \u003Cem\u003EExt\u003C\u002Fem\u003E.namespace() \n6.2.9 \u003Cem\u003EExt\u003C\u002Fem\u003E.each() \n6.2.1 0\u003Cem\u003EExt\u003C\u002Fem\u003E.apply() \n6.2.1 1\u003Cem\u003EExt\u003C\u002Fem\u003E.encode() \n6.2.1 2\u003Cem\u003EExt\u003C\u002Fem\u003E.htmlDecode() \n6.2.1 3\u003Cem\u003EExt\u003C\u002Fem\u003E.typeOf() \n6.3 \u003Cem\u003EExt\u003C\u002Fem\u003E.core.DomHelper \n6.3.1 \u003Cem\u003EExt\u003C\u002Fem\u003E.core.DomHepler.append() \n6.3.2 \u003Cem\u003EExt\u003C\u002Fem\u003E.core.DomHelper.applyStyles() \n6.3.3 createTemplate() \n6.3.4 insertAfter() \n6.3.5 insertBefore() \n6.3.6 insertFirst() \n6.3.7 insertHtml() \n6.3.8 overwrite() \n6.4 \u003Cem\u003EExt\u003C\u002Fem\u003E.core.DomQuery \n6.4.1 compile() \n6.4.2 filter() \n6.4.3 is() \n6.4.4 jsSelect() \n6.4.5 selectNode() \n6.5 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.CSS \n6.5.1 createStyleSheet() \n6.5.2 getRule() \n6.5.3 swapStyleSheet() \n6.5.4 removeStyleSheet() \n6.6 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.ClickRepeater \n6.6.1 click() \n6.6.2 mousedown() \n6.6.3 mouseup() \n6.7 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.DelayedTask提供setTimeout的简单替代 \n6.7.1 cancle() \n6.7.2 delay() \n6.8 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.\u003Cem\u003EForm\u003C\u002Fem\u003Eat提供常用的格式化方法 \n6.8.1 ellipsis() \n6.8.2 capitalize() \n6.8.3 date() \n6.8.4 htmlEncode() \n6.8.5 htmlDecode() \n6.8.6 stripTags() \n6.8.7 substr() \n6.8.8 lowercase() \n6.8.9 number() \n6.8.10 round() \n6.9 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.JSON编码和解码Json对象 \n6.9.1 decode() \n6.9.2 encode() \n6.10 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.MixedCollection \n6.10.1 向集合加入对象 \n6.10.2 将数组\u003Cem\u003E中\u003C\u002Fem\u003E的对象加入到集合\u003Cem\u003E中\u003C\u002Fem\u003E \n6.10.3 移除集合\u003Cem\u003E中\u003C\u002Fem\u003E的对象 \n6.10.4 克隆集合 \n6.10.5 匹配集合\u003Cem\u003E中\u003C\u002Fem\u003E关联对象 \n6.10.6 迭代集合\u003Cem\u003E中\u003C\u002Fem\u003E的对象调用指定的方法 \n6.10.7 获取集合\u003Cem\u003E中\u003C\u002Fem\u003E的对象 \n6.10.8 该类\u003Cem\u003E中\u003C\u002Fem\u003E的其他一些有用的方法 \n6.10.9 该类\u003Cem\u003E中\u003C\u002Fem\u003E重要的事件(Events) \n6.11 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.TaskRunner \n6.11.1 构造函数 \n6.11.2 启动一个线程start() \n6.11.3 停止一个线程stop() \n6.11.4 停止所有的线程stopAll() \n6.12 \u003Cem\u003EExt\u003C\u002Fem\u003E.util.T\u003Cem\u003Eext\u003C\u002Fem\u003EMetrics得到块状化文本规格 \n6.12.1 块的绑定 \n6.12.2 实例化对象 \n6.12.3 获取文本的高度 \n6.12.4 获取文本的宽、高 \n6.12.5 获取文本的宽度 \n6.12.6 获取指定节点内文本块的宽、高 \n6.12.7 指定文本块的宽 \n6.13 \u003Cem\u003EExt\u003C\u002Fem\u003E.KeyNav为元素提供简单的按键\u003Cem\u003E处理\u003C\u002Fem\u003E方法 \n6.13.1 实例化一个键盘绑定对象 \n6.13.2 废弃原有键盘绑定 \n6.13.3 将废弃的键盘绑定重新生效 \n6.14 \u003Cem\u003EExt\u003C\u002Fem\u003E.KeyMap提供更灵活强大的对按键的\u003Cem\u003E处理\u003C\u002Fem\u003E方法 \n6.14.1 构造函数 \n6.14.2 给对象添加键盘绑定 \n6.14.3 废弃已绑定到KeyMap的配置 \n6.14.4 将KeyMap或废弃的配置重新生效 \n6.14.5 获取当前KeyMap配置是否为有效 \n6.14.6 事件绑定函数 \n6.15 本章小结 \n\n第7章 让\u003Cem\u003EExt\u003C\u002Fem\u003EJS开始响应事件 \n第8章 常见Web框架的\u003Cem\u003EExt\u003C\u002Fem\u003EJS改造 \n第9章 \u003Cem\u003EExt\u003C\u002Fem\u003EJS对Ajax的支持 \n第10章 增强型模板 \n第11章 数据模型 \n第12章 Grid组件 \n第13章 Tree组件 \n第14章 \u003Cem\u003EExt\u003C\u002Fem\u003EJS与服务端框架的整合 \n第15章 主题 \n第16章 \u003Cem\u003EExt\u003C\u002Fem\u003E.Direct \n第17章 Draw图形 \n第18章 Chart图表 \n附录A","createTime":"2013-07-27 16:50:00","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-5825091-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-5825091-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fmh942408056\u002F5825091\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-5825091-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fmh942408056\u002F5825091\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-5825091-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fweixin_35857371\u002F11138210","title":"UniGUI 说明","desc":"这个文档\u003Cem\u003E中\u003C\u002Fem\u003E的话题与解决方案, 几乎全部来自 UniGUI 的交流群, 群\u003Cem\u003E中\u003C\u002Fem\u003E活跃的 BDS2007、\ncmj 等人,给了众多使用 UniGUI 的人很多帮助。\n这个文档, 主要是学习与方便后来之人, 文档积累的起因是严肃而正式的, 因为每个人\n都有学习的需求;但文档的所谓版权、著述, 我希望它是有公益色彩的东西,如有哪位不希\n望解决方案不出现在这里,请您告知。\n此外, 就是期待大家都能把自己的一些经验, 给指导和帮助后来人的东西, 在不影响您\n正常工作与其他事情的前提下,奉献出来。至于正确与错误、高超或低下,无关大体。\n目 录\n1. 事件\u003Cem\u003E中\u003C\u002Fem\u003E的代码在服务器端和客户端,哪一端执行? ........................................................... 3\n2. 为什么 UniGUI 控件在 IE\u003Cem\u003E中\u003C\u002Fem\u003E显示的字体会变小、模糊? .................................................... 3\n3. 在浏览器端不能使用 ShowMessage() .................................................................................... 5\n4. 修改工程文件,使 exe 程序编译成 dll .................................................................................. 6\n5. UniGUI 开发的 dll 如何发布 .................................................................................................... 7\n6. uniGUI0.94 以 EXE形式发布程序的布署方法 ..................................................................... 13\n7. uniGUI 执行程序部署有 3 种形式 ......................................................................................... 14\n8. 在 UniGUI 里使用 ADO 的设置 .............................................................................................. 16\n9. MainModule 怎样得到 js 变量的值 ...................................................................................... 16\n10. TUniServerModule 和 TUniMainModule 这两模块有何区别 ....................................... 16\n11. MainModule 里一般放什么, ServerModule 一般放什么? ....................................... 17\n12. 主窗体的标题怎么去掉 ................................................................................................. 17\n13. 用 \u003Cem\u003EExt\u003C\u002Fem\u003EEvent 打开链接和下载文件 ................................................................................. 17\n14. WebApplication 显示对话框 .......................................................................................... 17\n15. Uni \u003Cem\u003E中\u003C\u002Fem\u003E的 UniChart 的 Series增删 .................................................................................. 17\n16. 怎样给每一个在线用户建立一套变量,在用户断开后立即清除 ............................. 18\n17. TUniHiddenPanel 的作用 ................................................................................................ 18\n18. UniDBGrid 如何转为 Excel供下载? ............................................................................. 18\n19. uniGUI 实现 Excel的导出 .............................................................................................. 18\n20. UniDBGrid Excel文件下载 .............................................................................................. 19\n21. Excel文件导入系统 ........................................................................................................ 21\n22. 文件转档与下载 ............................................................................................................. 21\n23. Send File()应用 ............................................................................................................... 21\n24. UniGUI 的 Canvas使用 ................................................................................................... 22\n25. 动态生成 T\u003Cem\u003ETab\u003C\u002Fem\u003ESheet or TUni\u003Cem\u003ETab\u003C\u002Fem\u003ESheet ........................................................................... 22\n26. UniGUI \u003Cem\u003E中\u003C\u002Fem\u003E如果获得 Session情况 .................................................................................. 23\n27. UniGUI Func 之 Sessions ............................................................................................... 23\n28. uniGUI 通过 SessionList操作另外的登录用户 ............................................................ 24\n29. UniGui \u003Cem\u003E中\u003C\u002Fem\u003E如何监听 Session的开始与结束 ................................................................... 25\n30. UniGUI 如何禁止关闭新窗口 ........................................................................................ 27\n31. UniGUI \u003Cem\u003E中\u003C\u002Fem\u003E控件类名的变化 ............................................................................................ 27\n32. 再议 UniGUI \u003Cem\u003E中\u003C\u002Fem\u003E使用 Grid+Rport 报表控件 (推荐此方法 ) ............................................. 28\n33. UniGUI 的布局面板控件 TUniRegionPanel ................................................................... 28\n34. UniGUI 使用报表 Grid+Report 的方法之一 (静态调用 ) ................................................ 28\n35. UniGUI 使用报表 Grid+Report 的方法之二 (动态调用 ) ................................................ 28\n36. UniGUI \u003Cem\u003E中\u003C\u002Fem\u003E Cookies 使用\u003Cem\u003E中\u003C\u002Fem\u003E文汉字的方法 ...................................................................... 28\n37. UniGUI 如何实现压缩传输数据? ................................................................................ 29\n38. UniGUI 的 ShowModal .................................................................................................... 29\n39. UniGUI 前台用户如何在软件\u003Cem\u003E中\u003C\u002Fem\u003E点击一个按钮打开浏览器并打开地址? ................ 29\n40. How To Make Caption In UniGUI? ................................................................................. 30\n41. 在 UniGUI 的 UniHtmlFrame \u003Cem\u003E中\u003C\u002Fem\u003E不能使用的 HTML 标签 .............................................. 30\n42. 利用 UniGUI \u003Cem\u003E中\u003C\u002Fem\u003E的 TUniPageControl 实现多\u003Cem\u003E页\u003C\u002Fem\u003E面 .......................................................... 30\n43. UniGUI TreeView \u003Cem\u003E处理\u003C\u002Fem\u003E .................................................................................................... 31\n44. UniGUI 设置超时 ........................................................................................................... 31\n45. UniGUI 如何实现登陆\u003Cem\u003E页\u003C\u002Fem\u003E面 ............................................................................................ 31\n46. UniGUI 如何实现超链接 ................................................................................................ 32\n47. 从 ASP网站登录到 UniGUI \u003Cem\u003E中\u003C\u002Fem\u003E ....................................................................................... 32\n48. UniGUI 数据库初始化要放到 MainModule 里 ............................................................. 32\n49. UniGUI Cookies ................................................................................................................ 32\n50. \u003Cem\u003EForm\u003C\u002Fem\u003E Inheritance ............................................................................................................. 33\n51. UniGUI 组件\u003Cem\u003E中\u003C\u002Fem\u003E的 Client JavaScript Delphi 组件之间的操作 ......................................... 33\n52. JS能取 Delphi 控件的值? ............................................................................................ 34\n53. 写 js 的注意 .................................................................................................................... 34\n54. unigui 结合 JS方法记录 ................................................................................................. 34\n55. JS,Jquery获取各种屏幕的宽度和高度 ......................................................................... 35\n56. uniGUI 动态建立 \u003Cem\u003EForm\u003C\u002Fem\u003E 及释放 ...................................................................................... 37\n57. uniGUI 经验两则 uniTimer uniHtmlFrame .................................................................... 37\n58. uniGUI 使用百度地图 api 进行标注 .............................................................................. 37\n59. fileupload 的问题 ........................................................................................................... 38\n60. unigui unidbgrid 显示列的合计值 ................................................................................. 38\n61. UniGui \u003Cem\u003E中\u003C\u002Fem\u003E设置 uniEdit 控件的 fieldLabel ,emptyT\u003Cem\u003Eext\u003C\u002Fem\u003E 等 \u003Cem\u003EExt\u003C\u002Fem\u003Ejs 属性 .............................. 40\n62. uniGUI 用 Grid++Report 报表插件设计保存报表 (For unigui ver:0.95.0.1045) ............ 40\n63. UniGUI 的 TUniLogin\u003Cem\u003EForm\u003C\u002Fem\u003E 窗口自定义背景色 .............................................................. 46\n64. uniGUI 显示 Warning: \u003Cem\u003EForm\u003C\u002Fem\u003E must be shown after it is created 的解决办法 ................. 46\n65. 界面上的快捷方式 ......................................................................................................... 46\n66. 调用 WebService............................................................................................................. 47\n67. TUniTreeView 的 CheckBox ............................................................................................ 49\n68. 通过 URL来获取相关参数 ............................................................................................ 52\n69. uniDBGrid 实行多选表格行 ........................................................................................... 52\n70. UniDBGrid 增加显示记录数的 label 及隐藏 refresh 按钮 ............................................ 56\n71. 对 UniDBGrid 的单元格操作 .......................................................................................... 57\n72. DBGrid 多选后计算问题(是否可以作为参考?) .................................................... 58\n73. UniDBGrid 选择字段 Boolean \u003Cem\u003E处理\u003C\u002Fem\u003E ................................................................................ 59\n74. UniDBGrid 自带 MultiSelect 无法使用【最新版可以】 ............................................... 60\n75. 如何打开 URL,让系统看起来舒服点 ......................................................................... 61\n76. 如何修改 UniGUI 下的\u003Cem\u003E中\u003C\u002Fem\u003E文信息 ................................................................................... 62\n77. 如何实现 UniDBGrid 下字段显示按钮 .......................................................................... 62\n78. 如何实现 UniDBGrid 下字段自动换行 .......................................................................... 62\n79. 如何结合 kbmMW .......................................................................................................... 63\n80. 如何规避浏览器访问时 ajax 异常 ................................................................................ 63\n81. 事件操作时,如果出现等待效果 ................................................................................. 63\n82. 登录\u003Cem\u003E页\u003C\u002Fem\u003E面和主\u003Cem\u003E页\u003C\u002Fem\u003E面切换之间碰到的异常 ..................................................................... 63\n83. 让 Page \u003Cem\u003E中\u003C\u002Fem\u003E切换 \u003Cem\u003ETab\u003C\u002Fem\u003E效果稍微好一点 ........................................................................... 64\n84. UniImage 可以嵌入 PNG图片 ....................................................................................... 64\n85. UniImage 自带导入 PNG图片的问题 ........................................................................... 65","createTime":"2019-04-23 10:08:49","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-11138210-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-11138210-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fweixin_35857371\u002F11138210\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-11138210-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fweixin_35857371\u002F11138210\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-11138210-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130","title":"\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet_v2.3.2_dll","desc":"\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet - \u003Cem\u003EExt\u003C\u002Fem\u003EJS based ASP.NET Controls with Full AJAX Support\n\t\n\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet是一组专业的Asp.net控件库,拥有原生的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注:\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet基于一些开源的程序\u003Cem\u003EExt\u003C\u002Fem\u003EJS, HtmlAgilityPack, Nii.JSON, YUICompressor。\n\n示例: http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Easp.net\u002F\n开源: http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Easpnet.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时,确保\u003Cem\u003E页\u003C\u002Fem\u003E面不会出错。\n\t-修正了Grid列属性Data\u003Cem\u003EForm\u003C\u002Fem\u003EatString的一个bug,比如设置{0:yy-MM-dd HH:mm}时没有效果。\n\t-修正下拉列表控件不能绑定Data\u003Cem\u003ETab\u003C\u002Fem\u003Ele的BUG(feedback:RedOcean)。\n\t-增加土耳其语言资料文件(feedback:abdullaharslan)。\n\t-Grid的BoundField增加NullDisplayT\u003Cem\u003Eext\u003C\u002Fem\u003E属性,用于\u003Cem\u003E处理\u003C\u002Fem\u003E数据库\u003Cem\u003E中\u003C\u002Fem\u003E的null值,如果没有设置则默认为空字符串。\n\t-修正DatePicker\u003Cem\u003E中\u003C\u002Fem\u003E的一个bug(31\u002F01\u002F2010将会返回NULL)使用Date\u003Cem\u003EForm\u003C\u002Fem\u003EatString来生成SelectedDate属性(feedback:OktaEndy)。\n\t-修正\u003Cem\u003Eext\u003C\u002Fem\u003Ejs最新版本(v3.2.2)\u003Cem\u003E中\u003C\u002Fem\u003E的一个bug,如果下拉列表\u003Cem\u003E中\u003C\u002Fem\u003E存在两个相同的T\u003Cem\u003Eext\u003C\u002Fem\u003E,则SelectedValue返回值永远是第一个T\u003Cem\u003Eext\u003C\u002Fem\u003E的值(feedback:ben.zhou)。\n\t-应用补丁#6593, #6621(feedback:vbelyaev)。\n\t+修正IE7下Grid分\u003Cem\u003E页\u003C\u002Fem\u003E速度慢(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-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件将不在依赖ViewState,减少1\u002F4左右的HTTP数据传输量。\n\t-控件和示例的增强。\n\t\n\t\n\n+2010-03-28 v2.2.1\n\t+为\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的GetAdd\u003Cem\u003ETab\u003C\u002Fem\u003EReference函数增加重载方法,以便指定\u003Cem\u003ETab\u003C\u002Fem\u003E的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首\u003Cem\u003E页\u003C\u002Fem\u003E最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成\u003Cem\u003EExt\u003C\u002Fem\u003Ejs最新版本v3.1.1。\n\t\t-增加一个新的Theme - Access。\n\t\t-修正了Firefox下Zoom In\u002FOut时\u003Cem\u003E页\u003C\u002Fem\u003E面消失的BUG。\n\t\t-删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。\n\n\n\n+2010-01-31 v2.2.0\n\t-使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax\u003Cem\u003E提交\u003C\u002Fem\u003E)(feedback:261629698)。\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加GetAdd\u003Cem\u003ETab\u003C\u002Fem\u003EReference和GetRemove\u003Cem\u003ETab\u003C\u002Fem\u003EReference两个函数,用来向\u003Cem\u003ETab\u003C\u002Fem\u003EStrip控件动态增加删除\u003Cem\u003ETab\u003C\u002Fem\u003E。\n\t\t-增加示例\u003Cem\u003Etab\u003C\u002Fem\u003Estrip\u002F\u003Cem\u003Etab\u003C\u002Fem\u003Estrip_add\u003Cem\u003Etab\u003C\u002Fem\u003E.aspx。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加Enable\u003Cem\u003ETab\u003C\u002Fem\u003ECloseMenu属性,是否启用右键菜单,可用来关闭当前\u003Cem\u003ETab\u003C\u002Fem\u003E和所有其他\u003Cem\u003ETab\u003C\u002Fem\u003E。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window控件更新。\n\t\t-关闭按钮默认直接关闭,不会弹出确认对话框。\n\t\t-GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedHideReference的函数\u003Cem\u003E中\u003C\u002Fem\u003E的Confirm\u003Cem\u003EForm\u003C\u002Fem\u003EModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居\u003Cem\u003E中\u003C\u002Fem\u003E,而不是黄金分割位置。\n\t+Button, Window等控件弹出位置属性的变化。\n\t\t-Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target=\"_self\" -\u003E Target=\"Self\", Target=\"_parent\" -\u003E Target=\"Parent\"。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。\n\t\t-Confirm.GetShowReference的最后一个参数target变为枚举类型。\n\t\t-Alert.GetShowReference\u003Cem\u003E中\u003C\u002Fem\u003E的showInParent参数也变为Target枚举类型。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。\n\n\n\n+2010-01-06 v2.1.9\n\t-集成\u003Cem\u003EExt\u003C\u002Fem\u003Ejs最新版本v3.1.0。\n\t-修正灰色皮肤的CSS问题。\n\t-修正Grid的列名\u003Cem\u003E中\u003C\u002Fem\u003E不能包含\u003Cem\u003E中\u003C\u002Fem\u003E文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件\u003Cem\u003E中\u003C\u002Fem\u003E不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其\u003Cem\u003E中\u003C\u002Fem\u003E的Close全部改为Hide。\n\t-增加\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u003Cem\u003E中\u003C\u002Fem\u003E\u003Cem\u003ETab\u003C\u002Fem\u003E控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument\u003Cem\u003E中\u003C\u002Fem\u003EIcon属性映射错误(feedback:nopnop9)。\n\t-修正HtmlEditor不能编辑的BUG(feedback:TheBox)。\n\t-修正IE下有时会出现空白\u003Cem\u003E页\u003C\u002Fem\u003E面的情况(feedback:olivia919)。\n\t\n\t\n\n+2009-12-06 v2.1.8\n\t-修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。\n\t-修正了IE下Grid\u003Cem\u003E中\u003C\u002Fem\u003E的一个JS问题(feedback:lqm4108)。\n\t-修正Alert消息\u003Cem\u003E中\u003C\u002Fem\u003E引号未编码导致的JS错误(feedback:sun1299shine)。\n\t+集成\u003Cem\u003Eext\u003C\u002Fem\u003Ejs3.0.3。\n\t\t-修正弹出对话框的宽度计算错误(会保持最小的状态)。\n\t\t-增加新的皮肤Gray。\n\t-为示例工程添加改变语言和皮肤的下拉列表。\n\t-为PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E增加静态函数Refresh,在切换语言和皮肤时使用。\t\n\n\n\n+2009-12-01 v2.1.7\n\t-增加示例(iframe\u002Fparent_postback_run3.aspx),如何通过简单的Javascript代码回发父\u003Cem\u003E页\u003C\u002Fem\u003E面(feedback:eroach)。\n\t-修正一些书写错误(feedback:bmck)。\n\t-从Region控件\u003Cem\u003E中\u003C\u002Fem\u003E删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。\n\t-BorderPanel更名为RegionPanel。\n\t-DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。\n\t-增加\u003Cem\u003E中\u003C\u002Fem\u003E国的省市县三级联动示例(data\u002Fshengshixian.aspx)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的\u003Cem\u003ETab\u003C\u002Fem\u003E在切换过程\u003Cem\u003E中\u003C\u002Fem\u003E会重复加载的问题,这是一个在v2.1.6引入的问题(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-修正\u003Cem\u003EForm\u003C\u002Fem\u003E不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器控件(比如Panel,Region,\u003Cem\u003ETab\u003C\u002Fem\u003E等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的实现,避免选\u003Cem\u003E中\u003C\u002Fem\u003E某项后的闪烁。\n\t\t\t\n\n\n+2009-11-21 v2.1.5\n\t+Tree优化。\n\t\t-修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。\n\t\t-GetNodeById更名为FindNode,保持和FindControl一致命名。\n\t\t-删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。\n\t\t-删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。\n\t\t-增加示例(data\u002Ftree_select_run.aspx),如何选\u003Cem\u003E中\u003C\u002Fem\u003E当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet\u003Cem\u003E中\u003C\u002Fem\u003E的一个命名约定。\n\t\t\t-同时更名的还有GridColumn的ColumnId-\u003EColumnID,GetColumnId-\u003EGetColumnID。\n\t\t\t-Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。\n\t\t-为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。\n\t-为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.aspx)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#\u003Cem\u003E处理\u003C\u002Fem\u003E函数来响应键盘事件。\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的关闭按钮提示信息一直是\u003Cem\u003E中\u003C\u002Fem\u003E文的BUG(feedback:thebox)。\n\t-部分\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件的设计时支持(会在后续版本\u003Cem\u003E中\u003C\u002Fem\u003E逐步完善)。\n\t-v0.2beta2版本\u003Cem\u003E中\u003C\u002Fem\u003E关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。\n\t-修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为T\u003Cem\u003Eext\u003C\u002Fem\u003EBox,T\u003Cem\u003Eext\u003C\u002Fem\u003EArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:\u003Cem\u003Eform\u003C\u002Fem\u003E\u002F\u003Cem\u003Eform\u003C\u002Fem\u003E_validate.aspx\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的控件属性列表(\u002Fajax.aspx)。\n\t\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程\u003Cem\u003E中\u003C\u002Fem\u003E会反映到\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E,但并不是所有的控件属性都支持AJAX改变。\n\t-加载s.gif图片在本机进行,不会请求\u003Cem\u003Eext\u003C\u002Fem\u003Ejs.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保Asp.net的按钮控件仍然具有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\u003Cem\u003E中\u003C\u002Fem\u003ETemplateField生成到\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,\u003Cem\u003EForm\u003C\u002Fem\u003E等)增加枚举类型Icon,其\u003Cem\u003E中\u003C\u002Fem\u003E包含1700\u003Cem\u003E多个\u003C\u002Fem\u003E小图标。\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-如果需要在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出确认对话框,需要设置ConfirmTarget=\"_parent\"(类似Window控件的Target=\"_parent\")。\n\t+为\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-一个典型应用,在Window控件\u003Cem\u003E中\u003C\u002Fem\u003E打开新\u003Cem\u003E页\u003C\u002Fem\u003E面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Alert.Show(\"参数错误!\", String.Empty, \u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以自动回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Easp.net\u002Fdata\u002Ftree_run.aspx\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选\u003Cem\u003E中\u003C\u002Fem\u003E任何一项时在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出对话框的JS代码。\n\t-修正IE7下不能以下划线作为CSS\u003Cem\u003E中\u003C\u002Fem\u003E类名的前缀的BUG(feedback:Steve.Wei)。\n\t-添加定时器控件Timer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree控件的AJAX实现。\n\t+为\u003Cem\u003E页\u003C\u002Fem\u003E面的\u003Cem\u003EForm\u003C\u002Fem\u003E添加autocomplete=\"off\"属性。\n\t\t-参考http:\u002F\u002Fwww.cnblogs.com\u002Fsanshi\u002Farchive\u002F2009\u002F09\u002F04\u002F1560146.html#1635830\n\t+添加对\u003Cem\u003Eext\u003C\u002Fem\u003Ejs3.0\u003Cem\u003E中\u003C\u002Fem\u003E所有语言的支持。\n\t\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet扩展的多语言包在js\\languages\\\u003Cem\u003Eext\u003C\u002Fem\u003Easpnet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其\u003Cem\u003E中\u003C\u002Fem\u003E添加自己的语言版本,并执行js\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口。\n\t+在aspx\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E必须显示的声明控件的集合属性(比如\u003Cem\u003ETab\u003C\u002Fem\u003Es(\u003Cem\u003ETab\u003C\u002Fem\u003EStrip), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将会影响所有的aspx\u003Cem\u003E页\u003C\u002Fem\u003E面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX\u003Cem\u003E中\u003C\u002Fem\u003E使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管\u003Cem\u003ETab\u003C\u002Fem\u003EStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将会影响所有的aspx\u003Cem\u003E页\u003C\u002Fem\u003E面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config\u003Cem\u003E中\u003C\u002Fem\u003E修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree控件的一个BUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Current,而不是一个全局变量。\n\t -这个BUG导致Asp.net compatibility\u003Cem\u003E中\u003C\u002Fem\u003E的示例无法完成,现在已经修正。\n\t+去除PageManager\u003Cem\u003E中\u003C\u002Fem\u003E方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。\n\t -这个属性和Button得Validate\u003Cem\u003EForm\u003C\u002Fem\u003Es属性类似,可以查看Asp.net compatibility\u003Cem\u003E中\u003C\u002Fem\u003E的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复\u003Cem\u003E提交\u003C\u002Fem\u003E - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid\u003Cem\u003E中\u003C\u002Fem\u003E每个单元格的值了。\n -增加示例-如何将Grid控件导出为Excel(data\\grid_excel_run.aspx)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不会被选\u003Cem\u003E中\u003C\u002Fem\u003E(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.aspx)。\n -修正Panel图标不能显示的BUG(CSS\u003Cem\u003E中\u003C\u002Fem\u003Eclass名不能有$字符)。\n +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,\u003Cem\u003EForm\u003C\u002Fem\u003E,GroupPanel,Simple\u003Cem\u003EForm\u003C\u002Fem\u003E,Tree还是Grid,\u003Cem\u003ETab\u003C\u002Fem\u003EStrip)都可以通过这种方式全屏。\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的内部实现,每个\u003Cem\u003E页\u003C\u002Fem\u003E面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId自动生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet和Asp.net的\u003Cem\u003E提交\u003C\u002Fem\u003E按钮兼容问题(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX\u003Cem\u003E提交\u003C\u002Fem\u003E,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们做了优化,现在要使一个Asp.net的按钮能够AJAX\u003Cem\u003E提交\u003C\u002Fem\u003E,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E设置需要在AJAX\u003Cem\u003E中\u003C\u002Fem\u003E需要更新的Asp.net控件了。\n\t\t-在Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E设置了哪些需要在AJAX\u003Cem\u003E中\u003C\u002Fem\u003E更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。\n\t\t-示例在aspnet\\fckeditor_run.aspx和aspnet\\aspnet_run.aspx。\n\t\t-FCKEditor和上传控件兼容。示例在aspnet\\fileupload_run.aspx。\n\t-修正ToolbarT\u003Cem\u003Eext\u003C\u002Fem\u003E的文本在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的\u003Cem\u003EForm\u003C\u002Fem\u003Es Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和Asp.Net Ajax类似的\u003Cem\u003E处理\u003C\u002Fem\u003E方式,需要在配置文件Web.config增加一个httpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Redirect重定向\u003Cem\u003E页\u003C\u002Fem\u003E面,两者效果一样。\n\t\t-支持\u003Cem\u003EForm\u003C\u002Fem\u003EsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。\n\t-Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。\n\t-修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。\n\t-修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。\n\t-增加Menu和Accordion的示例。\n\t-修正Window控件的IconUrl有时不显示(Target=\"_parent\")的BUG[feedback:xmq&mgzhenhong]。\n\t\n\n\n+2009-07-22 v2.0 beta3\n\t-兼容FCKEditor。\n\t-在IE8.0,Firefox3.5下测试通过。以后\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet将不会对IE6.0提供支持。\n\t\n\n\n+2009-07-13 v2.0 beta2\n\t-集成\u003Cem\u003Eext\u003C\u002Fem\u003Ejs最新版本v3.0。\n\t+兼容IE6.0-7.0-8.0。\n\t\t-这应该是\u003Cem\u003EExt\u003C\u002Fem\u003Ejs3.0的一个BUG,在IE6.0-7.0下面设置\u003Cem\u003EExt\u003C\u002Fem\u003E.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。\n\t\t-目前先禁用IE6.0-7.0的QuickTips。\n\t-优化底层JavaScript。\n\t\n\t\n\t\n+2009-07-05 v2.0 beta1\n\t-更新\u003Cem\u003Eext\u003C\u002Fem\u003Ejs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个\u003Cem\u003E页\u003C\u002Fem\u003E面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。\n\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet自身的CSS会紧挨着\u003Cem\u003E页\u003C\u002Fem\u003E面标签引入,这样在\u003Cem\u003E中\u003C\u002Fem\u003E自定义的样式可以覆盖\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet缺省样式。\n\t+Alert对话框会遮挡所有的Window窗口。\n\t\t-使用一个变通的方法解决,因为无法改变\u003Cem\u003EExt\u003C\u002Fem\u003E.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。\t\n\t-为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。\n\t-因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选\u003Cem\u003E中\u003C\u002Fem\u003E第一项。\n\t-重新绑定模拟树的下拉列表后,选\u003Cem\u003E中\u003C\u002Fem\u003E项的前面有图片的HTML标签的BUG。\n\t-更新自定义JavaScript组件\u003Cem\u003EExt\u003C\u002Fem\u003E.ux.SimplePagingToolbar。\n\t-更新示例工程。\n\t\n\t\n\n+2009-03-25 v1.3.1\n\t-Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed]\n\t-Window\u003Cem\u003E中\u003C\u002Fem\u003E的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed]\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生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-如果弹出的窗口(\u003Cem\u003EExt\u003C\u002Fem\u003E-Window)含有ASP.NET控件FileUpload,则此弹出窗口在关闭时出现JS错误(http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Ejs.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E存在ASP.NET控件(T\u003Cem\u003Eext\u003C\u002Fem\u003EBox),则第二次\u003Cem\u003E提交\u003C\u002Fem\u003E表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed]\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面上放置\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet-Button和ASP.NET-Button,则点击\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和\u003Cem\u003EExt\u003C\u002Fem\u003Ejs2.2.1\u003Cem\u003E中\u003C\u002Fem\u003E\u003Cem\u003EExt\u003C\u002Fem\u003E.Ajax.serialize\u003Cem\u003EForm\u003C\u002Fem\u003E的实现有关。[fixed]\n\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet工程\u003Cem\u003E中\u003C\u002Fem\u003E使用ASP.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件和ASP.NET标准控件和平共处了。[fixed]\n\t\t-如果一个ASP.NET按钮控件要使用\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet的原生AJAX回发时更新ASP.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet\u002Faspnet.aspx)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新\u003Cem\u003E页\u003C\u002Fem\u003E面重试。”。[fixed]\n\t-自动测试功能会在以后版本\u003Cem\u003E中\u003C\u002Fem\u003E逐步完善。这个版本完成测试框架,采用\u003Cem\u003EExt\u003C\u002Fem\u003Ejs\u003Cem\u003E中\u003C\u002Fem\u003EJS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E静态类\u003Cem\u003E中\u003C\u002Fem\u003E的GetPageStateChangedFunction改名为GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedReference,底层代码优化。表示“获取当前\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E的GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedReference,使用CurrentActiveWindow\u003Cem\u003E中\u003C\u002Fem\u003E的GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseReference\u002FGetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseRefreshReference\u002FGetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedClosePostBackReference三个方法代替。\n\t\t-不会修改弹出\u003Cem\u003E页\u003C\u002Fem\u003E面的URL(\u003Cem\u003EExt\u003C\u002Fem\u003E-Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame),以前为了实现功能为每个弹出\u003Cem\u003E页\u003C\u002Fem\u003E面添加box_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Get\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的ASPX\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E查找RegisterPageStateChangedScript属性,并删除,否则会运行错误!\n\t\t-A\u003Cem\u003E页\u003C\u002Fem\u003E面有\u003Cem\u003EExt\u003C\u002Fem\u003E-Window控件弹出B\u003Cem\u003E页\u003C\u002Fem\u003E面,B\u003Cem\u003E页\u003C\u002Fem\u003E面有\u003Cem\u003EExt\u003C\u002Fem\u003E-Window控件弹出C\u003Cem\u003E页\u003C\u002Fem\u003E面,B\u003Cem\u003E页\u003C\u002Fem\u003E面的\u003Cem\u003EExt\u003C\u002Fem\u003E-Window控件设置Target='_parent',则弹出的\u003Cem\u003EExt\u003C\u002Fem\u003E-Window(C\u003Cem\u003E页\u003C\u002Fem\u003E面)会覆盖整个A\u003Cem\u003E页\u003C\u002Fem\u003E面,这是正确的。\n\t\t---当时如果用户直接访问B\u003Cem\u003E页\u003C\u002Fem\u003E面,就会报JS错误,因为此时找不到B\u003Cem\u003E页\u003C\u002Fem\u003E面的父\u003Cem\u003E页\u003C\u002Fem\u003E面A了。现在的版本修正为如果找不到父\u003Cem\u003E页\u003C\u002Fem\u003E面,则就在当前\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口,这样用户直接访问B\u003Cem\u003E页\u003C\u002Fem\u003E面也不会出错了。\n\t\t-Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseReference,表示“获取先确认IFrame的\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window控件增加如下两个方法GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseRefreshReference和GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出\u003Cem\u003EExt\u003C\u002Fem\u003E-Window,再然后刷新父\u003Cem\u003E页\u003C\u002Fem\u003E面或回发父\u003Cem\u003E页\u003C\u002Fem\u003E面”。\n\t\t---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父\u003Cem\u003E页\u003C\u002Fem\u003E面或者关闭后回发父\u003Cem\u003E页\u003C\u002Fem\u003E面的行为。\n\t\t-如果弹出窗口(Window控件)\u003Cem\u003E中\u003C\u002Fem\u003EIFrame的\u003Cem\u003E页\u003C\u002Fem\u003E面不能正常加载(网络暂时出错或\u003Cem\u003E页\u003C\u002Fem\u003E面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时\u003Cem\u003E页\u003C\u002Fem\u003E面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时\u003Cem\u003E页\u003C\u002Fem\u003E面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window控件的IFrameName属性是自动生成的,只读属性。(因为有可能所有的\u003Cem\u003EExt\u003C\u002Fem\u003E-Window最终都渲染到最外层的\u003Cem\u003E页\u003C\u002Fem\u003E面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部\u003Cem\u003E处理\u003C\u002Fem\u003E)。\n\t\t-CurrentActiveWindow改名为ActiveWindow。\n\t\t-[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values)\n\t\t---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed]\n\t-DropDownList在\u003Cem\u003E页\u003C\u002Fem\u003E面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed]\n\t-升级底层\u003Cem\u003EExt\u003C\u002Fem\u003EJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed]\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面加载过程\u003Cem\u003E中\u003C\u002Fem\u003E的时间信息保存在Javascript变量window.box.timeInfo\u003Cem\u003E中\u003C\u002Fem\u003E。[added]\n\t+增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选\u003Cem\u003E中\u003C\u002Fem\u003E任何一项,回发时报错[feedback:huihuang]。[fixed]\n\t-Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed]\n\t+PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E优化。[fixed]\n\t\t-去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。\n\t\t-去除RegisterStartupScript的重载函数,只保留最简单的PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript(string script)函数。\n\t\t-Resirect增加重载函数Redirect(string url, string target),其\u003Cem\u003E中\u003C\u002Fem\u003Etarget可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image控件增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包\u003Cem\u003E中\u003C\u002Fem\u003E增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed]\n\t-ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed]\n\t-Row和Column布局时,修正IE下设置RowHeight=\"100%\"时显示不正确的BUG。[fixed]\n\t-AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed]\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003E控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此\u003Cem\u003ETab\u003C\u002Fem\u003E都会回发)。[fixed]\n\t\t-有这样一个效果,如果\u003Cem\u003ETab\u003C\u002Fem\u003E1默认显示,\u003Cem\u003ETab\u003C\u002Fem\u003E1的EnablePostBack=true,则\u003Cem\u003E页\u003C\u002Fem\u003E面加载完毕后会回发\u003Cem\u003ETab\u003C\u002Fem\u003E1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-aspnet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemT\u003Cem\u003Eext\u003C\u002Fem\u003E\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new \u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选\u003Cem\u003E中\u003C\u002Fem\u003E[feedback:jqpeng]。\n\t\t\t-和Asp.net\u003Cem\u003E中\u003C\u002Fem\u003E的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string t\u003Cem\u003Eext\u003C\u002Fem\u003E, string value),这样方便后台添加列表项。\n\t-处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS\u003Cem\u003E中\u003C\u002Fem\u003E的height不同,CSS\u003Cem\u003E中\u003C\u002Fem\u003E的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有控件属性增加在VS\u003Cem\u003E中\u003C\u002Fem\u003E的智能提示。[fixed]\n\t\t-需要将\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.XML和\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。\n\t+控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed]\n\t\t-TriggerIconType.Default -\u003E TriggerIconType.None\n\t\t-SystemIconType.Empty -\u003E SystemIconType.None\n\t\t-RegexPattern.USER_DEFINED -\u003E RegexPattern.None\n\t-表单验证属性名称变化(ValueToCompare-\u003ECompareValue,ControlToCompare-\u003ECompareControl)。[fixed]\n\t+注意:一个属性可以拥有\u003Cem\u003E多个\u003C\u002Fem\u003E值的情况。[fixed]\n\t\t-属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。\n\t\t-其他的都是逗号分隔(比如Validate\u003Cem\u003EForm\u003C\u002Fem\u003Es,DataKeyNames,DataNavigateUrlFields)。\n\t+AccordionLink实现为控件。[fixed]\n\t\t-可以方便的在子\u003Cem\u003E页\u003C\u002Fem\u003E面(iframe)\u003Cem\u003E中\u003C\u002Fem\u003E通过js切换父\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E选\u003Cem\u003E中\u003C\u002Fem\u003E的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.aspx,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的动态添加控件,并且可以给控件添加服务器端事件(示例在\u003Cem\u003Eform\u003C\u002Fem\u003E\u002F\u003Cem\u003Eform\u003C\u002Fem\u003E_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属性进行验证,而不是T\u003Cem\u003Eext\u003C\u002Fem\u003E属性。\n\t\t-DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。\n\t\t-DropDownList不支持EmptyT\u003Cem\u003Eext\u003C\u002Fem\u003E属性。\n\t\t-ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)\u003Cem\u003E中\u003C\u002Fem\u003E设置哪些项不可选择,以及创建模拟下拉树。\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\u003Cem\u003E中\u003C\u002Fem\u003E的容器,比如ContentPanel需要在外层加上标签。\n\t\t-适当增大AccordionPanel\u003Cem\u003E中\u003C\u002Fem\u003E链接的高度20px-\u003E22px,同时对链接的样式也做了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少ASPX\u003Cem\u003E中\u003C\u002Fem\u003EHTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在ASPX\u003Cem\u003E页\u003C\u002Fem\u003E切换到“设计时”,方便属性的更改和事件\u003Cem\u003E处理\u003C\u002Fem\u003E函数的添加)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u002FToolbar\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E动态添加控件的BUG,现在\u003Cem\u003Eform\u003C\u002Fem\u003E\u002F\u003Cem\u003Eform\u003C\u002Fem\u003E_dynamic_run.aspx示例已经能正确运行。[fixed]\n\t+大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的控件包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FWindow等。\n\t\t-保留\u003Cem\u003EForm\u003C\u002Fem\u003E的Rows(\u003Cem\u003EForm\u003C\u002Fem\u003ERowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003Es(\u003Cem\u003ETab\u003C\u002Fem\u003ECollection)属性。\n\t\t-保留PageLayout\u002FBorderLayout的Regions(RegionCollection)属性。\n\t-预祝今晚神七发射成功。\n\t\n\t\n\t\n+2008-09-22 v1.2 beta2\n\t+Grid选\u003Cem\u003E中\u003C\u002Fem\u003E项(SelectedRowIndexArray)在ajax回发过程\u003Cem\u003E中\u003C\u002Fem\u003E存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选\u003Cem\u003E中\u003C\u002Fem\u003E项\u003Cem\u003E中\u003C\u002Fem\u003E会存在当前不存在的行序号,导致服务器端遍历选\u003Cem\u003E中\u003C\u002Fem\u003E项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例\u003Cem\u003E中\u003C\u002Fem\u003E表单控件都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FButton\u002FHyperLink\u002FLabel\u002FImage\u002FLinkButton\u002FT\u003Cem\u003Eext\u003C\u002Fem\u003EBox\n\t\t-TriggerBox\u002FTwinTriggerBox\u002FWindow\u002FT\u003Cem\u003Eext\u003C\u002Fem\u003EArea\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-修正\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FSimple\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E隐藏一个表单字段(Hidden=false)会占据\u003Cem\u003E页\u003C\u002Fem\u003E面空间的BUG。\n\t-ToolbarT\u003Cem\u003Eext\u003C\u002Fem\u003E\u002FToolbarFill\u002FToolbarSeparator在ASPX\u003Cem\u003E中\u003C\u002Fem\u003E设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed]\n\t-Button去除MarginRight属性(可以通过CssStyle=\"margin-right:5px;\"达到相同的效果)[fixed]\n\t\n\t\n\t\n+2008-09-09 v1.1\n\t+Toolbar去除IsPageMenu属性,在网报\u003Cem\u003E中\u003C\u002Fem\u003E可以用自定义样式实现,而不应该写在控件\u003Cem\u003E中\u003C\u002Fem\u003E。[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\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E六种布局,总共有9\u003Cem\u003E中\u003C\u002Fem\u003E布局可供使用。\n\t\t-其\u003Cem\u003E中\u003C\u002Fem\u003E一些控件默认使用一种布局:Simple\u003Cem\u003EForm\u003C\u002Fem\u003E(\u003Cem\u003EForm\u003C\u002Fem\u003E)\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E(\u003Cem\u003EForm\u003C\u002Fem\u003E)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002F\u003Cem\u003ETab\u003C\u002Fem\u003EStrip(Card),所有布局控件默认的布局是Container。\n\t\t-经常用到的布局控件:Simple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FAccordion\u002F\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuT\u003Cem\u003Eext\u003C\u002Fem\u003E增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。\n\t\t-US的\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报\u003Cem\u003E中\u003C\u002Fem\u003E唯一没有用到\u003Cem\u003EExt\u003C\u002Fem\u003EAspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Redirect支持普通\u003Cem\u003E页\u003C\u002Fem\u003E面转向和\u003Cem\u003EExt\u003C\u002Fem\u003EAspNetAjax下\u003Cem\u003E页\u003C\u002Fem\u003E面转向。[fixed]\n\t+模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,\u003Cem\u003ETab\u003C\u002Fem\u003EStrip)。\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后,保持项是否可选状态是最新的(\u003Cem\u003E页\u003C\u002Fem\u003E面第一次加载时,即使没有数据也需要设置DataT\u003Cem\u003Eext\u003C\u002Fem\u003EField\u002FDataValueField\u002FDataSimulateTreeLevelField\u002FDataEnableSelectField等属性的值,否则Ajax回发时会出错)。[fixed]\n\t-UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用AspnetAjax,这个控件已经完成使命)。[fixed]\n\t-不要使用Asp.net的控件HiddenField,而是使用\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet的HiddenField,因为Asp.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList\u003Cem\u003E中\u003C\u002Fem\u003E项如果存在汉字,则会换行的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E如果有ContentPanel,则在\u003Cem\u003E页\u003C\u002Fem\u003E面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢\u003Cem\u003E页\u003C\u002Fem\u003E面的加载速度),现在已经解决这个问题。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(Simple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E)的背景色一致。[fixed]\n\t-TwinTriggerBox的第一个Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config\u003Cem\u003E中\u003C\u002Fem\u003E增加配置项\u003Cem\u003EForm\u003C\u002Fem\u003ELabelWidth=\"80\"(默认为80),同时PageManager增加\u003Cem\u003EForm\u003C\u002Fem\u003ELabelWidth属性用来控制\u003Cem\u003E页\u003C\u002Fem\u003E面上所有Simple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E的表单字段标题的宽度。[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-ToolbarT\u003Cem\u003Eext\u003C\u002Fem\u003E增加Ajax可更新属性T\u003Cem\u003Eext\u003C\u002Fem\u003E。\n\t\t\n\t\t\n\t\t\n+2008-08-31 v1.1 beta3\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加EnableDeferredRender属性(是否启用延迟加载\u003Cem\u003ETab\u003C\u002Fem\u003E,默认启用)。[fixed]\n\t-重定向\u003Cem\u003E页\u003C\u002Fem\u003E面,使用系统的方法 PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Redirect(string url),使用Response.Redirect方法会出错。[fixed]\n\t+安全的Ajax设计。[fixed]\n\t\t-这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。\n\t\t-基本思\u003Cem\u003E想\u003C\u002Fem\u003E:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。\n\t\t-整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。\n\t-网报Ajax整合(目前只支持所有的列表\u003Cem\u003E页\u003C\u002Fem\u003E面)(v0.8.1)。[fixed]\n\t\n\t\n\t\n+2008-08-29 v1.1 beta1\n\t+Window控件是否弹出的状态在回发时维持。[fixed]\n\t\t-控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃Asp.NetAjax,\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件内置Ajax支持。[fixed]\n\t\t-这是一个值得骄傲的设计,可以明显提高\u003Cem\u003E页\u003C\u002Fem\u003E面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager\u003Cem\u003E中\u003C\u002Fem\u003E有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件\u003Cem\u003E中\u003C\u002Fem\u003E设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前\u003Cem\u003EExt\u003C\u002Fem\u003EAspNetAjax的限制。\n\t\t\t-只对\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件起作用,对Asp.net控件不起作用。\n\t\t\t-对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。\n\t\t\t-对改变控件的Visible属性会有错误。\n\t\t\t-Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用\u003Cem\u003E页\u003C\u002Fem\u003E面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个\u003Cem\u003E页\u003C\u002Fem\u003E面都添加PageLoading控件。[fixed]\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选\u003Cem\u003E中\u003C\u002Fem\u003E的状态在回发后会得到保持。[fixed]\n\t-Grid选\u003Cem\u003E中\u003C\u002Fem\u003E行的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父\u003Cem\u003E页\u003C\u002Fem\u003E面加载一个比较大的css文件(~100k),则每次打开iframe\u003Cem\u003E页\u003C\u002Fem\u003E面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003EIFrame的显示速度。[fixed]\n\t\t-在当前\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口需要~20ms,在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报\u003Cem\u003E中\u003C\u002Fem\u003E需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、\u003Cem\u003EForm\u003C\u002Fem\u003EMessageTarget、\u003Cem\u003EForm\u003C\u002Fem\u003EOffsetRight等属性,这些属性可以在Web.config\u003Cem\u003E中\u003C\u002Fem\u003E设置(推荐方法),也可以为每个\u003Cem\u003E页\u003C\u002Fem\u003E面设置。[fixed]\n\t\t-一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器\u003Cem\u003E中\u003C\u002Fem\u003ECookie设置的值)(示例在default.aspx)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u003Cem\u003E中\u003C\u002Fem\u003E非当前\u003Cem\u003ETab\u003C\u002Fem\u003E会延迟渲染。[fixed]\n\t\t-这会明显加快\u003Cem\u003E页\u003C\u002Fem\u003E面的渲染速度,网报\u003Cem\u003E中\u003C\u002Fem\u003E一个典型的费用审批\u003Cem\u003E页\u003C\u002Fem\u003E面可以减少200ms的渲染时间。\n\t\t-由于非当前\u003Cem\u003ETab\u003C\u002Fem\u003E不会在\u003Cem\u003E页\u003C\u002Fem\u003E面加载时渲染,所以那些\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E的节点在\u003Cem\u003E页\u003C\u002Fem\u003E面加载后也是不可见的,需要将相关的脚本移动到控件的render事件\u003Cem\u003E中\u003C\u002Fem\u003E。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip延迟加载引起的BUG(非当前\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E的ContentPanel会占据\u003Cem\u003E页\u003C\u002Fem\u003E面空间,已修正)。[fixed]\n\t-全新的\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Examples(基础知识\u002F表单控件\u002F数据绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E使用父\u003Cem\u003E页\u003C\u002Fem\u003E面的脚本和样式(示例在iframe\u002Fdefault.aspx和iframe\u002Fpage3.aspx)。[fixed]\n\t\t-测试发现,IFrame\u003Cem\u003E页\u003C\u002Fem\u003E面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout\u003Cem\u003E中\u003C\u002Fem\u003E显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+\u003Cem\u003Eext\u003C\u002Fem\u003Ejs的BUG,当\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E含有iframe时,\u003Cem\u003EExt\u003C\u002Fem\u003E.onReady会被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.\u003Cem\u003Eext\u003C\u002Fem\u003Ejs.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.aspx)[fixed]\n\t\t-现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true;\n\t+需要先回发\u003Cem\u003E页\u003C\u002Fem\u003E面再弹出IFrame窗口。[fixed]\n\t\t-在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。\n\t\t-另一种做法(推荐):PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript(Window99.GetShowReference(\".\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下会有JS错误。[fixed]\n\t-增加BorderLayout控件,示例在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-动态向\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E添加\u003Cem\u003EForm\u003C\u002Fem\u003ERow,并动态的向\u003Cem\u003EForm\u003C\u002Fem\u003ERow\u003Cem\u003E中\u003C\u002Fem\u003E添加表单字段,以及如何取得表单字段的值。(示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_dynamic.aspx)[fixed]\n\t+IFrame弹出窗口关闭后回发父\u003Cem\u003E页\u003C\u002Fem\u003E面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是一个重要的BUG,会严重影响\u003Cem\u003E页\u003C\u002Fem\u003E面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父\u003Cem\u003E页\u003C\u002Fem\u003E面后Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame被添加到\u003Cem\u003E页\u003C\u002Fem\u003E面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在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+修正一个的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面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框架\u003Cem\u003EExt\u003C\u002Fem\u003Ejs升级为v2.2,Grid的渲染速度有很大提升。[fixed]\n\t-Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight=\"true\"解决)。[fixed]\n\t+\u003Cem\u003E页\u003C\u002Fem\u003E面正在加载的提示尽早的显示出来。[fixed]\n\t\t-首先在执行js来完成\u003Cem\u003E页\u003C\u002Fem\u003E面渲染之前延迟5ms,以便浏览器把当前\u003Cem\u003E页\u003C\u002Fem\u003E面内容显示出来。\n\t\t-加载js脚本的script标签放置在\u003Cem\u003E页\u003C\u002Fem\u003E面的最后,放置加载js而阻塞PageLoading的显示。\n\t\n\t\n\t\n+2008-08-08 v0.4 beta2\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip延时加载出错。[fixed]\n\t-Window的IFrameUrl\u003Cem\u003E处理\u003C\u002Fem\u003E的BUG,比如Pages_\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet目录下的\u003Cem\u003E页\u003C\u002Fem\u003E面应该为.\u002FFE_ApplyEditor.aspx或~\u002FPages_\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet\u002FFE_ApplyEditor.aspx。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则会JS错误。[fixed]\n\t-实现网报首\u003Cem\u003E页\u003C\u002Fem\u003E下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在\u003Cem\u003E页\u003C\u002Fem\u003E面显示后进行,不计算在js渲染时间内。[fixed]\n\t-优化费用申请\u003Cem\u003E页\u003C\u002Fem\u003E面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.aspx默认会加载\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面(Window控件的BUG)。[fixed]\n\t-Window\u003Cem\u003E中\u003C\u002Fem\u003E的保存并关闭按钮和Asp.netAjax冲突。[fixed]\n\t-优化关闭Window的js脚本,减少写到\u003Cem\u003E页\u003C\u002Fem\u003E面的js大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的Asp.net控件一样不可编辑。[fixed]\n\t-DropDownList增加SelectedT\u003Cem\u003Eext\u003C\u002Fem\u003E属性(去除了模拟树时通过SelectedItem.T\u003Cem\u003Eext\u003C\u002Fem\u003E的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的js对象的名称简单化,这样可以减少生成的js内容,加快\u003Cem\u003E页\u003C\u002Fem\u003E面加载速度(一个典型\u003Cem\u003E页\u003C\u002Fem\u003E面的js由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003E,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在\u003Cem\u003E页\u003C\u002Fem\u003E面的Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E,if (!IsPostBack){PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterPageStateChangedStartupScript();}通过这样方法向\u003Cem\u003E页\u003C\u002Fem\u003E面注册了一段脚本,但是这段脚本在回发时没有注册到\u003Cem\u003E页\u003C\u002Fem\u003E面,因为js调用此脚本时报错。\n\t\t-一种解决方法是将向\u003Cem\u003E页\u003C\u002Fem\u003E面注册脚本的函数移动到if语句的外面,即每次都向\u003Cem\u003E页\u003C\u002Fem\u003E面注册此脚本。\n\t\t-另一种办法就是在PageManager控件\u003Cem\u003E中\u003C\u002Fem\u003E增加RegisterPageStateChangedScript(向\u003Cem\u003E页\u003C\u002Fem\u003E面注册监视\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E表单内容改变的脚本)的属性(会在每次\u003Cem\u003E页\u003C\u002Fem\u003E面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)。\n\t+PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed]\n\t\t-这个手工添加onReady函数能够在每次\u003Cem\u003E页\u003C\u002Fem\u003E面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报\u003Cem\u003E中\u003C\u002Fem\u003E遇到这种情况)。\n\t-每个\u003Cem\u003E页\u003C\u002Fem\u003E面必须添加一个PageManager控件,否则会出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed]\n\t-T\u003Cem\u003Eext\u003C\u002Fem\u003EField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少\u003Cem\u003E页\u003C\u002Fem\u003E面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父\u003Cem\u003E页\u003C\u002Fem\u003E面,也可在关闭后刷新或回发父\u003Cem\u003E页\u003C\u002Fem\u003E面。(default.aspx\u002Fpage2.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加一个属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,控件本身封装了大量的代码,简单来看现在有三个\u003Cem\u003E页\u003C\u002Fem\u003E面(default.aspx(A)\u002Fpage2.aspx(B)\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx(C)),其\u003Cem\u003E中\u003C\u002Fem\u003EA包含B\u003Cem\u003E页\u003C\u002Fem\u003E面,当你在B\u003Cem\u003E中\u003C\u002Fem\u003E打开包含有\u003Cem\u003E页\u003C\u002Fem\u003E面C的窗口时,窗口不是在B\u003Cem\u003E中\u003C\u002Fem\u003E打开,而是在A\u003Cem\u003E中\u003C\u002Fem\u003E打开,这样才能保证窗口覆盖整个\u003Cem\u003E页\u003C\u002Fem\u003E面,当你从C\u003Cem\u003E中\u003C\u002Fem\u003E返回需要回发\u003Cem\u003E页\u003C\u002Fem\u003E面B时,却发现取得的是A\u003Cem\u003E页\u003C\u002Fem\u003E面,因为我们窗口是在A\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E创建的。我会通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid\u003Cem\u003E中\u003C\u002Fem\u003E弹出窗口。(default.aspx\u002Fpage3.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.aspx\u002Ftriggerbox.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)\t\n\t\t\t-在整个\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口或者在当前\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003E的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下\u003Cem\u003ETab\u003C\u002Fem\u003EStrip在Ajax回发后不会去掉x-hide-display样式,导致\u003Cem\u003ETab\u003C\u002Fem\u003E显示为空的BUG。[fixed]\n\t-对\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u002FPanel\u002FWindow\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到\u003Cem\u003E页\u003C\u002Fem\u003E面节点,同时第二次打开Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame不会有残影出现。[fixed]\n\t-如果\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003E不是激活\u003Cem\u003ETab\u003C\u002Fem\u003E并且设置了IFrameUrl,则会延迟加载(示例在\u003Cem\u003Etab\u003C\u002Fem\u003Estrip_iframe.aspx)。[fixed]\n\t-Tree控件,点击一个节点自动回发,则当前点击的那个节点的选\u003Cem\u003E中\u003C\u002Fem\u003E状态不会保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe\u003Cem\u003E中\u003C\u002Fem\u003E关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx,PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript增加重载函数),而不是原来的先创建整个\u003Cem\u003E页\u003C\u002Fem\u003E面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将JS文件引用由head移动到body\u003Cem\u003E中\u003C\u002Fem\u003E。[fixed]\n\t-Firefox下,如果\u003Cem\u003E页\u003C\u002Fem\u003E面太长会出滚动条,原来在ViewPort样式\u003Cem\u003E中\u003C\u002Fem\u003E有body{overflow:hidden;}。[fixed]\n\t+IFrame内的\u003Cem\u003E页\u003C\u002Fem\u003E面宽度和高度会自动设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E2.aspx)[fixed]\n\t\t-增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个\u003Cem\u003E页\u003C\u002Fem\u003E面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息\u003Cem\u003E中\u003C\u002Fem\u003EMessageTarget改名为\u003Cem\u003EForm\u003C\u002Fem\u003EMessageTarget,增加\u003Cem\u003EForm\u003C\u002Fem\u003EOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image控件 [feedback:jima]。[fixed]\n\t-Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起\u003Cem\u003E页\u003C\u002Fem\u003E面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed]\n\t-去掉DropDownList控件的T\u003Cem\u003Eext\u003C\u002Fem\u003E属性(强制性),可以通过设置SelectedValue来设置选\u003Cem\u003E中\u003C\u002Fem\u003E哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息\u003Cem\u003E中\u003C\u002Fem\u003E的换行符(转换为),否则提示信息可能导致\u003Cem\u003E页\u003C\u002Fem\u003E面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree控件。[fixed]\n\t\t-如何将数据库\u003Cem\u003E中\u003C\u002Fem\u003E的数据绑定到Tree(示例在tree2_bind_da\u003Cem\u003Etab\u003C\u002Fem\u003Ease.aspx)。\n\t\t-ajax加载树节点,放在UpdatePanel\u003Cem\u003E中\u003C\u002Fem\u003E才有ajax的效果(示例在tree2_ajax.aspx)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树\u003Cem\u003E中\u003C\u002Fem\u003E不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同一个\u003Cem\u003E页\u003C\u002Fem\u003E面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltip\u003Cem\u003EForm\u003C\u002Fem\u003EatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选\u003Cem\u003E中\u003C\u002Fem\u003E样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才行(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed]\n\t\t-虽然最后未能解决##差旅交通费在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+增加树控件(Tree)(示例在tree2.aspx)。[fixed]\n\t\t-可以在回发时维持树的状态(选\u003Cem\u003E中\u003C\u002Fem\u003E行,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式添加树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到\u003Cem\u003E页\u003C\u002Fem\u003E面,也可以引发PostBack事件,可以添加自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E放置\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件,则渲染时会出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E渲染\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件,如果容器的display='none',则会出现各种问题(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。\n\t+IE6下,在应用Asp.NetAjax后,\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。\n\t\t-最后发现IE6下应用Asp.NetAjax后不仅\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数\u003Cem\u003E中\u003C\u002Fem\u003E,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E所有表单的宽度(box_fix\u003Cem\u003EForm\u003C\u002Fem\u003EWidthInIE6();):\n\t\t 示例在 Site.Master \u003Cem\u003E页\u003C\u002Fem\u003E面。\n\t+集成的AspNetAjax有一个很大的BUG,只要你在\u003Cem\u003E页\u003C\u002Fem\u003E面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();),\n\t\t 这样的代码让我\u003Cem\u003E想\u003C\u002Fem\u003E起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。\n\t\n\t\n\t\n+2008-07-14 v0.3 beta6\n\t-增加FlashObject控件。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选\u003Cem\u003E中\u003C\u002Fem\u003E样式微调。[fixed]\n\t-预加载\u003Cem\u003EForm\u003C\u002Fem\u003E表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快\u003Cem\u003E页\u003C\u002Fem\u003E面的渲染速度(一个典型的20个记录的\u003Cem\u003E页\u003C\u002Fem\u003E面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid\u003Cem\u003E中\u003C\u002Fem\u003E静态的CheckBoxField图片。[fixed]\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加\u003Cem\u003ETab\u003C\u002Fem\u003EIndexChanged事件,同时\u003Cem\u003ETab\u003C\u002Fem\u003E增加EnablePostBack,可以在点击一个\u003Cem\u003ETab\u003C\u002Fem\u003E时引起回发事件。这在延迟加载\u003Cem\u003ETab\u003C\u002Fem\u003E的内容非常有用。(示例在\u003Cem\u003Etab\u003C\u002Fem\u003Estrip.aspx)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_compare.aspx)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和T\u003Cem\u003Eext\u003C\u002Fem\u003EBox比较大小需要指定CompareType。\n\t+如果在编辑\u003Cem\u003E页\u003C\u002Fem\u003E面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx\u002Fajax_editor.aspx)。[fixed]\n\t\t-这是由于ajax后执行的javascript\u003Cem\u003E中\u003C\u002Fem\u003E不能有return false语句。\n\t+在文本框失去焦点时,执行一些Javascript脚本(示例在t\u003Cem\u003Eext\u003C\u002Fem\u003Ebox_blur.aspx) [feedback:xmzhu]。[fixed]\n\t\t-在\u003Cem\u003E页\u003C\u002Fem\u003E面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误\u003Cem\u003E页\u003C\u002Fem\u003E面,解决方法在当前目录添加一个空的html\u003Cem\u003E页\u003C\u002Fem\u003E面,然后把Window控件的IFrameUrl指向这个\u003Cem\u003E页\u003C\u002Fem\u003E面而不是\"#\"。[fixed]\n\t+弹出的窗口\u003Cem\u003E中\u003C\u002Fem\u003E的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例\u003Cem\u003E中\u003C\u002Fem\u003Ealert\\alert_1.aspx和alert\\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。\n\t-点击\u003Cem\u003E提交\u003C\u002Fem\u003E按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed]\n\t+增加Menu、MenuT\u003Cem\u003Eext\u003C\u002Fem\u003E、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed]\n\t-增加SplitButton控件。[fixed]\n\t\n\t\n\t\n+2008-07-09 v0.3 beta4\n\t-DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed]\n\t+\u003Cem\u003EForm\u003C\u002Fem\u003E表单字段(T\u003Cem\u003Eext\u003C\u002Fem\u003EBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed]\n\t\t-增加ControlToCompare\u002FValueToCompare\u002FCompareOperator\u002FCompareMessage四个属性,示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_compare.aspx。\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u003Cem\u003E中\u003C\u002Fem\u003E放置IFrame会出现渲染错误 (示例在\u003Cem\u003Etab\u003C\u002Fem\u003Estrip_iframe.aspx)[feedback:jima]。[fixed]\n\t\t-特殊\u003Cem\u003E处理\u003C\u002Fem\u003E,拥有IFrame的\u003Cem\u003ETab\u003C\u002Fem\u003E如果不是激活\u003Cem\u003ETab\u003C\u002Fem\u003E,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed]\n\t-\u003Cem\u003EForm\u003C\u002Fem\u003ERow可以设置各列的宽度百分比 (示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_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没有数据,向后翻\u003Cem\u003E页\u003C\u002Fem\u003E按钮可以点击的BUG [feedback:huihuang]。[fixed]\n\t+增加HiddenField控件。[fixed]\n\t\t-其实用T\u003Cem\u003Eext\u003C\u002Fem\u003EBox也能模拟HiddenField的行为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableT\u003Cem\u003Eext\u003C\u002Fem\u003EBox = true,则不能将T\u003Cem\u003Eext\u003C\u002Fem\u003E回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在t\u003Cem\u003Eext\u003C\u002Fem\u003Ebox2.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有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。\n\t\t-示例在ajax3.aspx\u002Fcontent_page4.aspx。\n\t\t-示例content_page3.aspx\u003Cem\u003E中\u003C\u002Fem\u003E,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器控件的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工添加AutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其\u003Cem\u003E中\u003C\u002Fem\u003E放置用户控件(示例在page_usercontrol.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\u003Cem\u003E中\u003C\u002Fem\u003E使用,示例在ajax1.aspx\u002Fcontent_ajax2.aspx\u003Cem\u003E中\u003C\u002Fem\u003E。\n\t\t-对于使用布局构建的\u003Cem\u003E页\u003C\u002Fem\u003E面(比如content_page1.aspx)还不能使用Asp.net ajax,因为\u003Cem\u003E页\u003C\u002Fem\u003E面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前\u003Cem\u003E页\u003C\u002Fem\u003E面已经被修改(示例在content_page1.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe\u003Cem\u003E中\u003C\u002Fem\u003E做法一致)。\n\t+iframe\u003Cem\u003E中\u003C\u002Fem\u003E的alert\u002Fconfirm要覆盖整个父\u003Cem\u003E页\u003C\u002Fem\u003E面,而不仅仅是iframe\u003Cem\u003E页\u003C\u002Fem\u003E面。[fixed]\n\t\t-在Firefox下还有问题。[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\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E如果放置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控件(示例在twintriggerbox.aspx)。[fixed]\n\t-Grid的数据库分\u003Cem\u003E页\u003C\u002Fem\u003E需要增加属性IsDa\u003Cem\u003Etab\u003C\u002Fem\u003EasePaging=true,以便普通分\u003Cem\u003E页\u003C\u002Fem\u003E和数据库分\u003Cem\u003E页\u003C\u002Fem\u003E,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的\u003Cem\u003Etab\u003C\u002Fem\u003E)。[fixed]\n\t+\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容\u003Cem\u003E页\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003EGrid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E的LinkButtonField设置ConfirmT\u003Cem\u003Eext\u003C\u002Fem\u003E会出错 [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\u003Cem\u003E中\u003C\u002Fem\u003E模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。\n\t\t-切换分\u003Cem\u003E页\u003C\u002Fem\u003E时清空选\u003Cem\u003E中\u003C\u002Fem\u003E的值 [feedback:jqpeng]。\n\t\t-增加PreRowDa\u003Cem\u003EtaB\u003C\u002Fem\u003Eound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowda\u003Cem\u003Etab\u003C\u002Fem\u003Eound.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窗体\u003Cem\u003E中\u003C\u002Fem\u003E的","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-330018749.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-2726130-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default","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-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"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-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657","title":"\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet v2.2.1 (2009-4-1) 值得一看","desc":"\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet v2.2.1\n\t\n\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet是一组专业的Asp.net控件库,拥有原生的AJAX支持和丰富的UI效果,\n目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。\n\n支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+\n\n注:\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet基于一些开源的程序\u003Cem\u003EExt\u003C\u002Fem\u003EJS, HtmlAgilityPack, Nii.JSON, YUICompressor。\n\n示例: http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Easp.net\u002F\n开源: http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Easpnet.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\u003ETab\u003C\u002Fem\u003EStrip的GetAdd\u003Cem\u003ETab\u003C\u002Fem\u003EReference函数增加重载方法,以便指定\u003Cem\u003ETab\u003C\u002Fem\u003E的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首\u003Cem\u003E页\u003C\u002Fem\u003E最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成\u003Cem\u003EExt\u003C\u002Fem\u003Ejs最新版本v3.1.1。\n\t\t-增加一个新的Theme - Access。\n\t\t-修正了Firefox下Zoom In\u002FOut时\u003Cem\u003E页\u003C\u002Fem\u003E面消失的BUG。\n\t\t-删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。\n\n\n\n+2010-01-31 v2.2.0\n\t-使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的行为(Ajax\u003Cem\u003E提交\u003C\u002Fem\u003E)(feedback:261629698)。\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加GetAdd\u003Cem\u003ETab\u003C\u002Fem\u003EReference和GetRemove\u003Cem\u003ETab\u003C\u002Fem\u003EReference两个函数,用来向\u003Cem\u003ETab\u003C\u002Fem\u003EStrip控件动态增加删除\u003Cem\u003ETab\u003C\u002Fem\u003E。\n\t\t-增加示例\u003Cem\u003Etab\u003C\u002Fem\u003Estrip\u002F\u003Cem\u003Etab\u003C\u002Fem\u003Estrip_add\u003Cem\u003Etab\u003C\u002Fem\u003E.aspx。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加Enable\u003Cem\u003ETab\u003C\u002Fem\u003ECloseMenu属性,是否启用右键菜单,可用来关闭当前\u003Cem\u003ETab\u003C\u002Fem\u003E和所有其他\u003Cem\u003ETab\u003C\u002Fem\u003E。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window控件更新。\n\t\t-关闭按钮默认直接关闭,不会弹出确认对话框。\n\t\t-GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedHideReference的函数\u003Cem\u003E中\u003C\u002Fem\u003E的Confirm\u003Cem\u003EForm\u003C\u002Fem\u003EModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居\u003Cem\u003E中\u003C\u002Fem\u003E,而不是黄金分割位置。\n\t+Button, Window等控件弹出位置属性的变化。\n\t\t-Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target=\"_self\" -\u003E Target=\"Self\", Target=\"_parent\" -\u003E Target=\"Parent\"。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。\n\t\t-Confirm.GetShowReference的最后一个参数target变为枚举类型。\n\t\t-Alert.GetShowReference\u003Cem\u003E中\u003C\u002Fem\u003E的showInParent参数也变为Target枚举类型。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。\n\n\n\n+2010-01-06 v2.1.9\n\t-集成\u003Cem\u003EExt\u003C\u002Fem\u003Ejs最新版本v3.1.0。\n\t-修正灰色皮肤的CSS问题。\n\t-修正Grid的列名\u003Cem\u003E中\u003C\u002Fem\u003E不能包含\u003Cem\u003E中\u003C\u002Fem\u003E文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件\u003Cem\u003E中\u003C\u002Fem\u003E不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其\u003Cem\u003E中\u003C\u002Fem\u003E的Close全部改为Hide。\n\t-增加\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u003Cem\u003E中\u003C\u002Fem\u003E\u003Cem\u003ETab\u003C\u002Fem\u003E控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument\u003Cem\u003E中\u003C\u002Fem\u003EIcon属性映射错误(feedback:nopnop9)。\n\t-修正HtmlEditor不能编辑的BUG(feedback:TheBox)。\n\t-修正IE下有时会出现空白\u003Cem\u003E页\u003C\u002Fem\u003E面的情况(feedback:olivia919)。\n\t\n\t\n\n+2009-12-06 v2.1.8\n\t-修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。\n\t-修正了IE下Grid\u003Cem\u003E中\u003C\u002Fem\u003E的一个JS问题(feedback:lqm4108)。\n\t-修正Alert消息\u003Cem\u003E中\u003C\u002Fem\u003E引号未编码导致的JS错误(feedback:sun1299shine)。\n\t+集成\u003Cem\u003Eext\u003C\u002Fem\u003Ejs3.0.3。\n\t\t-修正弹出对话框的宽度计算错误(会保持最小的状态)。\n\t\t-增加新的皮肤Gray。\n\t-为示例工程添加改变语言和皮肤的下拉列表。\n\t-为PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E增加静态函数Refresh,在切换语言和皮肤时使用。\t\n\n\n\n+2009-12-01 v2.1.7\n\t-增加示例(iframe\u002Fparent_postback_run3.aspx),如何通过简单的Javascript代码回发父\u003Cem\u003E页\u003C\u002Fem\u003E面(feedback:eroach)。\n\t-修正一些书写错误(feedback:bmck)。\n\t-从Region控件\u003Cem\u003E中\u003C\u002Fem\u003E删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。\n\t-BorderPanel更名为RegionPanel。\n\t-DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。\n\t-增加\u003Cem\u003E中\u003C\u002Fem\u003E国的省市县三级联动示例(data\u002Fshengshixian.aspx)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的\u003Cem\u003ETab\u003C\u002Fem\u003E在切换过程\u003Cem\u003E中\u003C\u002Fem\u003E会重复加载的问题,这是一个在v2.1.6引入的问题(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-修正\u003Cem\u003EForm\u003C\u002Fem\u003E不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器控件(比如Panel,Region,\u003Cem\u003ETab\u003C\u002Fem\u003E等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的实现,避免选\u003Cem\u003E中\u003C\u002Fem\u003E某项后的闪烁。\n\t\t\t\n\n\n+2009-11-21 v2.1.5\n\t+Tree优化。\n\t\t-修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。\n\t\t-GetNodeById更名为FindNode,保持和FindControl一致命名。\n\t\t-删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。\n\t\t-删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。\n\t\t-增加示例(data\u002Ftree_select_run.aspx),如何选\u003Cem\u003E中\u003C\u002Fem\u003E当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet\u003Cem\u003E中\u003C\u002Fem\u003E的一个命名约定。\n\t\t\t-同时更名的还有GridColumn的ColumnId-\u003EColumnID,GetColumnId-\u003EGetColumnID。\n\t\t\t-Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。\n\t\t-为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。\n\t-为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.aspx)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#\u003Cem\u003E处理\u003C\u002Fem\u003E函数来响应键盘事件。\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的关闭按钮提示信息一直是\u003Cem\u003E中\u003C\u002Fem\u003E文的BUG(feedback:thebox)。\n\t-部分\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件的设计时支持(会在后续版本\u003Cem\u003E中\u003C\u002Fem\u003E逐步完善)。\n\t-v0.2beta2版本\u003Cem\u003E中\u003C\u002Fem\u003E关于PersistChildren(true)的描述有误,这个是设计时属性,和运行时是否保持状态没有关系。\n\t-修正CheckBox控件的CheckedChanged事件会被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为T\u003Cem\u003Eext\u003C\u002Fem\u003EBox,T\u003Cem\u003Eext\u003C\u002Fem\u003EArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:\u003Cem\u003Eform\u003C\u002Fem\u003E\u002F\u003Cem\u003Eform\u003C\u002Fem\u003E_validate.aspx\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的控件属性列表(\u002Fajax.aspx)。\n\t\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程\u003Cem\u003E中\u003C\u002Fem\u003E会反映到\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E,但并不是所有的控件属性都支持AJAX改变。\n\t-加载s.gif图片在本机进行,不会请求\u003Cem\u003Eext\u003C\u002Fem\u003Ejs.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保Asp.net的按钮控件仍然具有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\u003Cem\u003E中\u003C\u002Fem\u003ETemplateField生成到\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,\u003Cem\u003EForm\u003C\u002Fem\u003E等)增加枚举类型Icon,其\u003Cem\u003E中\u003C\u002Fem\u003E包含1700\u003Cem\u003E多个\u003C\u002Fem\u003E小图标。\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-如果需要在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出确认对话框,需要设置ConfirmTarget=\"_parent\"(类似Window控件的Target=\"_parent\")。\n\t+为\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-一个典型应用,在Window控件\u003Cem\u003E中\u003C\u002Fem\u003E打开新\u003Cem\u003E页\u003C\u002Fem\u003E面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Alert.Show(\"参数错误!\", String.Empty, \u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以自动回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Easp.net\u002Fdata\u002Ftree_run.aspx\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选\u003Cem\u003E中\u003C\u002Fem\u003E任何一项时在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出对话框的JS代码。\n\t-修正IE7下不能以下划线作为CSS\u003Cem\u003E中\u003C\u002Fem\u003E类名的前缀的BUG(feedback:Steve.Wei)。\n\t-添加定时器控件Timer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree控件的AJAX实现。\n\t+为\u003Cem\u003E页\u003C\u002Fem\u003E面的\u003Cem\u003EForm\u003C\u002Fem\u003E添加autocomplete=\"off\"属性。\n\t\t-参考http:\u002F\u002Fwww.cnblogs.com\u002Fsanshi\u002Farchive\u002F2009\u002F09\u002F04\u002F1560146.html#1635830\n\t+添加对\u003Cem\u003Eext\u003C\u002Fem\u003Ejs3.0\u003Cem\u003E中\u003C\u002Fem\u003E所有语言的支持。\n\t\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet扩展的多语言包在js\\languages\\\u003Cem\u003Eext\u003C\u002Fem\u003Easpnet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其\u003Cem\u003E中\u003C\u002Fem\u003E添加自己的语言版本,并执行js\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口。\n\t+在aspx\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E必须显示的声明控件的集合属性(比如\u003Cem\u003ETab\u003C\u002Fem\u003Es(\u003Cem\u003ETab\u003C\u002Fem\u003EStrip), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将会影响所有的aspx\u003Cem\u003E页\u003C\u002Fem\u003E面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX\u003Cem\u003E中\u003C\u002Fem\u003E使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管\u003Cem\u003ETab\u003C\u002Fem\u003EStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将会影响所有的aspx\u003Cem\u003E页\u003C\u002Fem\u003E面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config\u003Cem\u003E中\u003C\u002Fem\u003E修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree控件的一个BUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Current,而不是一个全局变量。\n\t -这个BUG导致Asp.net compatibility\u003Cem\u003E中\u003C\u002Fem\u003E的示例无法完成,现在已经修正。\n\t+去除PageManager\u003Cem\u003E中\u003C\u002Fem\u003E方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。\n\t -这个属性和Button得Validate\u003Cem\u003EForm\u003C\u002Fem\u003Es属性类似,可以查看Asp.net compatibility\u003Cem\u003E中\u003C\u002Fem\u003E的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复\u003Cem\u003E提交\u003C\u002Fem\u003E - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid\u003Cem\u003E中\u003C\u002Fem\u003E每个单元格的值了。\n -增加示例-如何将Grid控件导出为Excel(data\\grid_excel_run.aspx)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不会被选\u003Cem\u003E中\u003C\u002Fem\u003E(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.aspx)。\n -修正Panel图标不能显示的BUG(CSS\u003Cem\u003E中\u003C\u002Fem\u003Eclass名不能有$字符)。\n +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,\u003Cem\u003EForm\u003C\u002Fem\u003E,GroupPanel,Simple\u003Cem\u003EForm\u003C\u002Fem\u003E,Tree还是Grid,\u003Cem\u003ETab\u003C\u002Fem\u003EStrip)都可以通过这种方式全屏。\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的内部实现,每个\u003Cem\u003E页\u003C\u002Fem\u003E面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId自动生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet和Asp.net的\u003Cem\u003E提交\u003C\u002Fem\u003E按钮兼容问题(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX\u003Cem\u003E提交\u003C\u002Fem\u003E,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们做了优化,现在要使一个Asp.net的按钮能够AJAX\u003Cem\u003E提交\u003C\u002Fem\u003E,你不需要做任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E设置需要在AJAX\u003Cem\u003E中\u003C\u002Fem\u003E需要更新的Asp.net控件了。\n\t\t-在Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E设置了哪些需要在AJAX\u003Cem\u003E中\u003C\u002Fem\u003E更新的Asp.net控件会在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。\n\t\t-示例在aspnet\\fckeditor_run.aspx和aspnet\\aspnet_run.aspx。\n\t\t-FCKEditor和上传控件兼容。示例在aspnet\\fileupload_run.aspx。\n\t-修正ToolbarT\u003Cem\u003Eext\u003C\u002Fem\u003E的文本在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的\u003Cem\u003EForm\u003C\u002Fem\u003Es Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和Asp.Net Ajax类似的\u003Cem\u003E处理\u003C\u002Fem\u003E方式,需要在配置文件Web.config增加一个httpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Redirect重定向\u003Cem\u003E页\u003C\u002Fem\u003E面,两者效果一样。\n\t\t-支持\u003Cem\u003EForm\u003C\u002Fem\u003EsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。\n\t-Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。\n\t-修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。\n\t-修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。\n\t-增加Menu和Accordion的示例。\n\t-修正Window控件的IconUrl有时不显示(Target=\"_parent\")的BUG[feedback:xmq&mgzhenhong]。\n\t\n\n\n+2009-07-22 v2.0 beta3\n\t-兼容FCKEditor。\n\t-在IE8.0,Firefox3.5下测试通过。以后\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet将不会对IE6.0提供支持。\n\t\n\n\n+2009-07-13 v2.0 beta2\n\t-集成\u003Cem\u003Eext\u003C\u002Fem\u003Ejs最新版本v3.0。\n\t+兼容IE6.0-7.0-8.0。\n\t\t-这应该是\u003Cem\u003EExt\u003C\u002Fem\u003Ejs3.0的一个BUG,在IE6.0-7.0下面设置\u003Cem\u003EExt\u003C\u002Fem\u003E.QuickTips.init();会导致button的click事件无法响应(IE8下无此问题)。\n\t\t-目前先禁用IE6.0-7.0的QuickTips。\n\t-优化底层JavaScript。\n\t\n\t\n\t\n+2009-07-05 v2.0 beta1\n\t-更新\u003Cem\u003Eext\u003C\u002Fem\u003Ejs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个\u003Cem\u003E页\u003C\u002Fem\u003E面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。\n\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet自身的CSS会紧挨着\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Ctitle\u003E标签引入,这样在\u003Chead\u003E\u003Cem\u003E中\u003C\u002Fem\u003E自定义的样式可以覆盖\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet缺省样式。\n\t+Alert对话框会遮挡所有的Window窗口。\n\t\t-使用一个变通的方法解决,因为无法改变\u003Cem\u003EExt\u003C\u002Fem\u003E.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。\t\n\t-为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。\n\t-因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选\u003Cem\u003E中\u003C\u002Fem\u003E第一项。\n\t-重新绑定模拟树的下拉列表后,选\u003Cem\u003E中\u003C\u002Fem\u003E项的前面有图片的HTML标签的BUG。\n\t-更新自定义JavaScript组件\u003Cem\u003EExt\u003C\u002Fem\u003E.ux.SimplePagingToolbar。\n\t-更新示例工程。\n\t\n\t\n\n+2009-03-25 v1.3.1\n\t-Tree在AJAX回发展开节点时JS错误[feedback:xlli]。[fixed]\n\t-Window\u003Cem\u003E中\u003C\u002Fem\u003E的EnableIFrame==false,则点击关闭按钮时报JS错误。[fixed]\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生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-如果弹出的窗口(\u003Cem\u003EExt\u003C\u002Fem\u003E-Window)含有ASP.NET控件FileUpload,则此弹出窗口在关闭时出现JS错误(http:\u002F\u002F\u003Cem\u003Eext\u003C\u002Fem\u003Ejs.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E存在ASP.NET控件(T\u003Cem\u003Eext\u003C\u002Fem\u003EBox),则第二次\u003Cem\u003E提交\u003C\u002Fem\u003E表单就会报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed]\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面上放置\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet-Button和ASP.NET-Button,则点击\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet-Button时激发的是ASP.NET-Button的事件,这个BUG和\u003Cem\u003EExt\u003C\u002Fem\u003Ejs2.2.1\u003Cem\u003E中\u003C\u002Fem\u003E\u003Cem\u003EExt\u003C\u002Fem\u003E.Ajax.serialize\u003Cem\u003EForm\u003C\u002Fem\u003E的实现有关。[fixed]\n\t-\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet内部包含HtmlAgilityPack和Nii.JSON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet工程\u003Cem\u003E中\u003C\u002Fem\u003E使用ASP.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件和ASP.NET标准控件和平共处了。[fixed]\n\t\t-如果一个ASP.NET按钮控件要使用\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet的原生AJAX回发时更新ASP.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:aspnet\u002Faspnet.aspx)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新\u003Cem\u003E页\u003C\u002Fem\u003E面重试。”。[fixed]\n\t-自动测试功能会在以后版本\u003Cem\u003E中\u003C\u002Fem\u003E逐步完善。这个版本完成测试框架,采用\u003Cem\u003EExt\u003C\u002Fem\u003Ejs\u003Cem\u003E中\u003C\u002Fem\u003EJS函数进行大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E静态类\u003Cem\u003E中\u003C\u002Fem\u003E的GetPageStateChangedFunction改名为GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedReference,底层代码优化。表示“获取当前\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E的GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedReference,使用CurrentActiveWindow\u003Cem\u003E中\u003C\u002Fem\u003E的GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseReference\u002FGetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseRefreshReference\u002FGetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedClosePostBackReference三个方法代替。\n\t\t-不会修改弹出\u003Cem\u003E页\u003C\u002Fem\u003E面的URL(\u003Cem\u003EExt\u003C\u002Fem\u003E-Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame),以前为了实现功能为每个弹出\u003Cem\u003E页\u003C\u002Fem\u003E面添加box_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的JS方法。可以通过PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Get\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的ASPX\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E查找RegisterPageStateChangedScript属性,并删除,否则会运行错误!\n\t\t-A\u003Cem\u003E页\u003C\u002Fem\u003E面有\u003Cem\u003EExt\u003C\u002Fem\u003E-Window控件弹出B\u003Cem\u003E页\u003C\u002Fem\u003E面,B\u003Cem\u003E页\u003C\u002Fem\u003E面有\u003Cem\u003EExt\u003C\u002Fem\u003E-Window控件弹出C\u003Cem\u003E页\u003C\u002Fem\u003E面,B\u003Cem\u003E页\u003C\u002Fem\u003E面的\u003Cem\u003EExt\u003C\u002Fem\u003E-Window控件设置Target='_parent',则弹出的\u003Cem\u003EExt\u003C\u002Fem\u003E-Window(C\u003Cem\u003E页\u003C\u002Fem\u003E面)会覆盖整个A\u003Cem\u003E页\u003C\u002Fem\u003E面,这是正确的。\n\t\t---当时如果用户直接访问B\u003Cem\u003E页\u003C\u002Fem\u003E面,就会报JS错误,因为此时找不到B\u003Cem\u003E页\u003C\u002Fem\u003E面的父\u003Cem\u003E页\u003C\u002Fem\u003E面A了。现在的版本修正为如果找不到父\u003Cem\u003E页\u003C\u002Fem\u003E面,则就在当前\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口,这样用户直接访问B\u003Cem\u003E页\u003C\u002Fem\u003E面也不会出错了。\n\t\t-Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseReference,表示“获取先确认IFrame的\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window控件增加如下两个方法GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseRefreshReference和GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出\u003Cem\u003EExt\u003C\u002Fem\u003E-Window,再然后刷新父\u003Cem\u003E页\u003C\u002Fem\u003E面或回发父\u003Cem\u003E页\u003C\u002Fem\u003E面”。\n\t\t---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirm\u003Cem\u003EForm\u003C\u002Fem\u003EModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window控件的关闭按钮添加关闭后刷新父\u003Cem\u003E页\u003C\u002Fem\u003E面或者关闭后回发父\u003Cem\u003E页\u003C\u002Fem\u003E面的行为。\n\t\t-如果弹出窗口(Window控件)\u003Cem\u003E中\u003C\u002Fem\u003EIFrame的\u003Cem\u003E页\u003C\u002Fem\u003E面不能正常加载(网络暂时出错或\u003Cem\u003E页\u003C\u002Fem\u003E面抛出异常),则此时点击右上角的关闭按钮会报JS错误,因为此时\u003Cem\u003E页\u003C\u002Fem\u003E面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时\u003Cem\u003E页\u003C\u002Fem\u003E面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window控件的IFrameName属性是自动生成的,只读属性。(因为有可能所有的\u003Cem\u003EExt\u003C\u002Fem\u003E-Window最终都渲染到最外层的\u003Cem\u003E页\u003C\u002Fem\u003E面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部\u003Cem\u003E处理\u003C\u002Fem\u003E)。\n\t\t-CurrentActiveWindow改名为ActiveWindow。\n\t\t-[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values)\n\t\t---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E内容不能自动扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的数据[feedback:huihuang]。[fixed]\n\t-DropDownList在\u003Cem\u003E页\u003C\u002Fem\u003E面第一次加载时没有不可选择项,则回发时也不会有不可选择项的BUG。[fixed]\n\t-升级底层\u003Cem\u003EExt\u003C\u002Fem\u003EJS类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed]\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面加载过程\u003Cem\u003E中\u003C\u002Fem\u003E的时间信息保存在Javascript变量window.box.timeInfo\u003Cem\u003E中\u003C\u002Fem\u003E。[added]\n\t+增加部分自动测试支持(使用WatiN和NUnit),下个版本将会提供完整的自动测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选\u003Cem\u003E中\u003C\u002Fem\u003E任何一项,回发时报错[feedback:huihuang]。[fixed]\n\t-Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed]\n\t+PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E优化。[fixed]\n\t\t-去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。\n\t\t-去除RegisterStartupScript的重载函数,只保留最简单的PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript(string script)函数。\n\t\t-Resirect增加重载函数Redirect(string url, string target),其\u003Cem\u003E中\u003C\u002Fem\u003Etarget可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image控件增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包\u003Cem\u003E中\u003C\u002Fem\u003E增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed]\n\t-ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed]\n\t-Row和Column布局时,修正IE下设置RowHeight=\"100%\"时显示不正确的BUG。[fixed]\n\t-AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed]\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003E控件的EnablePostBack属性会在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此\u003Cem\u003ETab\u003C\u002Fem\u003E都会回发)。[fixed]\n\t\t-有这样一个效果,如果\u003Cem\u003ETab\u003C\u002Fem\u003E1默认显示,\u003Cem\u003ETab\u003C\u002Fem\u003E1的EnablePostBack=true,则\u003Cem\u003E页\u003C\u002Fem\u003E面加载完毕后会回发\u003Cem\u003ETab\u003C\u002Fem\u003E1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用控件的站点必须建立虚拟目录,否则会报JS错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-aspnet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemT\u003Cem\u003Eext\u003C\u002Fem\u003E\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new \u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选\u003Cem\u003E中\u003C\u002Fem\u003E[feedback:jqpeng]。\n\t\t\t-和Asp.net\u003Cem\u003E中\u003C\u002Fem\u003E的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string t\u003Cem\u003Eext\u003C\u002Fem\u003E, string value),这样方便后台添加列表项。\n\t-处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight会自动设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS\u003Cem\u003E中\u003C\u002Fem\u003E的height不同,CSS\u003Cem\u003E中\u003C\u002Fem\u003E的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有控件属性增加在VS\u003Cem\u003E中\u003C\u002Fem\u003E的智能提示。[fixed]\n\t\t-需要将\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.XML和\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.dll放在一起,这样引用dll时xml会被拷贝到bin目录下,提供VS的智能提示。\n\t+控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed]\n\t\t-TriggerIconType.Default -\u003E TriggerIconType.None\n\t\t-SystemIconType.Empty -\u003E SystemIconType.None\n\t\t-RegexPattern.USER_DEFINED -\u003E RegexPattern.None\n\t-表单验证属性名称变化(ValueToCompare-\u003ECompareValue,ControlToCompare-\u003ECompareControl)。[fixed]\n\t+注意:一个属性可以拥有\u003Cem\u003E多个\u003C\u002Fem\u003E值的情况。[fixed]\n\t\t-属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。\n\t\t-其他的都是逗号分隔(比如Validate\u003Cem\u003EForm\u003C\u002Fem\u003Es,DataKeyNames,DataNavigateUrlFields)。\n\t+AccordionLink实现为控件。[fixed]\n\t\t-可以方便的在子\u003Cem\u003E页\u003C\u002Fem\u003E面(iframe)\u003Cem\u003E中\u003C\u002Fem\u003E通过js切换父\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E选\u003Cem\u003E中\u003C\u002Fem\u003E的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.aspx,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的动态添加控件,并且可以给控件添加服务器端事件(示例在\u003Cem\u003Eform\u003C\u002Fem\u003E\u002F\u003Cem\u003Eform\u003C\u002Fem\u003E_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属性进行验证,而不是T\u003Cem\u003Eext\u003C\u002Fem\u003E属性。\n\t\t-DropDownList的Items增加Insert方法(可方便的下拉列表选项添加“全部”)。\n\t\t-DropDownList不支持EmptyT\u003Cem\u003Eext\u003C\u002Fem\u003E属性。\n\t\t-ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(ASPX)\u003Cem\u003E中\u003C\u002Fem\u003E设置哪些项不可选择,以及创建模拟下拉树。\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\u003Cem\u003E中\u003C\u002Fem\u003E的容器,比如ContentPanel需要在外层加上\u003CItems\u003E标签。\n\t\t-适当增大AccordionPanel\u003Cem\u003E中\u003C\u002Fem\u003E链接的高度20px-\u003E22px,同时对链接的样式也做了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少ASPX\u003Cem\u003E中\u003C\u002Fem\u003EHTML代码和Javascript代码的书写,可以在后台动态添加链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在ASPX\u003Cem\u003E页\u003C\u002Fem\u003E切换到“设计时”,方便属性的更改和事件\u003Cem\u003E处理\u003C\u002Fem\u003E函数的添加)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u002FToolbar\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E动态添加控件的BUG,现在\u003Cem\u003Eform\u003C\u002Fem\u003E\u002F\u003Cem\u003Eform\u003C\u002Fem\u003E_dynamic_run.aspx示例已经能正确运行。[fixed]\n\t+大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的控件包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FWindow等。\n\t\t-保留\u003Cem\u003EForm\u003C\u002Fem\u003E的Rows(\u003Cem\u003EForm\u003C\u002Fem\u003ERowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003Es(\u003Cem\u003ETab\u003C\u002Fem\u003ECollection)属性。\n\t\t-保留PageLayout\u002FBorderLayout的Regions(RegionCollection)属性。\n\t-预祝今晚神七发射成功。\n\t\n\t\n\t\n+2008-09-22 v1.2 beta2\n\t+Grid选\u003Cem\u003E中\u003C\u002Fem\u003E项(SelectedRowIndexArray)在ajax回发过程\u003Cem\u003E中\u003C\u002Fem\u003E存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进行多次删除添加操作后,SelectedRowIndexArray选\u003Cem\u003E中\u003C\u002Fem\u003E项\u003Cem\u003E中\u003C\u002Fem\u003E会存在当前不存在的行序号,导致服务器端遍历选\u003Cem\u003E中\u003C\u002Fem\u003E项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例\u003Cem\u003E中\u003C\u002Fem\u003E表单控件都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FButton\u002FHyperLink\u002FLabel\u002FImage\u002FLinkButton\u002FT\u003Cem\u003Eext\u003C\u002Fem\u003EBox\n\t\t-TriggerBox\u002FTwinTriggerBox\u002FWindow\u002FT\u003Cem\u003Eext\u003C\u002Fem\u003EArea\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-修正\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FSimple\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E隐藏一个表单字段(Hidden=false)会占据\u003Cem\u003E页\u003C\u002Fem\u003E面空间的BUG。\n\t-ToolbarT\u003Cem\u003Eext\u003C\u002Fem\u003E\u002FToolbarFill\u002FToolbarSeparator在ASPX\u003Cem\u003E中\u003C\u002Fem\u003E设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed]\n\t-Button去除MarginRight属性(可以通过CssStyle=\"margin-right:5px;\"达到相同的效果)[fixed]\n\t\n\t\n\t\n+2008-09-09 v1.1\n\t+Toolbar去除IsPageMenu属性,在网报\u003Cem\u003E中\u003C\u002Fem\u003E可以用自定义样式实现,而不应该写在控件\u003Cem\u003E中\u003C\u002Fem\u003E。[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\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E六种布局,总共有9\u003Cem\u003E中\u003C\u002Fem\u003E布局可供使用。\n\t\t-其\u003Cem\u003E中\u003C\u002Fem\u003E一些控件默认使用一种布局:Simple\u003Cem\u003EForm\u003C\u002Fem\u003E(\u003Cem\u003EForm\u003C\u002Fem\u003E)\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E(\u003Cem\u003EForm\u003C\u002Fem\u003E)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002F\u003Cem\u003ETab\u003C\u002Fem\u003EStrip(Card),所有布局控件默认的布局是Container。\n\t\t-经常用到的布局控件:Simple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E\u002FAccordion\u002F\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuT\u003Cem\u003Eext\u003C\u002Fem\u003E增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不会渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。\n\t\t-US的\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报\u003Cem\u003E中\u003C\u002Fem\u003E唯一没有用到\u003Cem\u003EExt\u003C\u002Fem\u003EAspNetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Redirect支持普通\u003Cem\u003E页\u003C\u002Fem\u003E面转向和\u003Cem\u003EExt\u003C\u002Fem\u003EAspNetAjax下\u003Cem\u003E页\u003C\u002Fem\u003E面转向。[fixed]\n\t+模拟树的下拉列表的BUG(会使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,\u003Cem\u003ETab\u003C\u002Fem\u003EStrip)。\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后,保持项是否可选状态是最新的(\u003Cem\u003E页\u003C\u002Fem\u003E面第一次加载时,即使没有数据也需要设置DataT\u003Cem\u003Eext\u003C\u002Fem\u003EField\u002FDataValueField\u002FDataSimulateTreeLevelField\u002FDataEnableSelectField等属性的值,否则Ajax回发时会出错)。[fixed]\n\t-UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不会用AspnetAjax,这个控件已经完成使命)。[fixed]\n\t-不要使用Asp.net的控件HiddenField,而是使用\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet的HiddenField,因为Asp.net的控件在Ajax不会被更新,所以会导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList\u003Cem\u003E中\u003C\u002Fem\u003E项如果存在汉字,则会换行的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E如果有ContentPanel,则在\u003Cem\u003E页\u003C\u002Fem\u003E面上方会有空白(可以通过设置EnableDeferredRender=false解决,但会减慢\u003Cem\u003E页\u003C\u002Fem\u003E面的加载速度),现在已经解决这个问题。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(Simple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E)的背景色一致。[fixed]\n\t-TwinTriggerBox的第一个Trigger图标不会先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config\u003Cem\u003E中\u003C\u002Fem\u003E增加配置项\u003Cem\u003EForm\u003C\u002Fem\u003ELabelWidth=\"80\"(默认为80),同时PageManager增加\u003Cem\u003EForm\u003C\u002Fem\u003ELabelWidth属性用来控制\u003Cem\u003E页\u003C\u002Fem\u003E面上所有Simple\u003Cem\u003EForm\u003C\u002Fem\u003E\u002F\u003Cem\u003EForm\u003C\u002Fem\u003E的表单字段标题的宽度。[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-ToolbarT\u003Cem\u003Eext\u003C\u002Fem\u003E增加Ajax可更新属性T\u003Cem\u003Eext\u003C\u002Fem\u003E。\n\t\t\n\t\t\n\t\t\n+2008-08-31 v1.1 beta3\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加EnableDeferredRender属性(是否启用延迟加载\u003Cem\u003ETab\u003C\u002Fem\u003E,默认启用)。[fixed]\n\t-重定向\u003Cem\u003E页\u003C\u002Fem\u003E面,使用系统的方法 PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.Redirect(string url),使用Response.Redirect方法会出错。[fixed]\n\t+安全的Ajax设计。[fixed]\n\t\t-这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上会有进一步的提升。\n\t\t-基本思\u003Cem\u003E想\u003C\u002Fem\u003E:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。\n\t\t-整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不会对UI起作用,同时是安全的,不会有js错误)。\n\t-网报Ajax整合(目前只支持所有的列表\u003Cem\u003E页\u003C\u002Fem\u003E面)(v0.8.1)。[fixed]\n\t\n\t\n\t\n+2008-08-29 v1.1 beta1\n\t+Window控件是否弹出的状态在回发时维持。[fixed]\n\t\t-控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃Asp.NetAjax,\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件内置Ajax支持。[fixed]\n\t\t-这是一个值得骄傲的设计,可以明显提高\u003Cem\u003E页\u003C\u002Fem\u003E面回发的速度(相比普通的回发和Asp.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要做任何配置,所有的回发都是Ajax(在Web.config和PageManager\u003Cem\u003E中\u003C\u002Fem\u003E有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件\u003Cem\u003E中\u003C\u002Fem\u003E设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的做法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前\u003Cem\u003EExt\u003C\u002Fem\u003EAspNetAjax的限制。\n\t\t\t-只对\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件起作用,对Asp.net控件不起作用。\n\t\t\t-对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。\n\t\t\t-对改变控件的Visible属性会有错误。\n\t\t\t-Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用\u003Cem\u003E页\u003C\u002Fem\u003E面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个\u003Cem\u003E页\u003C\u002Fem\u003E面都添加PageLoading控件。[fixed]\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执行,这样当前行被选\u003Cem\u003E中\u003C\u002Fem\u003E的状态在回发后会得到保持。[fixed]\n\t-Grid选\u003Cem\u003E中\u003C\u002Fem\u003E行的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知问题:IE的ActiveX插件IE Developer Toolbar会对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父\u003Cem\u003E页\u003C\u002Fem\u003E面加载一个比较大的css文件(~100k),则每次打开iframe\u003Cem\u003E页\u003C\u002Fem\u003E面,onload事件的调用都会有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003EIFrame的显示速度。[fixed]\n\t\t-在当前\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口需要~20ms,在父\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报\u003Cem\u003E中\u003C\u002Fem\u003E需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、\u003Cem\u003EForm\u003C\u002Fem\u003EMessageTarget、\u003Cem\u003EForm\u003C\u002Fem\u003EOffsetRight等属性,这些属性可以在Web.config\u003Cem\u003E中\u003C\u002Fem\u003E设置(推荐方法),也可以为每个\u003Cem\u003E页\u003C\u002Fem\u003E面设置。[fixed]\n\t\t-一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器\u003Cem\u003E中\u003C\u002Fem\u003ECookie设置的值)(示例在default.aspx)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u003Cem\u003E中\u003C\u002Fem\u003E非当前\u003Cem\u003ETab\u003C\u002Fem\u003E会延迟渲染。[fixed]\n\t\t-这会明显加快\u003Cem\u003E页\u003C\u002Fem\u003E面的渲染速度,网报\u003Cem\u003E中\u003C\u002Fem\u003E一个典型的费用审批\u003Cem\u003E页\u003C\u002Fem\u003E面可以减少200ms的渲染时间。\n\t\t-由于非当前\u003Cem\u003ETab\u003C\u002Fem\u003E不会在\u003Cem\u003E页\u003C\u002Fem\u003E面加载时渲染,所以那些\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E的节点在\u003Cem\u003E页\u003C\u002Fem\u003E面加载后也是不可见的,需要将相关的脚本移动到控件的render事件\u003Cem\u003E中\u003C\u002Fem\u003E。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip延迟加载引起的BUG(非当前\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E的ContentPanel会占据\u003Cem\u003E页\u003C\u002Fem\u003E面空间,已修正)。[fixed]\n\t-全新的\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet.Examples(基础知识\u002F表单控件\u002F数据绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E使用父\u003Cem\u003E页\u003C\u002Fem\u003E面的脚本和样式(示例在iframe\u002Fdefault.aspx和iframe\u002Fpage3.aspx)。[fixed]\n\t\t-测试发现,IFrame\u003Cem\u003E页\u003C\u002Fem\u003E面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout\u003Cem\u003E中\u003C\u002Fem\u003E显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+\u003Cem\u003Eext\u003C\u002Fem\u003Ejs的BUG,当\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E含有iframe时,\u003Cem\u003EExt\u003C\u002Fem\u003E.onReady会被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.\u003Cem\u003Eext\u003C\u002Fem\u003Ejs.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.aspx)[fixed]\n\t\t-现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true;\n\t+需要先回发\u003Cem\u003E页\u003C\u002Fem\u003E面再弹出IFrame窗口。[fixed]\n\t\t-在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。\n\t\t-另一种做法(推荐):PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript(Window99.GetShowReference(\".\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下会有JS错误。[fixed]\n\t-增加BorderLayout控件,示例在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-动态向\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E添加\u003Cem\u003EForm\u003C\u002Fem\u003ERow,并动态的向\u003Cem\u003EForm\u003C\u002Fem\u003ERow\u003Cem\u003E中\u003C\u002Fem\u003E添加表单字段,以及如何取得表单字段的值。(示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_dynamic.aspx)[fixed]\n\t+IFrame弹出窗口关闭后回发父\u003Cem\u003E页\u003C\u002Fem\u003E面,则会多加载IFrame一次,再次打开窗口会重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是一个重要的BUG,会严重影响\u003Cem\u003E页\u003C\u002Fem\u003E面的加载速度。原因是通过脚本改变的IFrameUrl会在回发时保持状态,从而回发父\u003Cem\u003E页\u003C\u002Fem\u003E面后Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame被添加到\u003Cem\u003E页\u003C\u002Fem\u003E面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不会影响服务器端的属性,也即是不保持状态。此问题解决。(示例在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+修正一个的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面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框架\u003Cem\u003EExt\u003C\u002Fem\u003Ejs升级为v2.2,Grid的渲染速度有很大提升。[fixed]\n\t-Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则行不可见,可以通过AutoHeight=\"true\"解决)。[fixed]\n\t+\u003Cem\u003E页\u003C\u002Fem\u003E面正在加载的提示尽早的显示出来。[fixed]\n\t\t-首先在执行js来完成\u003Cem\u003E页\u003C\u002Fem\u003E面渲染之前延迟5ms,以便浏览器把当前\u003Cem\u003E页\u003C\u002Fem\u003E面内容显示出来。\n\t\t-加载js脚本的script标签放置在\u003Cem\u003E页\u003C\u002Fem\u003E面的最后,放置加载js而阻塞PageLoading的显示。\n\t\n\t\n\t\n+2008-08-08 v0.4 beta2\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip延时加载出错。[fixed]\n\t-Window的IFrameUrl\u003Cem\u003E处理\u003C\u002Fem\u003E的BUG,比如Pages_\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet目录下的\u003Cem\u003E页\u003C\u002Fem\u003E面应该为.\u002FFE_ApplyEditor.aspx或~\u002FPages_\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet\u002FFE_ApplyEditor.aspx。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则会JS错误。[fixed]\n\t-实现网报首\u003Cem\u003E页\u003C\u002Fem\u003E下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在\u003Cem\u003E页\u003C\u002Fem\u003E面显示后进行,不计算在js渲染时间内。[fixed]\n\t-优化费用申请\u003Cem\u003E页\u003C\u002Fem\u003E面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.aspx默认会加载\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\u003Cem\u003E页\u003C\u002Fem\u003E面(Window控件的BUG)。[fixed]\n\t-Window\u003Cem\u003E中\u003C\u002Fem\u003E的保存并关闭按钮和Asp.netAjax冲突。[fixed]\n\t-优化关闭Window的js脚本,减少写到\u003Cem\u003E页\u003C\u002Fem\u003E面的js大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的Asp.net控件一样不可编辑。[fixed]\n\t-DropDownList增加SelectedT\u003Cem\u003Eext\u003C\u002Fem\u003E属性(去除了模拟树时通过SelectedItem.T\u003Cem\u003Eext\u003C\u002Fem\u003E的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的js对象的名称简单化,这样可以减少生成的js内容,加快\u003Cem\u003E页\u003C\u002Fem\u003E面加载速度(一个典型\u003Cem\u003E页\u003C\u002Fem\u003E面的js由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003E,点击按钮回发然后点击关闭按钮,出现js错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在\u003Cem\u003E页\u003C\u002Fem\u003E面的Page_Load\u003Cem\u003E中\u003C\u002Fem\u003E,if (!IsPostBack){PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterPageStateChangedStartupScript();}通过这样方法向\u003Cem\u003E页\u003C\u002Fem\u003E面注册了一段脚本,但是这段脚本在回发时没有注册到\u003Cem\u003E页\u003C\u002Fem\u003E面,因为js调用此脚本时报错。\n\t\t-一种解决方法是将向\u003Cem\u003E页\u003C\u002Fem\u003E面注册脚本的函数移动到if语句的外面,即每次都向\u003Cem\u003E页\u003C\u002Fem\u003E面注册此脚本。\n\t\t-另一种办法就是在PageManager控件\u003Cem\u003E中\u003C\u002Fem\u003E增加RegisterPageStateChangedScript(向\u003Cem\u003E页\u003C\u002Fem\u003E面注册监视\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E表单内容改变的脚本)的属性(会在每次\u003Cem\u003E页\u003C\u002Fem\u003E面回发(包含ajax回发)时注册脚本)(示例在button_iframe.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)。\n\t+PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.aspx)。[fixed]\n\t\t-这个手工添加onReady函数能够在每次\u003Cem\u003E页\u003C\u002Fem\u003E面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去做的麻烦(已经在网报\u003Cem\u003E中\u003C\u002Fem\u003E遇到这种情况)。\n\t-每个\u003Cem\u003E页\u003C\u002Fem\u003E面必须添加一个PageManager控件,否则会出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed]\n\t-T\u003Cem\u003Eext\u003C\u002Fem\u003EField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和Asp.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少\u003Cem\u003E页\u003C\u002Fem\u003E面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父\u003Cem\u003E页\u003C\u002Fem\u003E面,也可在关闭后刷新或回发父\u003Cem\u003E页\u003C\u002Fem\u003E面。(default.aspx\u002Fpage2.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要做的仅仅是为Window控件增加一个属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,控件本身封装了大量的代码,简单来看现在有三个\u003Cem\u003E页\u003C\u002Fem\u003E面(default.aspx(A)\u002Fpage2.aspx(B)\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx(C)),其\u003Cem\u003E中\u003C\u002Fem\u003EA包含B\u003Cem\u003E页\u003C\u002Fem\u003E面,当你在B\u003Cem\u003E中\u003C\u002Fem\u003E打开包含有\u003Cem\u003E页\u003C\u002Fem\u003E面C的窗口时,窗口不是在B\u003Cem\u003E中\u003C\u002Fem\u003E打开,而是在A\u003Cem\u003E中\u003C\u002Fem\u003E打开,这样才能保证窗口覆盖整个\u003Cem\u003E页\u003C\u002Fem\u003E面,当你从C\u003Cem\u003E中\u003C\u002Fem\u003E返回需要回发\u003Cem\u003E页\u003C\u002Fem\u003E面B时,却发现取得的是A\u003Cem\u003E页\u003C\u002Fem\u003E面,因为我们窗口是在A\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E创建的。我会通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid\u003Cem\u003E中\u003C\u002Fem\u003E弹出窗口。(default.aspx\u002Fpage3.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.aspx\u002Ftriggerbox.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)\t\n\t\t\t-在整个\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口或者在当前\u003Cem\u003E页\u003C\u002Fem\u003E面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口\u003Cem\u003E中\u003C\u002Fem\u003E的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下\u003Cem\u003ETab\u003C\u002Fem\u003EStrip在Ajax回发后不会去掉x-hide-display样式,导致\u003Cem\u003ETab\u003C\u002Fem\u003E显示为空的BUG。[fixed]\n\t-对\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u002FPanel\u002FWindow\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到\u003Cem\u003E页\u003C\u002Fem\u003E面节点,同时第二次打开Window\u003Cem\u003E中\u003C\u002Fem\u003E的IFrame不会有残影出现。[fixed]\n\t-如果\u003Cem\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003E不是激活\u003Cem\u003ETab\u003C\u002Fem\u003E并且设置了IFrameUrl,则会延迟加载(示例在\u003Cem\u003Etab\u003C\u002Fem\u003Estrip_iframe.aspx)。[fixed]\n\t-Tree控件,点击一个节点自动回发,则当前点击的那个节点的选\u003Cem\u003E中\u003C\u002Fem\u003E状态不会保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe\u003Cem\u003E中\u003C\u002Fem\u003E关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执行(在simple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx,PageCont\u003Cem\u003Eext\u003C\u002Fem\u003E.RegisterStartupScript增加重载函数),而不是原来的先创建整个\u003Cem\u003E页\u003C\u002Fem\u003E面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将JS文件引用由head移动到body\u003Cem\u003E中\u003C\u002Fem\u003E。[fixed]\n\t-Firefox下,如果\u003Cem\u003E页\u003C\u002Fem\u003E面太长会出滚动条,原来在ViewPort样式\u003Cem\u003E中\u003C\u002Fem\u003E有body{overflow:hidden;}。[fixed]\n\t+IFrame内的\u003Cem\u003E页\u003C\u002Fem\u003E面宽度和高度会自动设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E2.aspx)[fixed]\n\t\t-增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个\u003Cem\u003E页\u003C\u002Fem\u003E面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息\u003Cem\u003E中\u003C\u002Fem\u003EMessageTarget改名为\u003Cem\u003EForm\u003C\u002Fem\u003EMessageTarget,增加\u003Cem\u003EForm\u003C\u002Fem\u003EOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image控件 [feedback:jima]。[fixed]\n\t-Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则会引起\u003Cem\u003E页\u003C\u002Fem\u003E面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.aspx)。[fixed]\n\t-去掉DropDownList控件的T\u003Cem\u003Eext\u003C\u002Fem\u003E属性(强制性),可以通过设置SelectedValue来设置选\u003Cem\u003E中\u003C\u002Fem\u003E哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息\u003Cem\u003E中\u003C\u002Fem\u003E的换行符(转换为\u003Cbr\u002F\u003E),否则提示信息可能导致\u003Cem\u003E页\u003C\u002Fem\u003E面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree控件。[fixed]\n\t\t-如何将数据库\u003Cem\u003E中\u003C\u002Fem\u003E的数据绑定到Tree(示例在tree2_bind_da\u003Cem\u003Etab\u003C\u002Fem\u003Ease.aspx)。\n\t\t-ajax加载树节点,放在UpdatePanel\u003Cem\u003E中\u003C\u002Fem\u003E才有ajax的效果(示例在tree2_ajax.aspx)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树\u003Cem\u003E中\u003C\u002Fem\u003E不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同一个\u003Cem\u003E页\u003C\u002Fem\u003E面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltip\u003Cem\u003EForm\u003C\u002Fem\u003EatString两个字段,以显示ToolTip(示例在grid.aspx)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选\u003Cem\u003E中\u003C\u002Fem\u003E样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才行(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列表如果文字长度太长,则显示的文字会换行,导致错位。[fixed]\n\t\t-虽然最后未能解决\u003Cdiv style=\"width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;\"\u003E\u003Cdiv style=\"width: 16px; height: 18px; float: left;\"\u003E##\u003C\u002Fdiv\u003E差旅交通费\u003C\u002Fdiv\u003E在IE和Firefox下显示的不同效果。\n\t\t-但是通过用\u003Cimg src=\"##\" \u002F\u003E来代替\u003Cdiv style=\"background:url(##)\" \u002F\u003E,从而实现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+增加树控件(Tree)(示例在tree2.aspx)。[fixed]\n\t\t-可以在回发时维持树的状态(选\u003Cem\u003E中\u003C\u002Fem\u003E行,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式添加树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到\u003Cem\u003E页\u003C\u002Fem\u003E面,也可以引发PostBack事件,可以添加自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E放置\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件,则渲染时会出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel\u003Cem\u003E中\u003C\u002Fem\u003E渲染\u003Cem\u003EExt\u003C\u002Fem\u003EAspNet控件,如果容器的display='none',则会出现各种问题(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就会显示滚动条。\n\t+IE6下,在应用Asp.NetAjax后,\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。\n\t\t-最后发现IE6下应用Asp.NetAjax后不仅\u003Cem\u003EForm\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数\u003Cem\u003E中\u003C\u002Fem\u003E,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E所有表单的宽度(box_fix\u003Cem\u003EForm\u003C\u002Fem\u003EWidthInIE6();):\n\t\t 示例在 Site.Master \u003Cem\u003E页\u003C\u002Fem\u003E面。\n\t+集成的AspNetAjax有一个很大的BUG,只要你在\u003Cem\u003E页\u003C\u002Fem\u003E面上进行过ajax操作,当改变窗口大小时你会惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();),\n\t\t 这样的代码让我\u003Cem\u003E想\u003C\u002Fem\u003E起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。\n\t\n\t\n\t\n+2008-07-14 v0.3 beta6\n\t-增加FlashObject控件。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选\u003Cem\u003E中\u003C\u002Fem\u003E样式微调。[fixed]\n\t-预加载\u003Cem\u003EForm\u003C\u002Fem\u003E表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快\u003Cem\u003E页\u003C\u002Fem\u003E面的渲染速度(一个典型的20个记录的\u003Cem\u003E页\u003C\u002Fem\u003E面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载数据不会改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid\u003Cem\u003E中\u003C\u002Fem\u003E静态的CheckBoxField图片。[fixed]\n\t-\u003Cem\u003ETab\u003C\u002Fem\u003EStrip增加\u003Cem\u003ETab\u003C\u002Fem\u003EIndexChanged事件,同时\u003Cem\u003ETab\u003C\u002Fem\u003E增加EnablePostBack,可以在点击一个\u003Cem\u003ETab\u003C\u002Fem\u003E时引起回发事件。这在延迟加载\u003Cem\u003ETab\u003C\u002Fem\u003E的内容非常有用。(示例在\u003Cem\u003Etab\u003C\u002Fem\u003Estrip.aspx)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-\u003Cem\u003E页\u003C\u002Fem\u003E面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_compare.aspx)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和T\u003Cem\u003Eext\u003C\u002Fem\u003EBox比较大小需要指定CompareType。\n\t+如果在编辑\u003Cem\u003E页\u003C\u002Fem\u003E面使用AspNetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.aspx\u002Fajax_editor.aspx)。[fixed]\n\t\t-这是由于ajax后执行的javascript\u003Cem\u003E中\u003C\u002Fem\u003E不能有return false语句。\n\t+在文本框失去焦点时,执行一些Javascript脚本(示例在t\u003Cem\u003Eext\u003C\u002Fem\u003Ebox_blur.aspx) [feedback:xmzhu]。[fixed]\n\t\t-在\u003Cem\u003E页\u003C\u002Fem\u003E面添加onReady函数(会被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误\u003Cem\u003E页\u003C\u002Fem\u003E面,解决方法在当前目录添加一个空的html\u003Cem\u003E页\u003C\u002Fem\u003E面,然后把Window控件的IFrameUrl指向这个\u003Cem\u003E页\u003C\u002Fem\u003E面而不是\"#\"。[fixed]\n\t+弹出的窗口\u003Cem\u003E中\u003C\u002Fem\u003E的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时会有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例\u003Cem\u003E中\u003C\u002Fem\u003Ealert\\alert_1.aspx和alert\\alert_2.aspx,总计 6 行代码),现在只需要 3 行代码就OK了。\n\t-点击\u003Cem\u003E提交\u003C\u002Fem\u003E按钮后变成灰色不可再次点击(示例在button_click_gray.aspx)[feedback:jima]。[fixed]\n\t+增加Menu、MenuT\u003Cem\u003Eext\u003C\u002Fem\u003E、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.aspx)。[fixed]\n\t-增加SplitButton控件。[fixed]\n\t\n\t\n\t\n+2008-07-09 v0.3 beta4\n\t-DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed]\n\t+\u003Cem\u003EForm\u003C\u002Fem\u003E表单字段(T\u003Cem\u003Eext\u003C\u002Fem\u003EBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed]\n\t\t-增加ControlToCompare\u002FValueToCompare\u002FCompareOperator\u002FCompareMessage四个属性,示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_compare.aspx。\n\t+\u003Cem\u003ETab\u003C\u002Fem\u003EStrip\u003Cem\u003E中\u003C\u002Fem\u003E放置IFrame会出现渲染错误 (示例在\u003Cem\u003Etab\u003C\u002Fem\u003Estrip_iframe.aspx)[feedback:jima]。[fixed]\n\t\t-特殊\u003Cem\u003E处理\u003C\u002Fem\u003E,拥有IFrame的\u003Cem\u003ETab\u003C\u002Fem\u003E如果不是激活\u003Cem\u003ETab\u003C\u002Fem\u003E,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.aspx) [feedback:xmzhu]。[fixed]\n\t-\u003Cem\u003EForm\u003C\u002Fem\u003ERow可以设置各列的宽度百分比 (示例在\u003Cem\u003Eform\u003C\u002Fem\u003E_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没有数据,向后翻\u003Cem\u003E页\u003C\u002Fem\u003E按钮可以点击的BUG [feedback:huihuang]。[fixed]\n\t+增加HiddenField控件。[fixed]\n\t\t-其实用T\u003Cem\u003Eext\u003C\u002Fem\u003EBox也能模拟HiddenField的行为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableT\u003Cem\u003Eext\u003C\u002Fem\u003EBox = true,则不能将T\u003Cem\u003Eext\u003C\u002Fem\u003E回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在t\u003Cem\u003Eext\u003C\u002Fem\u003Ebox2.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有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。\n\t\t-示例在ajax3.aspx\u002Fcontent_page4.aspx。\n\t\t-示例content_page3.aspx\u003Cem\u003E中\u003C\u002Fem\u003E,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器控件的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工添加AutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其\u003Cem\u003E中\u003C\u002Fem\u003E放置用户控件(示例在page_usercontrol.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\u003Cem\u003E中\u003C\u002Fem\u003E使用,示例在ajax1.aspx\u002Fcontent_ajax2.aspx\u003Cem\u003E中\u003C\u002Fem\u003E。\n\t\t-对于使用布局构建的\u003Cem\u003E页\u003C\u002Fem\u003E面(比如content_page1.aspx)还不能使用Asp.net ajax,因为\u003Cem\u003E页\u003C\u002Fem\u003E面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前\u003Cem\u003E页\u003C\u002Fem\u003E面已经被修改(示例在content_page1.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe\u003Cem\u003E中\u003C\u002Fem\u003E做法一致)。\n\t+iframe\u003Cem\u003E中\u003C\u002Fem\u003E的alert\u002Fconfirm要覆盖整个父\u003Cem\u003E页\u003C\u002Fem\u003E面,而不仅仅是iframe\u003Cem\u003E页\u003C\u002Fem\u003E面。[fixed]\n\t\t-在Firefox下还有问题。[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\u003ETab\u003C\u002Fem\u003EStrip的\u003Cem\u003ETab\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003E如果放置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控件(示例在twintriggerbox.aspx)。[fixed]\n\t-Grid的数据库分\u003Cem\u003E页\u003C\u002Fem\u003E需要增加属性IsDa\u003Cem\u003Etab\u003C\u002Fem\u003EasePaging=true,以便普通分\u003Cem\u003E页\u003C\u002Fem\u003E和数据库分\u003Cem\u003E页\u003C\u002Fem\u003E,否则在添加删除记录时总记录数不会变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.aspx)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的\u003Cem\u003Etab\u003C\u002Fem\u003E)。[fixed]\n\t+\u003Cem\u003E页\u003C\u002Fem\u003E面\u003Cem\u003E中\u003C\u002Fem\u003E任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容\u003Cem\u003E页\u003C\u002Fem\u003E\u003Cem\u003E中\u003C\u002Fem\u003EGrid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid\u003Cem\u003E中\u003C\u002Fem\u003E的LinkButtonField设置ConfirmT\u003Cem\u003Eext\u003C\u002Fem\u003E会出错 [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\u003Cem\u003E中\u003C\u002Fem\u003E模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.aspx)。\n\t\t-切换分\u003Cem\u003E页\u003C\u002Fem\u003E时清空选\u003Cem\u003E中\u003C\u002Fem\u003E的值 [feedback:jqpeng]。\n\t\t-增加PreRowDa\u003Cem\u003EtaB\u003C\u002Fem\u003Eound事件,可以在数据绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowda\u003Cem\u003Etab\u003C\u002Fem\u003Eound.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窗体\u003Cem\u003E中\u003C\u002Fem\u003E的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.aspx\u002Fsimple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx)[fixed]\n\t\t-在simple\u003Cem\u003Eform\u003C\u002Fem\u003E.aspx\u003Cem\u003E中\u003C\u002Fem\u003E:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](Simple\u003Cem\u003EForm\u003C\u002Fem\u003E[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其\u003Cem\u003E中\u003C\u002Fem\u003E26是Toolbar的高度,32是窗口的标题栏和下边框的高度。\n\t+关闭Iframe的LoadMask,所以需要Iframe\u003Cem\u003E页\u003C\u002Fem\u003E面添加PageLoading控件,这样效果统一。[fixed]\n\t+Grid完善。\n\t\t-去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分\u003Cem\u003E页\u003C\u002Fem\u003E在ASP.NET应用\u003Cem\u003E中\u003C\u002Fem\u003E会有很多问题(主要是状态保持的问题)。\n\t\t+EnableServerSort改名AllowSorting。(示例在grid_sorting.aspx)\n\t\t\t-使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件\u003Cem\u003E处理\u003C\u002Fem\u003E函数\u003Cem\u003E中\u003C\u002Fem\u003E重新绑定数据。\n\t\t+增加AllowPaging属性。(示例在grid_paging.aspx)\n\t\t\t-使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件\u003Cem\u003E处理\u003C\u002Fem\u003E函数\u003Cem\u003E中\u003C\u002Fem\u003EGrid1.PageIndex = e.NewPageIndex;OK。\n\t\t+数据库分\u003Cem\u003E页\u003C\u002Fem\u003E支持。(示例在grid_da\u003Cem\u003Etab\u003C\u002Fem\u003Ease_paging.aspx)\n\t\t\t-使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件\u003Cem\u003E处理\u003C\u002Fem\u003E函数\u003Cem\u003E中\u003C\u002Fem\u003EGrid1.PageIn","createTime":"2010-04-01 09:41:27","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2190657-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2190657-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"5\",\"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-5-2190657-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"5\",\"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-5-2190657-bbs-330018749.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1709122695458_66813\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"}],"staffDOList":[{"id":null,"communityId":209,"username":"community_91","userNickname":"JavaScript","roleCode":1,"status":1,"createUsername":"","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","createTime":"2021-05-12 18:07:03","updateTime":"2021-05-12 18:07:03","lastLoginTime":"2021-05-12 18:07:03"},{"id":null,"communityId":209,"username":"sysdzw","userNickname":"无·法","roleCode":2,"status":1,"createUsername":"community_91","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F45dcec50fd694b578374e7167ff7914a_sysdzw.jpg!1","createTime":"2021-06-16 17:59:42","updateTime":"2021-06-16 17:59:42","lastLoginTime":"2021-06-16 17:59:42"}],"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\u002F330018749","openUrl":"","isApp":false,"localUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F330018749","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":["330018749"],"deviceType":"pc","isSpider":"","hostname":["bbs.csdn.net"]},"basePath":"bbs.csdn.net\u002Fccloud\u002Ftopics\u002F330018749","hrefUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F330018749","active":0,"navBarFixed":false,"title":"Ext中.多个tab页中的Form想同时提交怎么处理???","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":209,"topicId":330018749},"keywords":"","description":"以下内容是CSDN社区关于Ext中.多个tab页中的Form想同时提交怎么处理???相关内容,如果想了解更多关于JavaScript社区其他内容,请访问CSDN社区。"};</script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/runtime.deb630c4.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/common.ed079ce4.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/tpl/ccloud-detail/index.62763295.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>