﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-流水账-文章分类-EXT</title><link>http://www.blogjava.net/wanghun723/category/39600.html</link><description /><language>zh-cn</language><lastBuildDate>Mon, 18 May 2009 20:42:36 GMT</lastBuildDate><pubDate>Mon, 18 May 2009 20:42:36 GMT</pubDate><ttl>60</ttl><item><title>EXT提交服务器的三种方式</title><link>http://www.blogjava.net/wanghun723/articles/270904.html</link><dc:creator>L.J.</dc:creator><author>L.J.</author><pubDate>Fri, 15 May 2009 09:25:00 GMT</pubDate><guid>http://www.blogjava.net/wanghun723/articles/270904.html</guid><wfw:comment>http://www.blogjava.net/wanghun723/comments/270904.html</wfw:comment><comments>http://www.blogjava.net/wanghun723/articles/270904.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/wanghun723/comments/commentRss/270904.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/wanghun723/services/trackbacks/270904.html</trackback:ping><description><![CDATA[<p>1.EXT提交服务器的三种方式&nbsp;<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1, EXT的form表单ajax提交（默认提交方式）<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 相对单独的ajax提交来说优点在于能省略写参数数组。将按钮添加单击事件，执行以下方法<br />
&nbsp;代码<br />
</p>
<div style="border-right: #cccccc 1px solid; padding-right: 5px; border-top: #cccccc 1px solid; padding-left: 4px; font-size: 13px; padding-bottom: 4px; border-left: #cccccc 1px solid; width: 98%; word-break: break-all; padding-top: 4px; border-bottom: #cccccc 1px solid; background-color: #eeeeee"><img id="Codehighlighter1_20_917_Open_Image" onclick="this.style.display='none'; Codehighlighter1_20_917_Open_Text.style.display='none'; Codehighlighter1_20_917_Closed_Image.style.display='inline'; Codehighlighter1_20_917_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_20_917_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_20_917_Closed_Text.style.display='none'; Codehighlighter1_20_917_Open_Image.style.display='inline'; Codehighlighter1_20_917_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top"  alt="" /><span style="color: #0000ff">function</span><span style="color: #000000">&nbsp;login(item)</span><span id="Codehighlighter1_20_917_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_20_917_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /><br />
<img id="Codehighlighter1_48_915_Open_Image" onclick="this.style.display='none'; Codehighlighter1_48_915_Open_Text.style.display='none'; Codehighlighter1_48_915_Closed_Image.style.display='inline'; Codehighlighter1_48_915_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_48_915_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_48_915_Closed_Text.style.display='none'; Codehighlighter1_48_915_Open_Image.style.display='inline'; Codehighlighter1_48_915_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">if</span><span style="color: #000000">&nbsp;(validatorForm())&nbsp;</span><span id="Codehighlighter1_48_915_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_48_915_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">&nbsp;登录时将登录按钮设为disabled，防止重复提交&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.disabled&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;</span><span style="color: #0000ff">true</span><span style="color: #000000">;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">&nbsp;第一个参数可以为submit和load&nbsp;</span><span style="color: #008000"><br />
<img id="Codehighlighter1_200_876_Open_Image" onclick="this.style.display='none'; Codehighlighter1_200_876_Open_Text.style.display='none'; Codehighlighter1_200_876_Closed_Image.style.display='inline'; Codehighlighter1_200_876_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_200_876_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_200_876_Closed_Text.style.display='none'; Codehighlighter1_200_876_Open_Image.style.display='inline'; Codehighlighter1_200_876_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;formPanl.form.doAction('submit',&nbsp;</span><span id="Codehighlighter1_200_876_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_200_876_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;url:&nbsp;'user.</span><span style="color: #0000ff">do</span><span style="color: #000000">?</span><span style="color: #000000">method</span><span style="color: #000000">=</span><span style="color: #000000">login',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;method:&nbsp;'post',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">&nbsp;如果有表单以外的其它参数，可以加在这里。我这里暂时为空，也可以将下面这句省略&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;params:&nbsp;'',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">&nbsp;第一个参数是传入该表单，第二个是Ext.form.Action对象用来取得服务器端传过来的json数据&nbsp;</span><span style="color: #008000"><br />
<img id="Codehighlighter1_509_649_Open_Image" onclick="this.style.display='none'; Codehighlighter1_509_649_Open_Text.style.display='none'; Codehighlighter1_509_649_Closed_Image.style.display='inline'; Codehighlighter1_509_649_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_509_649_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_509_649_Closed_Text.style.display='none'; Codehighlighter1_509_649_Open_Image.style.display='inline'; Codehighlighter1_509_649_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;success:&nbsp;</span><span style="color: #0000ff">function</span><span style="color: #000000">(form,&nbsp;action)</span><span id="Codehighlighter1_509_649_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_509_649_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ext.Msg.alert('操作',&nbsp;action.result.data);<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.disabled&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;</span><span style="color: #0000ff">false</span><span style="color: #000000">;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">,<br />
<img id="Codehighlighter1_695_866_Open_Image" onclick="this.style.display='none'; Codehighlighter1_695_866_Open_Text.style.display='none'; Codehighlighter1_695_866_Closed_Image.style.display='inline'; Codehighlighter1_695_866_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_695_866_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_695_866_Closed_Text.style.display='none'; Codehighlighter1_695_866_Open_Image.style.display='inline'; Codehighlighter1_695_866_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;failure:&nbsp;</span><span style="color: #0000ff">function</span><span style="color: #000000">(form,&nbsp;action)</span><span id="Codehighlighter1_695_866_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_695_866_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ext.Msg.alert('警告',&nbsp;'用户名或密码错误！');<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">&nbsp;登录失败，将提交按钮重新设为可操作&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.disabled&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;</span><span style="color: #0000ff">false</span><span style="color: #000000">;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">);<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.disabled&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;</span><span style="color: #0000ff">false</span><span style="color: #000000">;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top"  alt="" />}</span></span></div>
<p><br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 2.EXT表单的非ajax提交，在表单需加入下列代码<br />
代码</p>
<div style="border-right: #cccccc 1px solid; padding-right: 5px; border-top: #cccccc 1px solid; padding-left: 4px; font-size: 13px; padding-bottom: 4px; border-left: #cccccc 1px solid; width: 98%; word-break: break-all; padding-top: 4px; border-bottom: #cccccc 1px solid; background-color: #eeeeee"><img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" /><span style="color: #008000">//</span><span style="color: #008000">实现非AJAX提交表单一定要加下面的两行！&nbsp;onSubmit&nbsp;:&nbsp;Ext.emptyFn,&nbsp;submit&nbsp;:&nbsp;</span><span style="color: #008000"><br />
<img id="Codehighlighter1_69_225_Open_Image" onclick="this.style.display='none'; Codehighlighter1_69_225_Open_Text.style.display='none'; Codehighlighter1_69_225_Closed_Image.style.display='inline'; Codehighlighter1_69_225_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_69_225_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_69_225_Closed_Text.style.display='none'; Codehighlighter1_69_225_Open_Image.style.display='inline'; Codehighlighter1_69_225_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top"  alt="" /></span><span style="color: #0000ff">function</span><span style="color: #000000">()&nbsp;</span><span id="Codehighlighter1_69_225_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_69_225_Open_Text"><span style="color: #000000">{&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">再次设定action的地址&nbsp;&nbsp;&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.getEl().dom.action&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">'user.</span><span style="color: #0000ff">do</span><span style="color: #000000">?</span><span style="color: #000000">method</span><span style="color: #000000">=</span><span style="color: #000000">login';&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.getEl().dom.method&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;'post';&nbsp;&nbsp;&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">提交submit&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">this</span><span style="color: #000000">.getEl().dom.submit();&nbsp;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top"  alt="" />}</span></span></div>
<p><br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 3.EXT的ajax提交<br />
代码<br />
</p>
<div style="border-right: #cccccc 1px solid; padding-right: 5px; border-top: #cccccc 1px solid; padding-left: 4px; font-size: 13px; padding-bottom: 4px; border-left: #cccccc 1px solid; width: 98%; word-break: break-all; padding-top: 4px; border-bottom: #cccccc 1px solid; background-color: #eeeeee"><img id="Codehighlighter1_17_524_Open_Image" onclick="this.style.display='none'; Codehighlighter1_17_524_Open_Text.style.display='none'; Codehighlighter1_17_524_Closed_Image.style.display='inline'; Codehighlighter1_17_524_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_17_524_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_17_524_Closed_Text.style.display='none'; Codehighlighter1_17_524_Open_Image.style.display='inline'; Codehighlighter1_17_524_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top"  alt="" /><span style="color: #000000">Ext.Ajax.request(</span><span id="Codehighlighter1_17_524_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_17_524_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">请求地址&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;url:&nbsp;'login.</span><span style="color: #0000ff">do</span><span style="color: #000000">',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">提交参数组&nbsp;</span><span style="color: #008000"><br />
<img id="Codehighlighter1_77_192_Open_Image" onclick="this.style.display='none'; Codehighlighter1_77_192_Open_Text.style.display='none'; Codehighlighter1_77_192_Closed_Image.style.display='inline'; Codehighlighter1_77_192_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_77_192_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_77_192_Closed_Text.style.display='none'; Codehighlighter1_77_192_Open_Image.style.display='inline'; Codehighlighter1_77_192_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;params:&nbsp;</span><span id="Codehighlighter1_77_192_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_77_192_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;LoginName:&nbsp;Ext.get('LoginName').dom.value,<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;LoginPassword:&nbsp;Ext.get('LoginPassword').dom.value<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">,<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">成功时回调&nbsp;</span><span style="color: #008000"><br />
<img id="Codehighlighter1_248_522_Open_Image" onclick="this.style.display='none'; Codehighlighter1_248_522_Open_Text.style.display='none'; Codehighlighter1_248_522_Closed_Image.style.display='inline'; Codehighlighter1_248_522_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_248_522_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_248_522_Closed_Text.style.display='none'; Codehighlighter1_248_522_Open_Image.style.display='inline'; Codehighlighter1_248_522_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;success:&nbsp;</span><span style="color: #0000ff">function</span><span style="color: #000000">(response,&nbsp;options)</span><span id="Codehighlighter1_248_522_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_248_522_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #008000">//</span><span style="color: #008000">获取响应的json字符串&nbsp;</span><span style="color: #008000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" /></span><span style="color: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">var</span><span style="color: #000000">&nbsp;responseArray&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;Ext.util.JSON.decode(response.responseText);<br />
<img id="Codehighlighter1_390_444_Open_Image" onclick="this.style.display='none'; Codehighlighter1_390_444_Open_Text.style.display='none'; Codehighlighter1_390_444_Closed_Image.style.display='inline'; Codehighlighter1_390_444_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_390_444_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_390_444_Closed_Text.style.display='none'; Codehighlighter1_390_444_Open_Image.style.display='inline'; Codehighlighter1_390_444_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">if</span><span style="color: #000000">&nbsp;(responseArray.success&nbsp;</span><span style="color: #000000">==</span><span style="color: #000000">&nbsp;</span><span style="color: #0000ff">true</span><span style="color: #000000">)&nbsp;</span><span id="Codehighlighter1_390_444_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_390_444_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ext.Msg.alert('恭喜',&nbsp;'您已成功登录！');<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000"><br />
<img id="Codehighlighter1_459_516_Open_Image" onclick="this.style.display='none'; Codehighlighter1_459_516_Open_Text.style.display='none'; Codehighlighter1_459_516_Closed_Image.style.display='inline'; Codehighlighter1_459_516_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_459_516_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_459_516_Closed_Text.style.display='none'; Codehighlighter1_459_516_Open_Image.style.display='inline'; Codehighlighter1_459_516_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000ff">else</span><span style="color: #000000">&nbsp;</span><span id="Codehighlighter1_459_516_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_459_516_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ext.Msg.alert('失败',&nbsp;'登录失败，请重新登录');<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000"><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top"  alt="" />}</span></span><span style="color: #000000">);</span></div>
<p><br />
2. 利用viewport布局左边区域系统菜单跳转两种方式<br />
<br />
<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1，使用Ext.get('centerPanel').load(url:"aaa.jsp");url为必选参数还有其他可选参数&nbsp;&nbsp;&nbsp;&nbsp; 请参见api文档。缺点，加入的页面js无效<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 2，使用iframe，具体<br />
js 代码<br />
Ext.get('centerPanel').dom.innerHTML='&lt; i f r a m e src=aaa.jsp&gt;&lt; / i f r a m e &gt;'; <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 优 点可以在载入的页面动态加载js脚本（推荐使用）<br />
</p>
<img src ="http://www.blogjava.net/wanghun723/aggbug/270904.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/wanghun723/" target="_blank">L.J.</a> 2009-05-15 17:25 <a href="http://www.blogjava.net/wanghun723/articles/270904.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>ext2.0(使用表格控件Grid)</title><link>http://www.blogjava.net/wanghun723/articles/270900.html</link><dc:creator>L.J.</dc:creator><author>L.J.</author><pubDate>Fri, 15 May 2009 09:17:00 GMT</pubDate><guid>http://www.blogjava.net/wanghun723/articles/270900.html</guid><wfw:comment>http://www.blogjava.net/wanghun723/comments/270900.html</wfw:comment><comments>http://www.blogjava.net/wanghun723/articles/270900.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/wanghun723/comments/commentRss/270900.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/wanghun723/services/trackbacks/270900.html</trackback:ping><description><![CDATA[&nbsp;ExtJS中的表格功能非常强大，包括了排序、缓存、拖动、隐藏某一列、自动显示行号、列汇总、单元格编辑等实用功能。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 表格由类Ext.grid.GridPanel定义，继承自Panel，其xtype为grid。ExtJS中，表格Grid必须包含列定义信息，并指定 表格的数据存储器Store。表格的列信息由类Ext.grid.ColumnModel定义、而表格的数据存储器由Ext.data.Store定义， 数据存储器根据解析的数据不同分为JsonStore、SimpleStroe、GroupingStore等。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 我们首先来看最简单的使用表格的代码：
<pre style="font-size: 12px; background-color: rgb(238,238,238)">Ext.onReady(function(){ <br />
<br />
var data=[ [1, 'EasyJWeb', 'EasyJF','www.easyjf.com'],<br />
<br />
[2, 'jfox', 'huihoo','www.huihoo.org'], <br />
<br />
[3, 'jdon', 'jdon','www.jdon.com'],<br />
<br />
[4, 'springside', 'springside','www.springside.org.cn'] ];<br />
<br />
var store=new Ext.data.SimpleStore({data:data,fields:["id","name","organization","homepage"]});<br />
<br />
var grid = new Ext.grid.GridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"中国Java开源产品及团队",<br />
<br />
height:150,<br />
<br />
width:600, <br />
<br />
columns:[{header:"项目名称",dataIndex:"name"},<br />
<br />
{header:"开发团队",dataIndex:"organization"},<br />
<br />
{header:"网址",dataIndex:"homepage"}],<br />
<br />
store:store,<br />
<br />
autoExpandColumn:2<br />
<br />
}); <br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 执行上面的代码，可以得到一个简单的表格，如下图所示：</p>
<p><img height="140" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image097.jpg" width="553" border="0"  alt="" /></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 上面的代码中，第一行&#8220;var data=&#8230;&#8221;用来定义表格中要显示的数据，这是一个[][]二维数组；第二行&#8220;var store=&#8230;&#8221;用来创建一个数据存储，这是GridPanel需要使用配置属性，数据存储器Store负责把各种各样的数据（如二维数组、JSon对象 数组、xml文本）等转换成ExtJS的数据记录集Record，关于数据存储器Store我们将在下一章中作专门介绍。第三行&#8220;var grid = new Ext.grid.GridPanel(&#8230;)&#8221;负责创建一个表格，表格包含的列由columns配置属性来描述，columns是一数组，每一行数据元素 描述表格的一列信息，表格的列信息包含列头显示文本(header)、列对应的记录集字段(dataIndex)、列是否可排序(sorable)、列的 渲染函数(renderer)、宽度(width)、格式化信息(format)等，在上面的列子中只用到了header及dataIndex。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 下面我们看简单看看表格的排序及隐藏列特性，简单修改一下上面的代码，内容如下：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">Ext.onReady(function(){ <br />
<br />
var data=[ [1, 'EasyJWeb', 'EasyJF','www.easyjf.com'],<br />
<br />
[2, 'jfox', 'huihoo','www.huihoo.org'], <br />
<br />
[3, 'jdon', 'jdon','www.jdon.com'],<br />
<br />
[4, 'springside', 'springside','www.springside.org.cn'] ];<br />
<br />
var store=new Ext.data.SimpleStore({data:data,fields:["id","name","organization","homepage"]});<br />
<br />
var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true},<br />
<br />
{header:"开发团队",dataIndex:"organization",sortable:true},<br />
<br />
{header:"网址",dataIndex:"homepage"}]);<br />
<br />
var grid = new Ext.grid.GridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"中国Java开源产品及团队",<br />
<br />
height:200,<br />
<br />
width:600, <br />
<br />
cm:colM,<br />
<br />
store:store,<br />
<br />
autoExpandColumn:2<br />
<br />
}); <br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 直接使用new Ext.grid.ColumnModel来创建表格的列信定义信息，在&#8220;项目名称&#8220;及&#8220;开发团队&#8221;列中我们添加了sortable为true的属性，表 示该列可以排序，执行上面的代码，我们可以得到一个支持按&#8220;项目名称&#8220;或&#8220;开发团队&#8221;的表格，如图xxx所示。</p>
<p align="center"><img height="185" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image099.jpg" width="553" border="0"  alt="" /></p>
<p align="center">(按项目名称排序)</p>
<p align="center"><img height="186" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image101.jpg" width="554" border="0"  alt="" /></p>
<p align="center">(可排序的列表头后面小按钮可以弹出操作菜单)</p>
<p align="center"><img height="187" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image103.jpg" width="554" border="0"  alt="" /></p>
<p align="center">(可以指定隐藏哪些列)</p>
<p align="left">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 另外，每一列的数据渲染方式还可以自己定义，比如上面的表格中，我们希望用户在表格中点击网址则直接打开这些开源团队的网站，也就是需要给网址这一列添加上超级连接。下面的代码实现这个功能：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">function showUrl(value)<br />
<br />
{<br />
<br />
return "<a href="http:///" target="_blank">"+value+"</a>";<br />
<br />
}<br />
<br />
Ext.onReady(function(){ <br />
<br />
var data=[ [1, 'EasyJWeb', 'EasyJF','www.easyjf.com'],<br />
<br />
[2, 'jfox', 'huihoo','www.huihoo.org'], <br />
<br />
[3, 'jdon', 'jdon','www.jdon.com'],<br />
<br />
[4, 'springside', 'springside','www.springside.org.cn'] ];<br />
<br />
var store=new Ext.data.SimpleStore({data:data,fields:["id","name","organization","homepage"]});<br />
<br />
var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true},<br />
<br />
{header:"开发团队",dataIndex:"organization",sortable:true},<br />
<br />
{header:"网址",dataIndex:"homepage",renderer:showUrl}]);<br />
<br />
var grid = new Ext.grid.GridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"中国Java开源产品及团队",<br />
<br />
height:200,<br />
<br />
width:600, <br />
<br />
cm:colM,<br />
<br />
store:store,<br />
<br />
autoExpandColumn:2<br />
<br />
}); <br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 上面的代码跟前面的示例差别不大，只是在定义&#8220;网址&#8221;列的时候多了一个renderer属性，即{header:"网址",dataIndex: "homepage",renderer:showUrl}。showUrl是一个自定义的函数，内容就是根据传入的value参数返回一个包含<a>标签的html片段。运行上面的代码显示结果如下图所示：</a><a href="http:///" target="_blank">"+value+"</a>"; } Ext.onReady(function(){ var store=new Ext.data.Store({ url:"hello.xml", reader:new Ext.data.XmlReader({ record:"row"}, ["id","name","organization","homepage"]) }); var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true}, {header:"开发团队",dataIndex:"organization",sortable:true}, {header:"网址",dataIndex:"homepage",renderer:showUrl}]); var grid = new Ext.grid.GridPanel({ renderTo:"hello", title:"中国Java开源产品及团队", height:200, width:600, cm:colM, store:store, autoExpandColumn:2 }); store.load(); });</p>
<p align="center"><img height="184" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image105.jpg" width="553" border="0"  alt="" /></p>
<p align="left"></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 自定义的列渲染函数可以实现在单元格中显示自己所需要的各种信息，只是的浏览器能处理的html都可以。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 除了二级数组以外，表格还能显示其它格式的数据吗？答案是肯定的，下面假如我们的表格数据data定义成了下面的形式：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">var data=[{id:1,<br />
<br />
name:'EasyJWeb',<br />
<br />
organization:'EasyJF',<br />
<br />
homepage:'www.easyjf.com'},<br />
<br />
{id:2,<br />
<br />
name:'jfox',<br />
<br />
organization:'huihoo',<br />
<br />
homepage:'www.huihoo.org'}, <br />
<br />
{id:3,<br />
<br />
name:'jdon',<br />
<br />
organization:'jdon',<br />
<br />
homepage:'www.jdon.com'},<br />
<br />
{id:4, <br />
<br />
name:'springside',<br />
<br />
organization: 'springside',<br />
<br />
homepage:'www.springside.org.cn'}<br />
<br />
];</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 也就是说数据变成了一维数组，数组中的每一个元素是一个对象，这些对象包含name、organization、homepage、id等属性。要让表格 显示上面的数据，其实非常简单，只需要把store改成用Ext.data.JsonStore即可，代码如下：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">var store=new Ext.data.JsonStore({data:data,fields:["id","name","organization","homepage"]});<br />
<br />
var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true},<br />
<br />
{header:"开发团队",dataIndex:"organization",sortable:true},<br />
<br />
{header:"网址",dataIndex:"homepage",renderer:showUrl}]);<br />
<br />
var grid = new Ext.grid.GridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"中国Java开源产品及团队",<br />
<br />
height:200,<br />
<br />
width:600, <br />
<br />
cm:colM,<br />
<br />
store:store,<br />
<br />
autoExpandColumn:2<br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 上面的代码得到的结果与前面的一样。当然，表格同样能显示xml格式的数据，假如上面的数据存放成hello.xml文件中，内容如下：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)"><br />
<br />
<br />
<br />
<br />
<br />
1<br />
<br />
EasyJWeb<br />
<br />
EasyJF<br />
<br />
www.easyjf.com<br />
<br />
<br />
<br />
<br />
<br />
2<br />
<br />
jfox<br />
<br />
huihoo<br />
<br />
www.huihoo.org<br />
<br />
<br />
<br />
<br />
<br />
3<br />
<br />
jdon<br />
<br />
jdon<br />
<br />
www.jdon.com<br />
<br />
<br />
<br />
<br />
<br />
4<br />
<br />
springside<br />
<br />
springside<br />
<br />
www.springside.org.cn</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 为了把这个xml数据用ExtJS的表格Grid进行显示，我们只需要把store部分的内容调整成如下的内容即可：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">var store=new Ext.data.Store({<br />
<br />
url:"hello.xml", <br />
<br />
reader:new Ext.data.XmlReader({<br />
<br />
record:"row"},<br />
<br />
["id","name","organization","homepage"])<br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 其它的部分不用改变，完整的代码如下：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">function showUrl(value)<br />
<br />
{<br />
<br />
return "<a href="http:///" target="_blank">"+value+"</a>";<br />
<br />
}<br />
<br />
Ext.onReady(function(){ <br />
<br />
var store=new Ext.data.Store({<br />
<br />
url:"hello.xml", <br />
<br />
reader:new Ext.data.XmlReader({<br />
<br />
record:"row"},<br />
<br />
["id","name","organization","homepage"])<br />
<br />
}); <br />
<br />
var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true},<br />
<br />
{header:"开发团队",dataIndex:"organization",sortable:true},<br />
<br />
{header:"网址",dataIndex:"homepage",renderer:showUrl}]);<br />
<br />
var grid = new Ext.grid.GridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"中国Java开源产品及团队",<br />
<br />
height:200,<br />
<br />
width:600, <br />
<br />
cm:colM,<br />
<br />
store:store,<br />
<br />
autoExpandColumn:2<br />
<br />
}); <br />
<br />
store.load(); <br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; store.laod()是用来加载数据，执行上面的代码产生的表格与前面的完全一样。</p>
<strong>可编辑表格EditorGridPanel<br />
<br />
</strong>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 可编辑表格是指可以直接在表格的单元格对表格的数据进行编辑，ExtJS中的可编辑表格由类Ext.grid.EditorGridPanel表示， xtype为editorgrid。使用EditorGridPanel与使用普通的GridPanel方式一样，区别只是在定义列信息的时候，可以指定 某一列使用的编辑即可，下面来看一个简单的示例。</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">Ext.onReady(function(){ <br />
<br />
var data=[{id:1,<br />
<br />
name:'小王',<br />
<br />
email:'xiaowang@easyjf.com',<br />
<br />
sex:'男',<br />
<br />
bornDate:'1991-4-4'},<br />
<br />
{id:1,<br />
<br />
name:'小李',<br />
<br />
email:'xiaoli@easyjf.com',<br />
<br />
sex:'男',<br />
<br />
bornDate:'1992-5-6'},<br />
<br />
{id:1,<br />
<br />
name:'小兰',<br />
<br />
email:'xiaoxiao@easyjf.com',<br />
<br />
sex:'女',<br />
<br />
bornDate:'1993-3-7'} <br />
<br />
];<br />
<br />
var store=new Ext.data.JsonStore({<br />
<br />
data:data,<br />
<br />
fields:["id","name","sex","email",{name:"bornDate",type:"date",dateFormat:"Y-n-j"}]<br />
<br />
}); <br />
<br />
var colM=new Ext.grid.ColumnModel([{<br />
<br />
header:"姓名",<br />
<br />
dataIndex:"name",<br />
<br />
sortable:true,<br />
<br />
editor:new Ext.form.TextField()}, <br />
<br />
{header:"性别",<br />
<br />
dataIndex:"sex"<br />
<br />
},<br />
<br />
{header:"出生日期",<br />
<br />
dataIndex:"bornDate",<br />
<br />
width:120,<br />
<br />
renderer:Ext.util.Format.dateRenderer('Y年m月d日')},<br />
<br />
{header:"电子邮件",<br />
<br />
dataIndex:"email",<br />
<br />
sortable:true,<br />
<br />
editor:new Ext.form.TextField()}<br />
<br />
]);<br />
<br />
var grid = new Ext.grid.EditorGridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"学生基本信息管理",<br />
<br />
height:200,<br />
<br />
width:600, <br />
<br />
cm:colM,<br />
<br />
store:store,<br />
<br />
autoExpandColumn:3<br />
<br />
});<br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 上面的程序首先定义了一个包含学生信息的对象数组，然后创建了一个JsonStore，在创建这个store的时候，指定bornDate列的类型为日期 date类型，并使用dateFormat来指定日期信息的格式为"Y-n-j"，Y代表年，n代表月,j代表日期。定义表格列模型的时候，对于&#8220;姓名&#8221; 及&#8220;电子邮件&#8221;列我们使用editor来定义该列使用的编辑器，这里是使用Ext.form.TextField，最后使用new Ext.grid.EditorGridPanel(&#8230;)来创建一个可编辑的表格。执行上面的程序可以生成一个表格，双击表格中的&#8220;姓名&#8221;、或&#8220;电子邮 件&#8221;单元格中的信息可以触发单元格的编辑，可以在单元格的文本框中直接编辑表格中的内容，修改过的单元格会有特殊的标记，如下图所示：</p>
<p align="center"><img height="185" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image107.jpg" width="554" border="0"  alt="" /></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 为了能编辑&#8220;性别&#8221;及&#8220;出生日期&#8221;列，同样只需要在定义该列的时候指定editor即可。由于出生日期是日期类型，因此我们可以使用日期编辑器来编辑， &#8220;性别&#8221;一列的数据不应该让用户直接输入，而应该是通过下拉框进行选择。日期编辑器可以直接使用Ext.form.DateField组件，下拉选择框编 辑器可以使用Ext.form.ComboBox组件，下面是实现对性别及出生日期等列信息编辑的代码：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">var colM=new Ext.grid.ColumnModel([{<br />
<br />
header:"姓名",<br />
<br />
dataIndex:"name",<br />
<br />
sortable:true,<br />
<br />
editor:new Ext.form.TextField()}, <br />
<br />
{header:"性别",<br />
<br />
dataIndex:"sex",<br />
<br />
editor:new Ext.form.ComboBox({transform:"sexList",<br />
<br />
triggerAction: 'all',<br />
<br />
lazyRender:true})<br />
<br />
},<br />
<br />
{header:"出生日期",<br />
<br />
dataIndex:"bornDate",<br />
<br />
width:120,<br />
<br />
renderer:Ext.util.Format.dateRenderer('Y年m月d日'),<br />
<br />
editor:new Ext.form.DateField({format:'Y年m月d日'})},<br />
<br />
{header:"电子邮件",<br />
<br />
dataIndex:"email",<br />
<br />
sortable:true,<br />
<br />
editor:new Ext.form.TextField()}<br />
<br />
]);<br />
<br />
var grid = new Ext.grid.EditorGridPanel({<br />
<br />
renderTo:"hello",<br />
<br />
title:"学生基本信息管理",<br />
<br />
height:200,<br />
<br />
width:600, <br />
<br />
cm:colM,<br />
<br />
store:store,<br />
<br />
autoExpandColumn:3,<br />
<br />
clicksToEdit:1<br />
<br />
});</pre>
<p>&nbsp;</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 注意在定义EditorGridPanel的时候，我们增加了一个属性&#8220;clicksToEdit:1&#8221;，表示点击一次单元格即触发编辑，因为默认情况下 该值为2，需要双击单元格才能编辑。为了给ComboBox中填充数据，我们使用设置了该组件的transform配置属性值为sexList， sexList是一个传统的 男 女</p>
<pre> </pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 执行上面的程序，我们可以得到一个能对表格中所有数据进行编辑的表格了。点击上面的&#8220;性别&#8221;一列的单元格时，会出现一个下拉选择框，点击&#8220;出生日期&#8221;一列的单元格时，会出现一个日期数据选择框，如图xxxx所示：</p>
<p align="center"><img height="184" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image109.jpg" width="553" border="0"  alt="" /></p>
<p align="center">(编辑性别列中的数据)</p>
<p align="center"><img height="254" src="file:///E:/Develop%20Helper/EXT/资料/ext2_0(使用表格控件Grid)_小熊爱燕子.files/image111.jpg" width="553" border="0"  alt="" /></p>
<p align="center">(编辑出生日期列中的数据)</p>
<p align="left"></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 那么如何保存编辑后的数据呢？答案是直接使用afteredit事件。当对一个单元格进行编辑完之后，就会触发afteredit事件，可以通过该事件处理函数来处理单元格的信息编辑。比如在<a href="http://wlr.easyjf.com/">http://wlr.easyjf.com/</a>这个单用户blog示例中，当我们编辑一个日志目录的时候，需要把编辑后的数据保存到服务器，代码如下：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">this.grid.on("afteredit",this.afterEdit,this);<br />
<br />
&#8230; <br />
<br />
afterEdit:function(obj){<br />
<br />
var r=obj.record;<br />
<br />
var id=r.get("id");<br />
<br />
var name=r.get("name");<br />
<br />
var c=this.record2obj(r);<br />
<br />
var tree=this.tree;<br />
<br />
var node=tree.getSelectionModel().getSelectedNode(); <br />
<br />
if(node &amp;&amp; node.id!="root")c.parentId=node.id;<br />
<br />
if(id=="-1" &amp;&amp; name!=""){ <br />
<br />
topicCategoryService.addTopicCategory(c,function(id){ <br />
<br />
if(id)r.set("id",id);<br />
<br />
if(!node)node=tree.root;<br />
<br />
node.appendChild(new Ext.tree.TreeNode({<br />
<br />
id:id,<br />
<br />
text:c.name,<br />
<br />
leaf:true<br />
<br />
}));<br />
<br />
node.getUI().removeClass('x-tree-node-leaf');<br />
<br />
node.getUI().addClass('x-tree-node-expanded');<br />
<br />
node.expand();<br />
<br />
});<br />
<br />
}<br />
<br />
else if(name!="")<br />
<br />
{ <br />
<br />
topicCategoryService.updateTopicCategory(r.get("id"),c,function(ret){ <br />
<br />
if(ret)tree.getNodeById(r.get("id")).setText(c.name);<br />
<br />
});<br />
<br />
}<br />
<br />
}</pre>
<br />
<p>&nbsp;</p>
<p><strong>与服务器交互</strong></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 在实际的应用中，表格中的数据一般都是直接存放在数据库表或服务器的文件中。因此，在使用表格控件的时候经常需要与服务器进行交互。ExtJS使用 Ajax方式提供了一套与服务器交互的机制，也就是可以不用刷新页面，就可以访问服务器的程序进行数据读取或数据保存等操作。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 比如前面在表格中显示xml文档中数据的例子中，就是一个非常简单的从服务器端读取数据的例子，再回顾一下代码：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">var store=new Ext.data.Store({<br />
<br />
url:"hello.xml", <br />
<br />
reader:new Ext.data.XmlReader({<br />
<br />
record:"row"},<br />
<br />
["id","name","organization","homepage"])<br />
<br />
});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 因为Sote组件接受一个参数url，如果设置url，则ExtJS会创建一个与服务器交互的Ext.data.HttpProxy对象，该对象通过指定 的Connection或Ext.Ajax.request来向服务端发送请求，从而可以读取到服务器端的数据。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 经验表明，服务器端产生JSon数据是一种非常不错的选择，也就是说假如服务器的url&#8220;student.ejf?cmd=list&#8221;产生下面的JSON数据输出：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">{results:[{id:1,<br />
<br />
name:'小王',<br />
<br />
email:'xiaowang@easyjf.com',<br />
<br />
sex:'男',<br />
<br />
bornDate:'1991-4-4'},<br />
<br />
{id:1,<br />
<br />
name:'小李',<br />
<br />
email:'xiaoli@easyjf.com',<br />
<br />
sex:'男',<br />
<br />
bornDate:'1992-5-6'},<br />
<br />
{id:1,<br />
<br />
name:'小兰',<br />
<br />
email:'xiaoxiao@easyjf.com',<br />
<br />
sex:'女',<br />
<br />
bornDate:'1993-3-7'} <br />
<br />
]<br />
<br />
}</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 则前面显示学习信息编辑表格的store可以创建成下面的形式：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">var store=new Ext.data.Store({<br />
<br />
url:"student.ejf?cmd=list", <br />
<br />
reader:new Ext.data.JsonReader({<br />
<br />
root:"result"},<br />
<br />
["id","name","organization","homepage"])<br />
<br />
}); <br />
<br />
或者：<br />
<br />
var store=new Ext.data.JsonStore({<br />
<br />
url:"student.ejf?cmd=list", <br />
<br />
root:"result",<br />
<br />
fields:["id","name","organization","homepage"]});</pre>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 其中root表示包含记录集数据的属性。<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 如果在运行程序中需要给服务器端发送数据的时候，此时可以直接使用ExtJS中提供的Ext.Ajax对象的request方法。比如下面的代码实现放服 务器的student.ejf?cmd=save这个url发起一个请求，并在params中指定发送的Student对象：</p>
<pre style="font-size: 12px; background-color: rgb(238,238,238)">function sFn()<br />
<br />
{<br />
<br />
alert('保存成功');<br />
<br />
}<br />
<br />
function fFn()<br />
<br />
{<br />
<br />
alert('保存失败');<br />
<br />
}<br />
<br />
Ext.Ajax.request({<br />
<br />
&nbsp;&nbsp;   url: 'student.ejf?cmd=save&#8217;<br />
<br />
&nbsp;&nbsp;   success: sFn<br />
<br />
&nbsp;&nbsp;   failure: fFn,<br />
<br />
&nbsp;&nbsp;   params: { name: '小李',email: ' xiaoli@easyjf.com',bornDate: ' 1992-5-6',sex: '男'}<br />
<br />
});</pre>
<img src ="http://www.blogjava.net/wanghun723/aggbug/270900.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/wanghun723/" target="_blank">L.J.</a> 2009-05-15 17:17 <a href="http://www.blogjava.net/wanghun723/articles/270900.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>从store中获取数据</title><link>http://www.blogjava.net/wanghun723/articles/270899.html</link><dc:creator>L.J.</dc:creator><author>L.J.</author><pubDate>Fri, 15 May 2009 09:14:00 GMT</pubDate><guid>http://www.blogjava.net/wanghun723/articles/270899.html</guid><wfw:comment>http://www.blogjava.net/wanghun723/comments/270899.html</wfw:comment><comments>http://www.blogjava.net/wanghun723/articles/270899.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/wanghun723/comments/commentRss/270899.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/wanghun723/services/trackbacks/270899.html</trackback:ping><description><![CDATA[<p>以下是从store中精确定位数据的几种方法：<br />
</p>
<div style="border-right: #cccccc 1px solid; padding-right: 5px; border-top: #cccccc 1px solid; padding-left: 4px; font-size: 13px; padding-bottom: 4px; border-left: #cccccc 1px solid; width: 98%; word-break: break-all; padding-top: 4px; border-bottom: #cccccc 1px solid; background-color: #eeeeee"><img id="Codehighlighter1_11_626_Open_Image" onclick="this.style.display='none'; Codehighlighter1_11_626_Open_Text.style.display='none'; Codehighlighter1_11_626_Closed_Image.style.display='inline'; Codehighlighter1_11_626_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_11_626_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_11_626_Closed_Text.style.display='none'; Codehighlighter1_11_626_Open_Image.style.display='inline'; Codehighlighter1_11_626_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top"  alt="" /><span style="color: #0000ff">var</span><span style="color: #000000">&nbsp;data&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;</span><span id="Codehighlighter1_11_626_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_11_626_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;'rowCountFather':&nbsp;</span><span style="color: #000000">3</span><span style="color: #000000">,<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;rowCountSon:&nbsp;</span><span style="color: #000000">3</span><span style="color: #000000">,<br />
<img id="Codehighlighter1_77_168_Open_Image" onclick="this.style.display='none'; Codehighlighter1_77_168_Open_Text.style.display='none'; Codehighlighter1_77_168_Closed_Image.style.display='inline'; Codehighlighter1_77_168_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_77_168_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_77_168_Closed_Text.style.display='none'; Codehighlighter1_77_168_Open_Image.style.display='inline'; Codehighlighter1_77_168_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;'fatherData':&nbsp;[</span><span id="Codehighlighter1_77_168_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_77_168_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherId:&nbsp;'father',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherName:&nbsp;'</span><span style="color: #000000">1</span><span style="color: #000000">',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherIconCls:&nbsp;'manage'<br />
<img id="Codehighlighter1_171_262_Open_Image" onclick="this.style.display='none'; Codehighlighter1_171_262_Open_Text.style.display='none'; Codehighlighter1_171_262_Closed_Image.style.display='inline'; Codehighlighter1_171_262_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_171_262_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_171_262_Closed_Text.style.display='none'; Codehighlighter1_171_262_Open_Image.style.display='inline'; Codehighlighter1_171_262_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">,&nbsp;</span><span id="Codehighlighter1_171_262_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_171_262_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherId:&nbsp;'father',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherName:&nbsp;'</span><span style="color: #000000">2</span><span style="color: #000000">',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherIconCls:&nbsp;'manage'<br />
<img id="Codehighlighter1_265_356_Open_Image" onclick="this.style.display='none'; Codehighlighter1_265_356_Open_Text.style.display='none'; Codehighlighter1_265_356_Closed_Image.style.display='inline'; Codehighlighter1_265_356_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_265_356_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_265_356_Closed_Text.style.display='none'; Codehighlighter1_265_356_Open_Image.style.display='inline'; Codehighlighter1_265_356_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">,&nbsp;</span><span id="Codehighlighter1_265_356_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_265_356_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherId:&nbsp;'father',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherName:&nbsp;'</span><span style="color: #000000">3</span><span style="color: #000000">',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fatherIconCls:&nbsp;'manage'<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">],<br />
<img id="Codehighlighter1_374_455_Open_Image" onclick="this.style.display='none'; Codehighlighter1_374_455_Open_Text.style.display='none'; Codehighlighter1_374_455_Closed_Image.style.display='inline'; Codehighlighter1_374_455_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_374_455_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_374_455_Closed_Text.style.display='none'; Codehighlighter1_374_455_Open_Image.style.display='inline'; Codehighlighter1_374_455_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;sonData:&nbsp;[</span><span id="Codehighlighter1_374_455_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_374_455_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonId:&nbsp;'son',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonName:&nbsp;'ho1',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonIconCls:&nbsp;'manage'<br />
<img id="Codehighlighter1_458_539_Open_Image" onclick="this.style.display='none'; Codehighlighter1_458_539_Open_Text.style.display='none'; Codehighlighter1_458_539_Closed_Image.style.display='inline'; Codehighlighter1_458_539_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_458_539_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_458_539_Closed_Text.style.display='none'; Codehighlighter1_458_539_Open_Image.style.display='inline'; Codehighlighter1_458_539_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">,&nbsp;</span><span id="Codehighlighter1_458_539_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_458_539_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonId:&nbsp;'son',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonName:&nbsp;'ho2',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonIconCls:&nbsp;'manage'<br />
<img id="Codehighlighter1_542_623_Open_Image" onclick="this.style.display='none'; Codehighlighter1_542_623_Open_Text.style.display='none'; Codehighlighter1_542_623_Closed_Image.style.display='inline'; Codehighlighter1_542_623_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_542_623_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_542_623_Closed_Text.style.display='none'; Codehighlighter1_542_623_Open_Image.style.display='inline'; Codehighlighter1_542_623_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">,&nbsp;</span><span id="Codehighlighter1_542_623_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_542_623_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonId:&nbsp;'son',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonName:&nbsp;'ho3',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sonIconCls:&nbsp;'manage'<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;}</span></span><span style="color: #000000">]<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top"  alt="" />}</span></span><span style="color: #000000">;<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" /><br />
<img id="Codehighlighter1_665_783_Open_Image" onclick="this.style.display='none'; Codehighlighter1_665_783_Open_Text.style.display='none'; Codehighlighter1_665_783_Closed_Image.style.display='inline'; Codehighlighter1_665_783_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top"  alt="" /><img id="Codehighlighter1_665_783_Closed_Image" style="display: none" onclick="this.style.display='none'; Codehighlighter1_665_783_Closed_Text.style.display='none'; Codehighlighter1_665_783_Open_Image.style.display='inline'; Codehighlighter1_665_783_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top"  alt="" /></span><span style="color: #0000ff">var</span><span style="color: #000000">&nbsp;store&nbsp;</span><span style="color: #000000">=</span><span style="color: #000000">&nbsp;</span><span style="color: #0000ff">new</span><span style="color: #000000">&nbsp;Ext.data.JsonStore(</span><span id="Codehighlighter1_665_783_Closed_Text" style="border-right: #808080 1px solid; border-top: #808080 1px solid; display: none; border-left: #808080 1px solid; border-bottom: #808080 1px solid; background-color: #ffffff"><img src="http://www.blogjava.net/Images/dot.gif"  alt="" /></span><span id="Codehighlighter1_665_783_Open_Text"><span style="color: #000000">{<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;data:&nbsp;data,<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;autoLoad:&nbsp;</span><span style="color: #0000ff">true</span><span style="color: #000000">,<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;root:&nbsp;'fatherData',<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top"  alt="" />&nbsp;&nbsp;&nbsp;&nbsp;fields:&nbsp;['fatherId',&nbsp;'fatherName',&nbsp;'fatherIconCls']<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top"  alt="" />}</span></span><span style="color: #000000">)<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" /><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" /><br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" />alert(</span><span style="color: #000000">"</span><span style="color: #000000">data</span><span style="color: #000000">"</span><span style="color: #000000">&nbsp;</span><span style="color: #000000">+</span><span style="color: #000000">&nbsp;data.rowCountFather);<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" />alert(store.reader.jsonData['rowCountFather']);<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" />alert(store.getAt(</span><span style="color: #000000">0</span><span style="color: #000000">).get('fatherName'));<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" />alert(store.reader.jsonData.fatherData[</span><span style="color: #000000">0</span><span style="color: #000000">].fatherName);<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" />alert(store.reader.jsonData.sonData[</span><span style="color: #000000">0</span><span style="color: #000000">].sonName);<br />
<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top"  alt="" /></span></div>
<img src ="http://www.blogjava.net/wanghun723/aggbug/270899.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/wanghun723/" target="_blank">L.J.</a> 2009-05-15 17:14 <a href="http://www.blogjava.net/wanghun723/articles/270899.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>