请问mvc4 如何实现折叠菜单

huang_huang118 2015-06-13 11:16:42
最近要写一个像这样http://aid.5173.com/左边的这种折叠菜单,但是尝试了很多种方法,都无法实现二级菜单的显示。
view部分代码:
 @foreach(var item in Model)
{
<li class="level1">
@Html.Raw(item.DirectoryContents)
<script type="text/javascript">
$(".level1").click(function () {
var currentDirectoryID = item.ListID;
sumbit(currentDirectoryID)
});
</script>
</li>
}

显示了一级菜单,之后click事件:

<script>
function sumbit(ListID) {
var postData={
ListID:ListID
};
$(".level2").empty();
$.ajax({
type: 'POST',
url: "~/ServiceCenter/AList",
dataType: 'json',
data: postData,
success: function (data) {
var HelpList = data.Context;
for (var i = 0; i < HelpList.length; i++) {
var listInfo = HelpList[i];
var directoryContents = listInfo.DirectoryContents;
var Level = listInfo.Level;
var firstDirectoryIdentity = listInfo.FirstDirectoryIdentity;
var firstDirectoryID = listInfo.FirstDirectoryID;
DirectoryList += "<ul class='level2'>";
DirectoryList += "<li><a href='~/ServiceCenter/HelpCategory/?FirstDirectoryID=" + firstDirectoryID + "&FirstDirectoryIdentity=" + firstDirectoryIdentity + "'>" + directoryContents + "</a></li>";
}
DirectoryList += "</ul></li>";

$(".level2").append(DirectoryList);
}
});
}
</script>

controller的代码:
       public ActionResult AList(FormCollection form)
{
int reciveListID =int.Parse( form["ListID"]);
List<GamesStore.Model.bm_Help_ADirectory> aContextList = null;
aContextList = help.bm_Help_ADirectory.Where(x => x.ListID == reciveListID).ToList();
return Json(new { DirectoryContents =aContextList});
}

显示一级菜单的 controller
        public ActionResult Help()
{
var db = help.bm_Help_HelpList.ToList();
return View(db);
}

显示了一级菜单,点击无反应,无法显示 二级菜单,请大家给看看。
或则个demo。谢谢!
...全文
418 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
无爱大叔 2015-06-23
  • 打赏
  • 举报
回复
看上去你的错误是把razor即服务端代码和客户端脚本混合写在一起了。 查看最终生成的脚本与你期望的脚本是否一致就知道了,要知道服务端的代码是优先执行的,然后再由浏览器来解析html和js输出到浏览器中。 服务端只管做服务端应该做的,你这里的菜单数据源应该是在服务端直接生成好的,类似json之类的数据源,再放到cshtml页面里,由js脚本来解析json,生成菜单的脚本
跳动de指尖 2015-06-23
  • 打赏
  • 举报
回复
我只是想说,这跟mvc没有半毛钱的关系 折叠菜单无非是对document的操作,顶多会从服务器获取一下折叠菜单的数据 可是关于mvc(4)有任何关系?
huang_huang118 2015-06-23
  • 打赏
  • 举报
回复
引用 5 楼 huang_huang118 的回复:
[quote=引用 3 楼 u011762977 的回复:] 你先拿到所有数据,把css和html写好,然后把二级菜单那块的数据隐藏,点击一级菜单再显示出对应的二级菜单就可以了
如果是数据库动态加载呢?[/quote] 无法断点,不知道哪里出了问题,但是你在二级菜单必须获得一级菜单的父id,才可以显示对应的二级菜单内容不是么?
land_L 2015-06-23
  • 打赏
  • 举报
回复
http://www.ztree.me/v3/main.php#_zTreeInfo
Xanl 2015-06-18
  • 打赏
  • 举报
回复
ul里嵌套li 用js做,数据结构先确定了
moonwrite 2015-06-18
  • 打赏
  • 举报
回复
//你这个foreach生成的js也太多了 而且只是变量不一样而已 @foreach(var item in Model) { <li class="level1" data-listid="@ item.ListID"> @Html.Raw(item.DirectoryContents) </li> } <script type="text/javascript"> $(".level1").click(function () { var currentDirectoryID =$(this).attr("data-listid"); sumbit(currentDirectoryID) }); </script> 你点击的时候 后台断点能断到么
huang_huang118 2015-06-18
  • 打赏
  • 举报
回复
引用 3 楼 u011762977 的回复:
你先拿到所有数据,把css和html写好,然后把二级菜单那块的数据隐藏,点击一级菜单再显示出对应的二级菜单就可以了
如果是数据库动态加载呢?
huang_huang118 2015-06-18
  • 打赏
  • 举报
回复
引用 1 楼 qq6648208281 的回复:
使用js写,我以前是用ul套ul做出来过,点击就显示相应的ul 所以先把样式搞定吧
样式和js已经搞定,就是显示不出二级菜单。
花猫阳 2015-06-15
  • 打赏
  • 举报
回复
你先拿到所有数据,把css和html写好,然后把二级菜单那块的数据隐藏,点击一级菜单再显示出对应的二级菜单就可以了
zjc405068789 2015-06-14
  • 打赏
  • 举报
回复
建议先把html和css先搞定了,再考虑输出的问题。
Yun__ 2015-06-13
  • 打赏
  • 举报
回复
使用js写,我以前是用ul套ul做出来过,点击就显示相应的ul 所以先把样式搞定吧
第1章 Java语言的GUI历史 2 1.1 最初的AWT 2 1.2 Swing工具包 3 1.3 Eclipse的诞生 3 1.4 Eclipse贡献SWT工具包 5 1.4.1 SWT的结构 6 1.4.2 SWT所支持的操作系统 6 1.5 Sun AWT/Swing与Eclipse SWT 7 1.5.1 Swing与SWT的比较 7 1.5.2 SWT的优势和不足 8 1.6 SWT与JFace、Eclipse 9 1.6.1 JFace是SWT的扩展 9 1.6.2 Eclipse的UI界面基于JFace 10 1.7 本章小结 10 第2章 配置SWT开发环境 11 2.1 下载和安装Eclipse 11 2.1.1 Eclipse下载页面介绍 11 2.1.2 下载Eclipse 12 2.1.3 安装Eclipse语言包 14 .2.1.4 在不同的语言中切换 15 2.2 直接获取SWT工具包 16 2.3 下载和安装Visual Editor 17 2.3.1 Visual Editor的下载 17 2.3.2 Visual Editor的安装 18 2.4 第一个SWT程序 19 2.4.1 创建SWT程序 19 2.4.2 编译和运行程序 20 2.5 本章小结 21 第3章 Eclipse开发环境概述 22 3.1 Eclipse界面一览 22 3.2 Eclipse项目的文件结构 23 3.2.1 设置编译后.class文件的保存目录 23 3.2.2 导入项目使用的包 25 3.2.3 设置编译方式 26 3.2.4 运行程序 27 3.3 常用的代码编辑功能 28 3.3.1 添加注释 28 3.3.2 自定义格式化代码 28 3.3.3 自动生成getter和setter代码 30 3.3.4 代码的重构 31 3.3.5 查看源代码 31 3.3.6 代码的展开和折叠 32 3.3.7 代码比较 33 3.3.8 子类中覆盖父类的方法 34 3.4 代码错误提示 34 3.4.1 如何定位错误 34 3.4.2 自动修正错误 35 3.5 文件查找 35 3.5.1 文件内部查找 35 3.5.2 项目内查找 36 3.6 使用快捷键 36 3.6.1 显示快捷键说明 37 3.6.2 自定义快捷键 37 3.7 本章小结 38 第2篇 SWT进阶篇 第4章 SWT开发基础 40 4.1 SWT应用程序基本结构 40 4.2 Display类 42 4.2.1 Display类概述 42 4.2.2 Display类常用方法 42 4.3 Shell类 45 4.3.1 Shell类概述 45 4.3.2 不同窗口的样式 46 4.3.3 应用多个样式 47 4.3.4 Shell类的主要方法 47 4.3.5 创建多个窗口 49 4.4 SWT包类结构 51 4.5 本章小结 52 第5章 SWT基本组件 53 5.1 SWT控件类概述 53 5.1.1 窗口小部件:Widget 53 5.1.2 Widget的继承关系 53 5.1.3 SWT中的子类 54 5.1.4 控件(Controls)与面板(Composites) 55 5.1.5 Widgets不是Controls 55 5.2 按钮(Button) 58 5.2.1 普通按钮(SWT.PUSH) 58 5.2.2 切换按钮(SWT.TOGGLE) 59 5.2.3 箭头按钮(SWT.ARROW) 60 5.2.4 单选按钮(SWT.RADIO) 60 5.2.5 多选按钮(SWT.CHECK) 61 5.2.6 常用的方法 63 5.3 标签(Label) 64 5.3.1 文本标签 64 5.3.2 分割线标签 64 5.3.3 自定义标签(CLabel) 65 5.4 文本框(Text) 65 5.4.1 文本框的样式 66 5.4.2 文本框程序示例 66 5.4.3 常用的方法 68 5.5 列表框(List) 69 5.5.1 列表框的样式 69 5.5.2 列表框程序示例 70 5.5.3 常用的方法 73 5.6 组合框(Combo) 74 5.6.1 组合框的样式 75 5.6.2 组合框程序示例 75 5.6.3 组合框的常用方法 77 5.6.4 自定义组合框CCombo类 77 5.7 本章小结 78 第6章 面板容器类 79 6.1 面板类(Composite) 79 6.1.1 面板类的样式 79 6.1.2 面板类的常用方法 80 6.2 分组框(Group) 80 6.3 选项卡(TabFolder) 81 6.3.1 选项卡的基本构成 81 6.3.2 设置底部显示选项卡 82 6.3.3 设置选项卡图标 82 6.3.4 选项卡的常用方法 83 6.4 自定义选项卡(CTabFolder ) 83 6.4.1 带有“关闭”按钮的选项卡 84 6.4.2 带有边框的选项卡 85 6.4.3 显示“最大化/最小化”按钮 85 6.4.4 设置选项卡的颜色和背景图片 85 6.4.5 仿Eclipse编辑区的选项卡 87 6.4.6 限制选项卡文字的长度 90 6.4.7 设置右上角控件 91 6.4.8 自定义选项的常用方法 91 6.5 分割窗框(SashForm) 92 6.5.1 分割窗框的样式 92 6.5.2 设置窗框显示的比例 93 6.5.3 设置窗框最大化所显示的控件 93 6.6 自定义分割框(CBanner) 94 6.6.1 改变分割线的外观 95 6.6.2 Eclipse中的CBanner 95 6.7 滚动面板(ScrolledComposite) 95 6.7.1 设置滚动条的样式 96 6.7.2 滚动面板的其他方法 97 6.8 本章小结 97 第7章 SWT布局管理器 98 7.1 布局管理器概述 98 7.1.1 绝对定位 98 7.1.2 托管定位 98 7.1.3 常见的布局管理器 100 7.2 FillLayout(充满式布局) 100 7.2.1 水平填充(默认)和垂直填充 101 7.2.2 设置四周补白 102 7.3 RowLayout(行列式布局) 102 7.3.1 设置折行显示:wrap属性 103 7.3.2 设置空间大小:pack属性 103 7.3.3 设置填充方式:type属性 103 7.3.4 设置是否充满整行:justify属性 104 7.3.5 设置补白和间隔 104 7.3.6 设置控件的大小RowData 105 7.3.7 设置是否等宽或等高:fill属性 105 7.4 GridLayout(网格式布局) 106 7.4.1 设置网格的列数:numColumns属性 106 7.4.2 设置网格等宽:makeColumnsEqualWidth属性 107 7.4.3 设置补白和间隔 107 7.4.4 使用GridData对象 107 7.4.5 设置单元格对齐方式:horizontalAlignment和verticalAlignment属性 108 7.4.6 设置缩进大小:horizontalIndent和verticalIndent属性 109 7.4.7 设置单元格跨行和跨列显示:horizontalSpan和verticalSpan属性 109 7.4.8 设置单元格空间的抢占方式:grabExcessHorizontalSpace和 grabExcessVerticalSpace属性 110 7.4.9 设置的控件大小:minimumWidth和minimumHeight属性 111 7.4.10 设置控件大小:widthHint和heightHint属性 111 7.4.11 样式常量对照表 112 7.5 FormLayout(表格式布局) 112 7.5.1 设置补白和间隔 113 7.5.2 使用FormData对象 113 7.5.3 使用FormAttachment对象 114 7.5.4 设置控件的相对位置 115 7.6 StackLayout(堆栈式布局) 115 7.7 自定义布局管理器 117 7.7.1 布局的基本原理 117 7.7.2 布局计算的常用方法 118 7.7.3 自定义布局类(BorderLayout) 119 7.8 使用VE可视化布局 123 7.8.1 创建可视化的类 123 7.8.2 进行布局设置 124 7.9 本章小结 125 第8章 SWT中的事件模型 126 8.1 事件模型概述 126 8.1.1 监听器(Listener) 126 8.1.2 事件(Event) 127 8.1.3 注册监听器 127 8.1.4 适配器 128 8.1.5 常见的事件 128 8.2 事件处理的常用写法 130 8.2.1 内部匿名类 130 8.2.2 内部类 130 8.2.3 实现接口的类 131 8.2.4 继承的类的方法 132 8.3 键盘事件 132 8.3.1 键盘事件程序示例 132 8.3.2 键盘事件的各种属性 134 8.4 鼠标事件 136 8.4.1 鼠标事件程序示例 136 8.4.2 鼠标事件的各种属性 139 8.5 其他常用的事件 139 8.5.1 选中事件 139 8.5.2 文本修改程序示例 140 8.5.3 文本修改事件:VerifyEvent的各种属性 142 8.5.4 文本修改事件:VerifyEvent和ModifyEvent的区别 143 8.6 无类型的事件 144 8.6.1 注册无类型事件监听器 144 8.6.2 无类型事件程序示例 145 8.7 本章小结 146 第3篇 SWT高级篇 第9章 SWT高级控件 148 9.1 链接文本(Link) 148 9.2 菜单(Menu和MenuItem) 149 9.2.1 菜单菜单项之间的关系 150 9.2.2 菜单的样式 151 9.2.3 菜单项的样式 152 9.2.4 设置菜单项的图标 152 9.2.5 设置菜单项快捷键 152 9.3 工具栏(ToolBar和ToolItem) 153 9.3.1 工具栏图片资源的管理 155 9.3.2 工具栏的不同样式 157 9.3.3 工具栏按钮的不同样式 158 9.3.4 工具栏常用的方法 160 9.4 可拖动的工具栏(CoolBar和CoolItem) 161 9.4.1 带有下拉选项的工具栏 163 9.4.2 常用的方法 163 9.5 系统托盘(Tray和TrayItem) 164 9.6 滑动组件 167 9.6.1 滑块(Slider) 167 9.6.2 刻度条(Scale) 168 9.6.3 微调按钮(Spinner) 168 9.7 进度条(ProgressBar) 169 9.8 对话框 170 9.8.1 消息提示框(MessageBox) 171 9.8.2 文件目录对话框(DirectoryDialog) 172 9.8.3 文件对话框(FileDialog) 173 9.8.4 颜色对话框(ColorDialog) 175 9.8.5 字体对话框(FontDialog) 176 9.8.6 打印对话框(PrintDialog) 177 9.9 表格(Table、TableItem和TableColumn) 178 9.9.1 Table、TableItem和TableColumn的关系 182 9.9.2 设置带有选择框的表格 182 9.9.3 设置可同时选中多行表格 183 9.9.4 可拖动的表格 184 9.9.5 设置单元格的图标 184 9.9.6 改变选中行高亮显示的颜色 185 9.9.7 带有上下文菜单的表格 186 9.9.8 可编辑的表格(TableEditor) 187 9.9.9 用键盘控制表格(TableCursor) 189 9.9.10 带有进度条的表格 191 9.9.11 表格小结 192 9.10 树(Tree) 192 9.10.1 不同样式的树 193 9.10.2 为树添加图标 193 9.10.3 可编辑的树 196 9.10.4 表格树 197 9.10.5 树小结 198 9.11 格式化文本(StyleText) 198 9.11.1 格式化对象(StyleRange) 199 9.11.2 格式化文本的事件处理 200 9.11.3 对选中文本设置格式 201 9.11.4 自动为数字字符着色 203 9.11.5 换行自动设置背景颜色 204 9.12 浏览器 205 9.13 本章小结 210 第10章 SWT中的拖放支持 211 10.1 可拖放的树 211 10.2 拖放原理概述 214 10.3 拖放源(DragSource) 215 10.3.1 创建拖放源对象 215 10.3.2 定义拖放源数据传输类型 215 10.3.3 处理拖放源事件 216 10.4 拖放目标(DragTarget) 218 10.4.1 定义目标对象 218 10.4.2 定义目标对象的数据传输类型 219 10.4.3 处理拖放目标事件 219 10.5 传输数据(Transfer) 221 10.6 综合示例:简单购物车 222 10.7 对剪贴板的操作 226 10.8 本章小结 229 第11章 SWT线程 230 11.1 线程概述 230 11.1.1 什么是线程 230 11.1.2 创建线程的两种方式 231 11.2 SWT中的UI线程 234 11.3 其他线程访问UI线程 234 11.4 改进的进度条 236 11.5 多线程程序设计 238 11.6 本章小结 243 第12章 SWT系统资源 244 12.1 系统资源概述 244 12.1.1 什么是系统资源 244 12.1.2 释放资源的原则 245 12.1.3 访问资源的原则 246 12.1.4 何时释放资源 246 12.2 颜色(Color) 247 12.2.1 系统颜色 248 12.2.2 RGB颜色 249 12.3 字体(Font) 250 12.4 光标(Cursor) 251 12.5 图像(Image) 252 12.5.1 画布类(Canvas) 252 12.5.2 图像类(Image) 254 12.5.3 图像数据类(ImageData) 255 12.5.4 保存图像类(ImageLoader) 256 12.5.5 Eclipse的图标 256 12.6 SWT绘图 257 12.6.1 使用绘制对象的方法 257 12.6.2 绘制线条 258 12.6.3 绘制字符 259 12.6.4 绘制填充图形 260 12.6.5 绘制图像 261 12.7 本章小结 261 第13章 SWT的高级应用.. 262 13.1 打印支持 262 13.1.1 打印类(Printer)和打印数据类(PrinterData) 262 13.1.2 打印程序示例概述 265 13.1.3 打印程序示例:主窗口程序 265 13.1.4 打印程序示例:打开文件程序 268 13.1.5 打印程序示例:设置字体和颜色程序 268 13.1.6 打印程序示例:打印文本的程序 269 13.1.7 打印程序示例:打印文件后的效果预览 273 13.2 使用应用程序 274 13.3 对AWT/Swing程序的支持 275 13.4 OLE和ActiveX控件的支持 275 13.4.1 OLE控件的面板类(OleFrame) 276 13.4.2 OLE控件类(OleClientSite和OleControlSite) 277 13.4.3 OLE 程序示例 278 13.5 Pocket PC应用 280 13.6 Web应用SWT 282 13.7 本章小结 282 第4篇 JFace篇 第14章 JFace概述 284 14.1 配置JFace运行环境 284 14.2 第一个JFace程序 285 14.3 JFace框架概述 287 14.4 JFace的包结构 287 14.5 本章小结 289 第15章 应用程序窗口 290 15.1 JFace的窗口类(Window类) 290 15.2 应用程序窗口ApplicationWindow类 292 15.3 带有菜单栏的主程序窗口 293 15.3.1 简单写字板程序示例 293 15.3.2 添加菜单栏的基本步骤 297 15.3.3 创建菜单项 297 15.3.4 菜单项的事件处理 298 15.4 带有工具栏的主程序窗口 299 15.5 带有状态栏的主程序窗口 300 15.6 其他处理事件的方法 304 15.6.1 “新建”操作 304 15.6.2 “保存”操作 305 15.6.3 “另存为”操作 306 15.6.4 “复制”、“剪切”和“粘贴”操作 307 15.7 本章小结 310 第16章 JFace对话框 311 16.1 JFace对话框概述 311 16.2 信息提示对话框(MessageDialog) 312 16.2.1 创建信息提示对话框 312 16.2.2 错误消息对话框 314 16.2.3 确认消息对话框 315 16.2.4 消息对话框 315 16.2.5 询问对话框 316 16.2.6 警告对话框 316 16.2.7 JFace的本地化 317 16.3 输入对话框(InputDialog) 318 16.3.1 创建输入对话框 319 16.3.2 创建输入文本的验证类 320 16.4 带有提示信息的对话框(TitleAreaDialog) 321 16.5 错误提示对话框(ErrorDialog) 325 16.5.1 创建错误提示对话框 325 16.5.2 使用错误状态对象 327 16.5.3 同时显示多个错误信息 327 16.6 带有进度条的对话框(ProgressMonitorDialog) 329 16.7 自定义对话框 330 16.7.1 自定义对话框程序示例 331 16.7.2 自定义对话框的步骤 333 16.8 本章小结 334 第17章 向导式对话框 335 17.1 向导式对话框概述 335 17.1.1 向导式对话框所涉及的类 335 17.1.2 向导式对话框的常用方法 336 17.2 简单的向导式对话框示例 338 17.2.1 第一个问题向导页面 338 17.2.2 第二个问题向导页面 339 17.2.3 感谢向导页面 340 17.2.4 创建向导 341 17.2.5 创建测试程序 342 17.3 保存对话框状态 344 17.4 复杂的向导式对话框示例 345 17.4.1 自定义向导页面 346 17.4.2 为向导添加帮助 349 17.5 向导式对话框的事件处理 350 17.6 本章小结 350 第18章 首选项 351 18.1 首选项概述 351 18.2 保存首选项的设置 353 18.2.1 首选项值的设置和获取 353 18.2.2 保存首选项所涉及的事件 354 18.3 显示首选项页面 354 18.3.1 创建一个首选项页面 354 18.3.2 创建首选项页面所对应的节点 357 18.3.3 显示首选项对话框 358 18.4 创建树型的导航菜单 360 18.4.1 第一种方法 361 18.4.2 第二种方法 361 18.5 首选项的选项设置 361 18.5.1 字段编辑器概述 362 18.5.2 使用字段编辑器基本步骤 362 18.5.3 布尔型字段编辑器(BooleanFieldEditor) 364 18.5.4 颜色字段编辑器(ColorFieldEditor) 364 18.5.5 字体字段编辑器(FontFieldEditor) 364 18.5.6 路径列表字段编辑器(PathEditor) 365 18.5.7 单选分组字段编辑器(RadioGroupFieldEditor) 365 18.5.8 刻度条字段编辑器(ScaleFieldEditor) 366 18.5.9 整数型字段编辑器(IntegerFieldEditor) 366 18.5.10 选择路径字段编辑器(DirectoryFieldEditor) 366 18.5.11 选择文件字段编辑器(FileFieldEditor) 366 18.6 自定义首选项页面 367 18.7 首选项的事件处理 368 18.8 本章小结 369 第19章 MVC的表格、树和列表 370 19.1 MVC概述 370 19.2 表格(TableViewer) 371 19.2.1 创建表格控制器(Controller) 371 19.2.2 创建表格模型(Model) 373 19.2.3 创建组织表格视图(View) 375 19.2.4 添加和删除数据 376 19.2.5 增加表格排序功能 378 19.2.6 增加表格过滤功能 380 19.2.7 编辑表格单元 381 19.2.8 表格的事件处理 383 19.2.9 带有复选框表格(CheckBoxTableViewer) 383 19.3 树(TreeViewer) 384 19.3.1 树的基本性质 385 19.3.2 创建树(TreeViewer) 386 19.3.3 对树的操作 389 19.4 树和表格的综合示例 390 19.4.1 文件浏览器功能概述 391 19.4.2 程序的整体框架 391 19.4.3 初始化树 393 19.4.4 初始化表格 394 19.4.5 程序的事件处理 396 19.5 列表ListViewer 397 19.6 本章小结 398 第20章 JFace的工具类 399 20.1 JFace资源管理机制 399 20.1.1 图像描述符(ImageDescriptor) 399 20.1.2 图像注册器(ImageRegistry) 401 20.1.3 字体描述符和字体注册器 403 20.1.4 颜色描述符和颜色注册器 404 20.1.5 JFace的资源管理器(JFaceResources) 406 20.1.6 字符转换工具类(StringConverter) 407 20.2 类型检查的工具类 407 20.3 本章小结 408 第21章 文本处理 409 21.1 文本处理概述 409 21.2 项目实战:JavaScript编辑器 409 21.2.1 主窗口预览 409 21.2.2 项目文件结构 410 21.3 主窗口模块 411 21.3.1 代码实现 411 21.3.2 主窗口程序代码分析 414 21.3.3 启动主窗口程序 416 21.4 代码着色 417 21.4.1 源代码配置类(SourceViewerConfiguration) 417 21.4.2 基于规则的代码扫描器类(RuleBasedScanner) 419 21.4.3 设置代码扫描规则 420 21.4.4 提取类(Token)和文本属性类(TextAttribute) 423 21.5 内容辅助 423 21.5.1 配置编辑器的内容助手 424 21.5.2 内容辅助类 424 21.5.3 辅助建议类(CompletionProposal) 426 21.6 文档的撤销与重复 427 21.6.1 文档管理器对象(DefaultUndoManager) 427 21.6.2 撤销操作的实现 427 21.6.3 恢复操作的实现 428 21.7 查找与替换窗口 429 21.7.1 窗口的界面设计 429 21.7.2 查找功能的实现 433 21.7.3 替换功能的实现 434 21.8 首选项的对话框 434 21.8.1 首选项页面的代码实现 435 21.8.2 打开首选项页面的代码 436 21.9 文件的打开、保存与打印 437 21.9.1 打开文件 437 21.9.2 保存文件 437 21.9.3 打印文件 438 21.10 帮助对话框 439 21.11 其他的一些工具类 440 21.11.1 事件管理类 440 21.11.2 资源管理类 441 21.11.3 程序中使用的常量 443 21.12 本章小结 444 第5篇 RCP应用篇 第22章 富客户端平台(RCP)应用 446 22.1 RCP概述 446 22.1.1 什么是RCP 446 22.1.2 RCP应用的现状 447 22.2 第一个RCP项目 448 22.2.1 创建插件项目 449 22.2.2 运行RCP程序 450 22.2.3 插件的文件清单 451 22.2.4 MANIFEST.MF文件 452 22.2.5 build.properties文件 454 22.2.6 plugin.xml文件 454 22.3 RCP运行的基本原理 455 22.3.1 插件类MyRCPPlugin 455 22.3.2 应用程序类Application 456 22.3.3 工作台窗口类 458 22.3.4 操作类 459 22.3.5 透视图类 460 22.4 创建扩展的基本方法 460 22.4.1 使用扩展向导创建 460 22.4.2 手工创建 462 22.4.3 获取扩展点的帮助 463 22.5 本章小结 464 第23章 RCP开发 465 23.1 扩展操作集(Action Set) 465 23.1.1 操作集扩展点 465 23.1.2 编写代码创建操作对象 469 23.1.3 编写代码创建操作的步骤 471 23.1.4 其他与操作有关的扩展点 473 23.2 扩展视图 473 23.2.1 视图扩展点 474 23.2.2 视图类 475 23.2.3 视图之间的交互 477 23.2.4 添加视图的工具栏 480 23.2.5 添加上下文菜单 481 23.3 扩展编辑器 484 23.3.1 编辑器扩展点 485 23.3.2 编辑器类 485 23.3.3 打开编辑器 488 23.3.4 添加编辑器的菜单和工具栏 491 23.3.5 多页编辑器 493 23.4 透视图 495 23.4.1 透视图的布局 495 23.4.2 透视图扩展点 498 23.4.3 透视图类 499 23.5 首选项 500 23.5.1 首选项扩展点 500 23.5.2 首选项页面扩展点 501 23.6 帮助文档 503 23.6.1 联机帮助文档扩展点 504 23.6.2 扩展配置 505 23.6.3 联机帮助的目录结构 506 23.6.4 添加动态帮助 507 23.7 RCP产品的发布 508 23.7.1 Eclipse产品配置 508 23.7.2 导出RCP产品 510 23.7.3 运行RCP产品 510 23.8 本章小结 511 第24章 Eclipse表单 512 24.1 Eclipse 表单概述 512 24.1.1 什么是Eclipse 表单 512 24.1.2 Eclipse表单的特性 513 24.1.3 Eclipse表单使用的类包 513 24.2 表单开发基础 513 24.2.1 视图中使用表单 513 24.2.2 多页编辑器中使用表单 515 24.2.3 SWT程序中使用表单 518 24.2.4 获得表单工具对象(FormToolkit)一般方法 519 24.3 表单的各种控件 519 24.3.1 可滚动的表单(ScrolledForm) 519 24.3.2 可折叠的面板(ExpandableComposite) 520 24.3.3 内容区(Section) 523 24.3.4 超链接(Hyperlink) 525 24.3.5 表单文本(FormText) 527 24.4 表单的布局管理器 531 24.4.1 表格布局(TableWrapLayout) 531 24.4.2 列布局(ColumnLayout) 534 24.5 表单的高级应用 536 24.5.1 Master/Details模式 536 24.5.2 实现Master/Detail示例程序 537 24.6 本章小结 544 第25章 项目实战——客户关系管理系统 545 25.1 系统概述 545 25.1.1 系统预览 545 25.1.2 基本概念介绍 546 25.1.3 系统的运行环境 547 25.1.4 系统文件结构的说明 547 25.2 UI界面设计 547 25.3 业务层设计 549 25.3.1 业务层服务的定义 549 25.3.2 业务层的实现 551 25.3.3 业务层服务的管理 552 25.3.4 业务层UML图 553 25.3.5 如何调用业务对象 554 25.4 数据库层设计 555 25.4.1 数据库接口类 556 25.4.2 实现了MySQL 数据库类 556 25.4.3 如何调用数据访问对象 561 25.4.4 应用多种数据库 562 25.4.5 数据库的初始化的脚本 563 25.4.6 表所对应的POJO类 564 25.5 登录模块 566 25.5.1 系统的上下文对象保存登录状态 566 25.5.2 登录验证的实现 567 25.5.3 登录窗口的实现 569 25.6 主窗口界面 572 25.6.1 工作台的实现 572 25.6.2 系统托盘的实现 573 25.6.3 菜单栏和工具栏的实现 575 25.6.4 操作管理类(ActionManager) 579 25.6.5 新建客户操作(NewCustomerAction) 580 25.6.6 打开视图操作(ShowViewAction) 581 25.7 各种视图和编辑器的实现 582 25.7.1 快速新建客户视图 583 25.7.2 客户列表视图 585 25.7.3 客户详细编辑器 590 25.7.4 联系人列表视图 595 25.7.5 快速新建联系人视图 597 25.7.6 搜索视图 600 25.7.7 导航视图 603 25.8 新建客户联系人向导 609 25.8.1 新建客户向导 609 25.8.2 新建联系人向导 615 25.9 首选项的实现 618 25.10 plugin.xml文件清单 623 25.11 本章小结... 626
jQuery Mobile快速入门245页完整版.pdf + 所有源码.7z 24H内删除,作者写书非常不容易,如觉得好,请购买纸质书籍,易读易懂!藏书不如读书,读书请买好书,这是好书。 第1章 jquery mobile简介  1.1 通用访问  1.2 跨所有移动平台的统一  1.3 简化的标记驱动的开发  1.4 渐进式增强  1.5 响应式设计  1.6 可主题化的设计  1.7 可访问性  1.8 总结 第2章 jquery mobile入门  2.1 jquery mobile页面模板  2.2 多页面模板  2.2.1 设置内部页面的页面标题  2.2.2 单页面文档与多页面文档的对比  2.3 ajax驱动的导航  2.3.1 $.mobile.changepage()  2.3.2 用途  2.3.3 参数  2.3.4 配置ajax导航  2.4 转换  2.5 对话框  2.5.1 链接与页面配置的对比  2.5.2 操作表  2.5.3 对话框ux指南  2.6 带有媒体查询的响应式布局  2.7 总结 第3章 使用页眉、工具栏和标签栏来导航  3.1 页眉栏  3.1.1 页眉基础知识  3.1.2 页眉结构  3.1.3 页眉定位  3.1.4 页眉按钮  3.1.5 既有文本又有图标的按钮  3.1.6 只带有图标的按钮  3.1.7 带有分段控件的页眉栏  3.1.8 修复被截断的页眉或页脚  3.2 回退按钮  3.3 页脚栏  3.3.1 页脚基础知识  3.3.2 页脚结构  3.3.3 页脚定位  3.3.4 页脚按钮  3.4 工具栏  3.4.1 带有图标的工具栏  3.4.2 带有分段控件的工具栏  3.5 标签栏  3.5.1 带有标准图标的标签栏  3.5.2 永久标签栏  3.5.3 带有自定义图标的标签栏  3.5.4 带有分段控件的标签栏  3.6 总结 第4章 表单元素和按钮  4.1 按钮  4.1.1 链接按钮  4.1.2 表单按钮  4.1.3 图像按钮  4.1.4 使用图标来设计按钮  4.1.5 只带有图标的按钮  4.1.6 按钮定位  4.1.7 带有自定义图标的按钮  4.1.8 分组按钮  4.1.9 主题按钮  4.1.10 动态按钮  4.2 表单元素  4.2.1 表单基础知识  4.2.2 文本输入  4.2.3 选择菜单  4.2.4 单选按钮  4.2.5 复选框  4.2.6 滑动条  4.2.7 开关控件  4.2.8 本地表单元素  4.2.9 mobiscroll日期选择器  4.3 总结 第5章 列表视图  5.1 列表基础知识  5.2 内置列表  5.3 列表分割线  5.4 带有缩略图和图标的列表  5.5 拆分按钮列表  5.6 编号列表  5.7 只读列表  5.8 列表徽章(计数泡)  5.9 使用搜索栏过滤列表  5.10 动态列表  5.10.1 列表选项  5.10.2 列表方法  5.10.3 列表事件  5.11 总结 第6章 使用表格和css渐变来格式化内容  6.1 表格布局  6.1.1 表格模板  6.1.2 两列的表格  6.1.3 带有css增强的三列表格  6.1.4 带有app图标的四列表格  6.1.5 带有emoji图标的五列表格  6.1.6 多行表格  6.1.7 不相等的表格  6.1.8 springboard  6.2 可折叠的内容块  6.3 可折叠的设置  6.4 使用css渐变进行样式化  6.5 总结 第7章 创建可主题化的设计  7.1 主题基础知识  7.2 主题和调色板  7.3 主题默认值  7.4 主题继承  7.5 自定义主题  7.6 themeroller  7.6.1 调色板和全局设置  7.6.2 preview inspector和quickswatch bar  7.6.3 adobe kuler集成  7.6.4 入门  7.7 总结 第8章 jquery mobile api  8.1 配置jquery mobile  8.1.1 自定义脚本的位置  8.1.2 可配置的jquery mobile选项  8.2 方法  8.3 事件  8.3.1 事件概览  8.3.2 触发事件  8.4 属性  8.5 数据属性  8.6 总结 第9章 服务集成策略  9.1 使用restful服务的客户端集成  9.1.1 使用ajax的客户端twitter集成  9.1.2 使用ajax的客户端表单post  9.2 使用mvc的服务器端集成  9.2.1 使用mvc的服务器端表单post  9.2.2 使用mvc的服务器端数据访问  9.2.3
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

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧