asp+js做的动态添加数据行,为何数据表会自动多添加一空白行

狐猫 2017-06-01 10:18:34
前台代码:
<table width="99%" border="0" id="tabUserInfo" cellpadding="0" cellspacing="1">
<tr class="bb02" align="center">
<td>件数:</td>
<td>单件重量</td>
<td>总重量</td>
<td>操作</td>
</tr>
<tr style="display:none" id="trUserInfo" align="center" bgcolor="#FFFFFF">
<td id="tdUserInfo" bgcolor="#FFFFFF"><input id="dhsl" name="dhsl" value="<%=dhsl%>" type="text"></td>
<td id="tdUserInfo" bgcolor="#FFFFFF"><input id="dhck" name="dhck" value="<%=dhck%>" type="text"></td>
<td id="tdUserInfo" bgcolor="#FFFFFF"><input id="xlh" name="xlh" value="<%=xlh%>" type="text"></td>
<td id="tdUserInfo" bgcolor="#FFFFFF"><input type="button" value="删除" onclick="deleteRow(document.all.tabUserInfo,1,this)"></td>
</tr>
<tr><td id="tdUserInfo"><input type="button" value="新增" onclick="addRow(document.all.tabUserInfo,null,1,1)" class="submit1"></td></tr>
</table>
后台代码:
'------------------------------添加和修改信息部分--------------------------------------
moduleid=0
if request("moduleid")<>"" then
moduleid=cint(request("moduleid"))
end if

conn.beginTrans ' Start a transaction
sql = "insert into rc_qt(sbmc,txm) values('"& request("sbmc") &"','"& request("txm") &"')"
conn.execute(sql)

if request("dhsl").count>0 then
dim maxid
maxid = 1
sql = "select max(qtid) as maxid from rc_qt"
set rs = conn.execute(sql)
maxid = rs("maxid")
rs.close
set rs = nothing

for i =1 to request("dhsl").count
sql = "insert into rc_qtt(qtid,dhsl,dhck,xlh) values("& maxid &",'"& request("dhsl")(i) &"','"& request("dhck")(i) &"','"& request("xlh")(i) &"')"
conn.execute(sql)
next
end if
以上代码就是点击保存后sql数据表会自动多增加了一行,但我明明只增加两行,现在变成三行,求高手们指教
...全文
427 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
保存的时候验证附表table中的值,要是为空则跳过,不为空就保存。
狐猫 2017-06-05
  • 打赏
  • 举报
回复
原来真的是隐藏了一行呀 <tr style="display:none" id="trUserInfo" align="center" bgcolor="#FFFFFF"> 新增按钮的代码: <td id="tdUserInfo"><input type="button" value="新增" onClick="addRow(document.all.tabUserInfo,null,1,1)" class="submit1"></td>
狐猫 2017-06-05
  • 打赏
  • 举报
回复
请问怎么写代码呀------ “保存的时候验证附表table中的值,要是为空则跳过,不为空就保存。” 我的保存代码是: <% if request("tj")="保 存" then set rs=server.CreateObject("adodb.RecordSet") strsql="select * from rc_qtt" rs.open strsql,conn,2,3 for i =1 to request("dhsl").count rs.addnew() rs("dhsl")=request("dhsl")(i) rs("dhck")=request("dhck")(i) rs("xlh")=request("xlh")(i) rs("name")=request("name")(i) rs("sex")=request("sex")(i) rs.update next end if %>
狐猫 2017-06-02
  • 打赏
  • 举报
回复
在前台点击新增时后台数据表是没有新增行的,只有前台点击保存后才会在数据表新增,因为是两个数据表,一个主表,另一个副表,有id关联的,主表是前台数据字段,副表是前台新增那里的数据字段,一保存两表同时新增并关联
  • 打赏
  • 举报
回复
你可以加个判断试试。 加一个保存按钮 保存时间 进行遍历table 如果table 某一字段是空的不允许保存 你点新增一行应该是前台新增了一行tr,并没有在数据表插入一条记录把?
狐猫 2017-06-01
  • 打赏
  • 举报
回复
我是参照http://www.jb51.net/article/72775.htm来做的


数据表就是多增加了一行

狐猫 2017-06-01
  • 打赏
  • 举报
回复
以下是新增行的js代码: function addRow(tabObj,colNum,sorPos,targPos){ var nTR = tabObj.insertRow(tabObj.rows.length-targPos); // Insert a new row into appointed table on the //appointed position. var TRs = tabObj.getElementsByTagName('TR'); // Get TRs collection from the appointed table var sorTR = TRs[sorPos]; // Positioned the sorTR var TDs = sorTR.getElementsByTagName('TD'); // Get TDs collection from the appointed row if(colNum==0 || colNum==undefined || colNum==isNaN){ colNum=tabObj.rows[0].cells.length; } var ntd = new Array(); // Create a new TDs array for(var i=0; i< colNum; i++){ // Traverl the TDs in row ntd[i] = nTR.insertCell(); // Create new cell ntd[i].id = TDs[0].id; // copy the TD's id to new cell. | Attention! The TDs's //suffix must be appointed ntd[i].innerHTML = TDs[i].innerHTML; // copy the value in ntd[i]'s innerHTML from corresponding TDs } } /**//* This function is use to remove appointed row in appointed table * tabObj: the appointed table * targPos: target row position * btnObj: currently clicked delete image button * */ function deleteRow(tabObj,targPos,btnObj){ //Remove table row for(var i =0; i<tabObj.rows.length;i++){ if(tabObj.getElementsByTagName('img')[i]==btnObj){ tabObj.deleteRow(i+targPos); } } }
狐猫 2017-06-01
  • 打赏
  • 举报
回复
前台页面是有代码先隐藏一行的,但这代码是没错的呀
ExtAspNet v2.2.1 ExtAspNet是一组专业的Asp.net控件库,拥有原生的AJAX支持和丰富的UI效果, 目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。 支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+ 注:ExtAspNet基于一些开源的程序ExtJS, HtmlAgilityPack, Nii.JSON, YUICompressor。 示例: http://extasp.net/ 开源: http://extaspnet.codeplex.com/ 博客: http://sanshi.cnblogs.com/ 邮箱: sanshi.ustc@gmail.com 发布历史: +2010-03-28 v2.2.1 +为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.aspx示例在单独浏览器打开后,不能弹出对话框的BUG。 -隐藏示例首页最外层RegionPanel的边框ShowBorder="false"。 +集成Extjs最新版本v3.1.1。 -增加一个新的Theme - Access。 -修正了Firefox下Zoom In/Out时页面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得Asp.net的控件ImageButton具有和Asp.net的Button控件类似的为(Ajax提交)(feedback:261629698)。 +TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件动态增加删除Tab。 -增加示例tabstrip/tabstrip_addtab.aspx。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window控件更新。 -关闭按钮默认直接关闭,不弹出确认对话框。 -GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居中,而不是黄金分割位置。 +Button, Window等控件弹出位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后一个参数target变为枚举类型。 -Alert.GetShowReference中的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Extjs最新版本v3.1.0。 -修正灰色皮肤的CSS问题。 -修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏ExtAspNet控件,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。 -增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时出现空白页面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid中的一个JS问题(feedback:lqm4108)。 -修正Alert消息中引号未编码导致的JS错误(feedback:sun1299shine)。 +集成extjs3.0.3。 -修正弹出对话框的宽度计算错误(保持最小的状态)。 -增加新的皮肤Gray。 -为示例工程添加改变语言和皮肤的下拉列表。 -为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。 +2009-12-01 v2.1.7 -增加示例(iframe/parent_postback_run3.aspx),如何通过简单的Javascript代码回发父页面(feedback:eroach)。 -修正一些书写错误(feedback:bmck)。 -从Region控件中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加中国的省市县三级联动示例(data/shengshixian.aspx)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程中重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。 +2009-11-26 v2.1.6 +修正动态创建Grid列的BUG(feedback:gxpan)。 -增加示例(data/grid_dynamic_columns.aspx)。 -修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。 -增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。 -为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。 -重新设计模拟树的下拉列表的实现,避免选中某项后的闪烁。 +2009-11-21 v2.1.5 +Tree优化。 -修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。 -GetNodeById更名为FindNode,保持和FindControl一致命名。 -删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。 -删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。 -增加示例(data/tree_select_run.aspx),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。 +TreeNode的属性NodeId被重命名为NodeID,这是ExtAspNet中的一个命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。 -增加示例(other/custom_postback.aspx)(feedback:thebox)。 -如何自定义Javascript脚本和C#处理函数来响应键盘事件。 -为Tree增加AutoLeafIdentification属性。 -增加示例(tree_auto_leaf_identification.aspx)(feedback:wdrabbit)。 +2009-11-17 v2.1.4 -修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。 -部分ExtAspNet控件的设计时支持(在后续版本中逐步完善)。 -v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运时是否保持状态没有关系。 -修正CheckBox控件的CheckedChanged事件被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。 +为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.aspx +2009-10-19 v2.1.3 +增加支持在AJAX时改变的控件属性列表(/ajax.aspx)。 -ExtAspNet支持原生的AJAX,也就是说控件的属性改变在AJAX过程中反映到页面中,但并不是所有的控件属性都支持AJAX改变。 -加载s.gif图片在本机进,不请求extjs.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保Asp.net的按钮控件仍然具有AJAX的特性。 -更新/basic/login.aspx示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.aspx(feedback:chenguizhu2006)。 -为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。 -Grid中TemplateField生成到页面中控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。 -修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。 -增加pt_BR语言,由Ujvari提供。 +为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。 -如果Panel具有IconUrl属性,则IconUrl优先于Icon。 -所有Icon的列表在icon.aspx。 -为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。 +2009-09-15 v2.1.1 -修正不能动态修改AccordionPane属性Items的BUG。 +为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。 -如果需要在父页面弹出确认对话框,需要设置ConfirmTarget="_parent"(类似Window控件的Target="_parent")。 +为ExtAspNet.Alert.Show增加点击确定的JavaScript回调函数。 -一个典型应用,在Window控件中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。 -ExtAspNet.Alert.Show("参数错误!", String.Empty, ExtAspNet.ActiveWindow.GetCloseReference()); +TreeNode的前面的多选框可以自动回发了。 -为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://extasp.net/data/tree_run.aspx -Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选中任何一项时在父页面弹出对话框的JS代码。 -修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。 -添加定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree控件的AJAX实现。 +为页面的Form添加autocomplete="off"属性。 -参考http://www.cnblogs.com/sanshi/archive/2009/09/04/1560146.html#1635830 +添加对extjs3.0中所有语言的支持。 -ExtAspNet扩展的多语言包在js\languages\extaspnet目录下,目前只有en,zh_CN,zh_TW三种实现 -你可以向其中添加自己的语言版本,并执js\languages下的pack.bat打包,最后编译工程。 +2009-09-01 v2.0.9 -为ExtAspNet.Alert添加两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。 +在aspx页面中必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。 -这将影响所有的aspx页面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在Asp.net AJAX中使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将影响所有的aspx页面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -ExtAspNet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。 -将所有的示例转化为英语版本。 -修正Tree控件的一个BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。 -这个BUG导致Asp.net compatibility中的示例无法完成,现在已经修正。 +去除PageManager中方法AddAjaxAspnetControls,增加属性AjaxAspnetControls。 -这个属性和Button得ValidateForms属性类似,可以查看Asp.net compatibility中的示例。 +2009-08-25 v2.0.7 -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。 -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。 -增加示例-如何将Grid控件导出为Excel(data\grid_excel_run.aspx)(feedback:503684912)。 -如果TreeNode的属性Enabled="false",则此项变灰并且不被选中(feedback:your568)。 -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~/开头)的BUG。 -增加Accordion和Tree配合使用的示例(other\accordion_tree_run.aspx)。 -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。 +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。 -简单方便,示例可以参考 default.aspx 或者 other\accordion_tree_run.aspx。 +2009-08-14 v2.0.6 -动态生成菜单实例(other\menu_dynamic_run.aspx和other\menu_dynamic2_run.aspx)(feedback:shguo)。 -优化AJAX的内部实现,每个页面保存的ViewState现在减少1/3左右(重要更新)。 -优化Tree节点的NodeId自动生成,减少ViewState占用。 +2009-08-09 v2.0 beta5 +ExtAspNet和Asp.net的提交按钮兼容问题(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果Asp.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们了优化,现在要使一个Asp.net的按钮能够AJAX提交,你不需要任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjaxAspnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的Asp.net控件了。 -在Page_Load中设置了哪些需要在AJAX中更新的Asp.net控件在回发时保持状态,可以通过RemoveAjaxAspnetControls来去除不需要更新的控件。 -示例在aspnet\fckeditor_run.aspx和aspnet\aspnet_run.aspx。 -FCKEditor和上传控件兼容。示例在aspnet\fileupload_run.aspx。 -修正ToolbarText的文本在AJAX下更新的BUG。 -Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。 -更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。 +2009-08-02 v2.0 beta4 +和Asp.Net的Forms Authentication兼容[feedback:mgzhenhong]。 -采用和Asp.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。 -现在支持Response.Redirect,你可以选择Response.Redirect或者ExtAspNet.PageContext.Redirect重定向页面,两者效果一样。 -支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。 -Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。 -修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。 -修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。 -增加Menu和Accordion的示例。 -修正Window控件的IconUrl有时不显示(Target="_parent")的BUG[feedback:xmq&mgzhenhong]。 +2009-07-22 v2.0 beta3 -兼容FCKEditor。 -在IE8.0,Firefox3.5下测试通过。以后ExtAspNet将不对IE6.0提供支持。 +2009-07-13 v2.0 beta2 -集成extjs最新版本v3.0。 +兼容IE6.0-7.0-8.0。 -这应该是Extjs3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();导致button的click事件无法响应(IE8下无此问题)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新extjs库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。 -ExtAspNet自身的CSS紧挨着页面标签引入,这样在<head>中自定义的样式可以覆盖Ext<em>Asp</em>Net缺省样式。 +Alert对话框<em>会</em>遮挡所有的Window窗口。 -使用一个变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。 -重新绑定模拟树的下拉列表后,选中项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时<em>JS</em>错误[feedback:xlli]。[fixed] -Window中的EnableIFrame==false,则点击关闭按钮时报<em>JS</em>错误。[fixed] -页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例<em>asp</em>net/fileupload.<em>asp</em>x)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(Ext-Window)含有<em>ASP</em>.NET控件FileUpload,则此弹出窗口在关闭时出现<em>JS</em>错误(http://ext<em>js</em>.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果页面中存在<em>ASP</em>.NET控件(TextBox),则第二次提交表单就<em>会</em>报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed] -页面上放置Ext<em>Asp</em>Net-Button和<em>ASP</em>.NET-Button,则点击Ext<em>Asp</em>Net-Button时激发的是<em>ASP</em>.NET-Button的事件,这个BUG和Ext<em>js</em>2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed] -Ext<em>Asp</em>Net内部包含HtmlAgilityPack和Nii.<em>JS</em>ON两个开源的第三方类库。[added] +如果以前你听过不要在Ext<em>Asp</em>Net工程中使用<em>ASP</em>.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在Ext<em>Asp</em>Net控件和<em>ASP</em>.NET标准控件和平共处了。[fixed] -如果一个<em>ASP</em>.NET按钮控件要使用Ext<em>Asp</em>Net的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次Ext<em>Asp</em>Net的原生AJAX回发时更新<em>ASP</em>.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:<em>asp</em>net/<em>asp</em>net.<em>asp</em>x)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed] -<em>自动</em>测试功能<em>会</em>在以后版本中逐步完善。这个版本完成测试框架,采用Ext<em>js</em>中<em>JS</em>函数进<em>行</em>大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。 -PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。 ---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference/GetConfirmFormModifiedCloseRefreshReference/GetConfirmFormModifiedClosePostBackReference三个方法代替。 -不<em>会</em>修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面<em>添加</em>box_parent_client_id查询字符串 -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的<em>JS</em>方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的<em>ASP</em>X页面中查找RegisterPageStateChangedScript属性,并删除,否则<em>会</em>运<em>行</em>错误! -A页面有Ext-Window控件弹出B页面,B页面有Ext-Window控件弹出C页面,B页面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C页面)<em>会</em>覆盖整个A页面,这是正确的。 ---当时如果用户直接访问B页面,就<em>会</em>报<em>JS</em>错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不<em>会</em>出错了。 -Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。 ---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window控件的关闭按钮<em>添加</em>关闭后刷新父页面或者关闭后回发父页面的<em>行</em>为。 -如果弹出窗口(Window控件)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮<em>会</em>报<em>JS</em>错误,因为此时页面尚未加载完毕。 ---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window控件的IFrameName属性是<em>自动</em>生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel中内容不能<em>自动</em>扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的<em>数据</em>[feedback:huihuang]。[fixed] -DropDownList在页面第一次加载时没有不可选择项,则回发时也不<em>会</em>有不可选择项的BUG。[fixed] -升级底层Ext<em>JS</em>类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed] -页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added] +增加部分<em>自动</em>测试支持(使用WatiN和NUnit),下个版本将<em>会</em>提供完整的<em>自动</em>测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageContext优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image控件增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包中增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +TabStrip的Tab控件的EnablePostBack属性<em>会</em>在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都<em>会</em>回发)。[fixed] -有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后<em>会</em>回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用控件的站点必须建立虚拟目录,否则<em>会</em>报<em>JS</em>错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-<em>asp</em>net-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemText/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new Ext<em>Asp</em>Net.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。 -和<em>Asp</em>.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string text, string value),这样方便后台<em>添加</em>列表项。 -处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight<em>会</em><em>自动</em>设置为false(避免开发人员发生此类错误)。[fixed] -注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有控件属性增加在VS中的智能提示。[fixed] -需要将Ext<em>Asp</em>Net.XML和Ext<em>Asp</em>Net.dll放在一起,这样引用dll时xml<em>会</em>被拷贝到bin目录下,提供VS的智能提示。 +控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:一个属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为控件。[fixed] -可以方便的在子页面(iframe)中通过<em>js</em>切换父页面中选中的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.<em>asp</em>x,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的<em>动态</em><em>添加</em>控件,并且可以给控件<em>添加</em>服务器端事件(示例在form/form_dynamic_run.<em>asp</em>x)。[fixed] +2008-10-15 v1.2 beta5 -验证表单字段的ValueToCompare属性,为字符串时<em>会</em>出错的BUG。[fixed] +优化下拉列表。[fixed] -验证下拉列表时,应该取ListItem的Value属性进<em>行</em>验证,而不是Text属性。 -DropDownList的Items增加Insert方法(可方便的下拉列表选项<em>添加</em>“全部”)。 -DropDownList不支持EmptyText属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(<em>ASP</em>X)中设置哪些项不可选择,以及创建模拟下拉树。 -DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则<em>自动</em>将EnableSimulateTree设置为true。 +2008-09-27 v1.2 beta4 +EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只<em>会</em>改变Accordion的标题大小,而不<em>会</em>对AccordionPanel起作用(示例见other/accordion_run.<em>asp</em>x)。[fixed] -Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。 -影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。 -AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed] +AccordionPanel增加Links属性,可以绑定列表<em>数据</em>到AccordionPanel,呈现的是链接的列表(示例在other/accordion_links_run.<em>asp</em>x)。[fixed] -原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上<Items>标签。 -适当增大AccordionPanel中链接的高度20px->22px,同时对链接的样式也<em>做</em>了微调。 -通过BodyPadding控制链接列表的边距。 -这样能大大减少<em>ASP</em>X中HTML代码和Javascript代码的书写,可以在后台<em>动态</em><em>添加</em>链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在<em>ASP</em>X页切换到“设计时”,方便属性的更改和事件处理函数的<em>添加</em>)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -TabStrip/Toolbar -TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form中<em>动态</em><em>添加</em>控件的BUG,现在form/form_dynamic_run.<em>asp</em>x示例已经能正确运<em>行</em>。[fixed] +大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed] -影响的控件包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留TabStrip的Tabs(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进<em>行</em>多次删除<em>添加</em>操作后,SelectedRowIndexArray选中项中<em>会</em>存在当前不存在的<em>行</em>序号,导致服务器端遍历选中项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例中表单控件都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/Label/Image/LinkButton/TextBox -TriggerBox/TwinTriggerBox/Window/TextArea/HtmlEditor/DatePicker/NumberBox -CheckBox/RadioButton/RadioButtonList/DropDownList -Grid +2008-09-19 v1.2 beta1 -Image/LinkButton/HyperLink增加一些Ajax可更新属性。[fixed] +隐藏的方式由HideMode属性控制Visibility/Offsets/Display。[fixed] -修正Form/SimpleForm中隐藏一个表单字段(Hidden=false)<em>会</em>占据页面空间的BUG。 -ToolbarText/ToolbarFill/ToolbarSeparator在<em>ASP</em>X中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在控件中。[fixed] -网报:CssClass="toolbar-pagemenu" CssStyle="border:0px;",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(../images/pagemenu_toolbar_background.gif) repeat-x left top;}。 -Region去除默认的Layout=Fit,如果希望Region使用Fit/Anchor/Column/Row等布局的话,需要手工指定。[fixed] -ToolbarSeparator/ToolbarFill在Ajax更新Hidden属性的BUG。[fixed] +布局整理。[fixed] -新增Column/Absolute/Row三种布局,加上以前的Container/Fit/Anchor/Accordion/Border/Form六种布局,总共有9中布局可供使用。 -其中一些控件默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/TabStrip(Card),所有布局控件默认的布局是Container。 -经常用到的布局控件:SimpleForm/Form/Accordion/TabStrip/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的Ext<em>Asp</em>Net控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不<em>会</em>渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。 -US的Ext<em>Asp</em>Net改造强烈依赖于此属性,这个版本发布后可以继续。 -网报中唯一没有用到Ext<em>Asp</em>NetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageContext.Redirect支持普通页面转向和Ext<em>Asp</em>NetAjax下页面转向。[fixed] +模拟树的下拉列表的BUG(<em>会</em>使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。 -解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) >= 0){ok}。 -DropDownList在Ajax时应该先更新<em>数据</em>再设置选定项 [feedback:xmzhu]。[fixed] -Button/MenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed] -Tree的Ajax支持(尚需优化)。[fixed] +2008-09-02 v1.1 beta5 -DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed] -模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有<em>数据</em>也需要设置DataTextField/DataValueField/DataSimulateTreeLevelField/DataEnableSelectField等属性的值,否则Ajax回发时<em>会</em>出错)。[fixed] -UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不<em>会</em>用<em>Asp</em>netAjax,这个控件已经完成使命)。[fixed] -不要使用<em>Asp</em>.net的控件HiddenField,而是使用Ext<em>Asp</em>Net的HiddenField,因为<em>Asp</em>.net的控件在Ajax不<em>会</em>被更新,所以<em>会</em>导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList中项如果存在汉字,则<em>会</em>换<em>行</em>的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab中如果有ContentPanel,则在页面上方<em>会</em>有空白(可以通过设置EnableDeferredRender=false解决,但<em>会</em>减慢页面的加载速度),现在已经解决这个问题。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第一个Trigger图标不<em>会</em>先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config中增加配置项FormLabelWidth="80"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm/Form的表单字段标题的宽度。[fixed] +完善Ajax。[fixed] -RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue/SelectedItem)。 -DropDownList增加Ajax可更新属性Enable/SelectedIndex(SelectedValue/SelectedItem)/DataSource。 -Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。 -ToolbarText增加Ajax可更新属性Text。 +2008-08-31 v1.1 beta3 -TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法<em>会</em>出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上<em>会</em>有进一步的提升。 -基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。 -整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不<em>会</em>对UI起作用,同时是安全的,不<em>会</em>有<em>js</em>错误)。 -网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window控件是否弹出的状态在回发时维持。[fixed] -控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃<em>Asp</em>.NetAjax,Ext<em>Asp</em>Net控件内置Ajax支持。[fixed] -这是一个值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和<em>Asp</em>.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要<em>做</em>任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的<em>做</em>法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前Ext<em>Asp</em>NetAjax的限制。 -只对Ext<em>Asp</em>Net控件起作用,对<em>Asp</em>.net控件不起作用。 -对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。 -对改变控件的Visible属性<em>会</em>有错误。 -Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都<em>添加</em>PageLoading控件。[fixed] -Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执<em>行</em>,这样当前<em>行</em>被选中的状态在回发后<em>会</em>得到保持。[fixed] -Grid选中<em>行</em>的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知问题:IE的ActiveX插件IE Developer Toolbar<em>会</em>对IFrame的加载造成0.5m左右的延迟。 -主要是父页面加载一个比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都<em>会</em>有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹出窗口中IFrame的显示速度。[fixed] -在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed] -一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.<em>asp</em>x)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +TabStrip中非当前Tab<em>会</em>延迟渲染。[fixed] -这<em>会</em>明显加快页面的渲染速度,网报中一个典型的费用审批页面可以减少200ms的渲染时间。 -由于非当前Tab不<em>会</em>在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render事件中。 -不能比较两个DataPicker大小的BUG。[fixed] -TabStrip延迟加载引起的BUG(非当前Tab中的ContentPanel<em>会</em>占据页面空间,已修正)。[fixed] -全新的Ext<em>Asp</em>Net.Examples(基础知识/表单控件/<em>数据</em>绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe/default.<em>asp</em>x和iframe/page3.<em>asp</em>x)。[fixed] -测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed] +ext<em>js</em>的BUG,当页面中含有iframe时,Ext.onReady<em>会</em>被调用两次(IE6/IE7)(http://www.ext<em>js</em>.net/forum/showthread.php?t=43246)(示例在test.<em>asp</em>x)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发页面再弹出IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种<em>做</em>法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference("./simpleform.<em>asp</em>x"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下<em>会</em>有<em>JS</em>错误。[fixed] -增加BorderLayout控件,示例在iframe/borderlayout.<em>asp</em>x。[fixed] +Radiobuttonlist显示有重影(示例在radio.<em>asp</em>x)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -<em>动态</em>向Form中<em>添加</em>FormRow,并<em>动态</em>的向FormRow中<em>添加</em>表单字段,以及如何取得表单字段的值。(示例在form_dynamic.<em>asp</em>x)[fixed] +IFrame弹出窗口关闭后回发父页面,则<em>会</em>多加载IFrame一次,再次打开窗口<em>会</em>重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是一个重要的BUG,<em>会</em>严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl<em>会</em>在回发时保持状态,从而回发父页面后Window中的IFrame被<em>添加</em>到页面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不<em>会</em>影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.<em>asp</em>x) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下<em>会</em>有<em>JS</em>错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正一个的内存泄漏。[fixed] -IE7下测试,打开iframe/default.<em>asp</em>x页面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.<em>asp</em>x页面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.<em>asp</em>x页面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE<em>会</em><em>自动</em>进<em>行</em>垃圾回收。 +2008-08-12 v0.4 beta3 -底层的javascript框架Ext<em>js</em>升级为v2.2,Grid的渲染速度有很大提升。[fixed] -Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则<em>行</em>不可见,可以通过AutoHeight="true"解决)。[fixed] +页面正在加载的提示尽早的显示出来。[fixed] -首先在执<em>行</em><em>js</em>来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示出来。 -加载<em>js</em>脚本的script标签放置在页面的最后,放置加载<em>js</em>而阻塞PageLoading的显示。 +2008-08-08 v0.4 beta2 -TabStrip延时加载出错。[fixed] -Window的IFrameUrl处理的BUG,比如Pages_Ext<em>Asp</em>Net目录下的页面应该为./FE_ApplyEditor.<em>asp</em>x或~/Pages_Ext<em>Asp</em>Net/FE_ApplyEditor.<em>asp</em>x。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则<em>会</em><em>JS</em>错误。[fixed] -实现网报首页下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在页面显示后进<em>行</em>,不计算在<em>js</em>渲染时间内。[fixed] -优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.<em>asp</em>x默认<em>会</em>加载form.<em>asp</em>x页面(Window控件的BUG)。[fixed] -Window中的保存并关闭按钮和<em>Asp</em>.netAjax冲突。[fixed] -优化关闭Window的<em>js</em>脚本,减少写到页面的<em>js</em>大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.<em>asp</em>x)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的<em>Asp</em>.net控件一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的<em>js</em>对象的名称简单化,这样可以减少生成的<em>js</em>内容,加快页面加载速度(一个典型页面的<em>js</em>由原来的33.0k降低为21.4k)。[fixed] +弹出窗口中,点击按钮回发然后点击关闭按钮,出现<em>js</em>错误 [feedback:xmzhu]。[fixed] -因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为<em>js</em>调用此脚本时报错。 -一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。 -另一种办法就是在PageManager控件中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(<em>会</em>在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.<em>asp</em>x/simpleform.<em>asp</em>x)。 +PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.<em>asp</em>x)。[fixed] -这个手工<em>添加</em>onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去<em>做</em>的麻烦(已经在网报中遇到这种情况)。 -每个页面必须<em>添加</em>一个PageManager控件,否则<em>会</em>出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed] -TextField等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和<em>Asp</em>.net Ajax保持兼容)。[fixed] -最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.<em>asp</em>x/page2.<em>asp</em>x/simpleform.<em>asp</em>x) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要<em>做</em>的仅仅是为Window控件增加一个属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.<em>asp</em>x(A)/page2.<em>asp</em>x(B)/simpleform.<em>asp</em>x(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我<em>会</em>通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid中弹出窗口。(default.<em>asp</em>x/page3.<em>asp</em>x/simpleform.<em>asp</em>x) +示例3,TriggerBox弹出窗口。(default.<em>asp</em>x/triggerbox.<em>asp</em>x/simpleform.<em>asp</em>x) -在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。 -示例4,弹出窗口中的弹出窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下TabStrip在Ajax回发后不<em>会</em>去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对TabStrip/Panel/Window中的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不<em>会</em>有残影出现。[fixed] -如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则<em>会</em>延迟加载(示例在tabstrip_iframe.<em>asp</em>x)。[fixed] -Tree控件,点击一个节点<em>自动</em>回发,则当前点击的那个节点的选中状态不<em>会</em>保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.<em>asp</em>x/simpleform.<em>asp</em>x)。[fixed] -内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执<em>行</em>(在simpleform.<em>asp</em>x,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。 -参照Yslow的评分规则,将<em>JS</em>文件引用由head移动到body中。[fixed] -Firefox下,如果页面太长<em>会</em>出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed] +IFrame内的页面宽度和高度<em>会</em><em>自动</em>设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.<em>asp</em>x/simpleform.<em>asp</em>x/simpleform2.<em>asp</em>x)[fixed] -增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image控件 [feedback:jima]。[fixed] -Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则<em>会</em>引起页面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.<em>asp</em>x)。[fixed] -去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息中的换<em>行</em>符(转换为<br/>),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree控件。[fixed] -如何将<em>数据</em>库中的<em>数据</em>绑定到Tree(示例在tree2_bind_database.<em>asp</em>x)。 -ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.<em>asp</em>x)。 -更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同一个页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltipFormatString两个字段,以显示ToolTip(示例在grid.<em>asp</em>x)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed] -发现原来ie6不能正确解析li的高度,必须手工设置才<em>行</em>(style="height:20px;")。 +IE6/IE7下,模拟树的下拉列表如果文字长度太长,则显示的文字<em>会</em>换<em>行</em>,导致错位。[fixed] -虽然最后未能解决<div style="width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;"><div style="width: 16px; height: 18px; float: left;">##</div>差旅交通费</div>在IE和Firefox下显示的不同效果。 -但是通过用<img src="##" />来代替<div style="background:url(##)" />,从而实现FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“<span style="margin-right: -1000px;">差旅交通费</span>”,在IE下和FF下的都不换<em>行</em>,:-) -LinkButton增加OnClick事件 [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树控件(Tree)(示例在tree2.<em>asp</em>x)。[fixed] -可以在回发时维持树的状态(选中<em>行</em>,折叠/展开,CheckBox)。 -可以通过Inline的方式<em>添加</em>树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到页面,也可以引发PostBack事件,可以<em>添加</em>自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel中放置Ext<em>Asp</em>Net控件,则渲染时<em>会</em>出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel中渲染Ext<em>Asp</em>Net控件,如果容器的display='none',则<em>会</em>出现各种问题(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就<em>会</em>显示滚动条。 +IE6下,在应用<em>Asp</em>.NetAjax后,Form中字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。 -最后发现IE6下应用<em>Asp</em>.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 页面。 +集成的<em>Asp</em>NetAjax有一个很大的BUG,只要你在页面上进<em>行</em>过ajax操作,当改变窗口大小时你<em>会</em>惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject控件。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选中样式微调。[fixed] -预加载Form表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(一个典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载<em>数据</em>不<em>会</em>改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid中静态的CheckBoxField图片。[fixed] -TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.<em>asp</em>x)[fixed] +2008-07-12 v0.3 beta5 -页面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.<em>asp</em>x)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和TextBox比较大小需要指定CompareType。 +如果在编辑页面使用<em>Asp</em>NetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.<em>asp</em>x/ajax_editor.<em>asp</em>x)。[fixed] -这是由于ajax后执<em>行</em>的javascript中不能有return false语句。 +在文本框失去焦点时,执<em>行</em>一些Javascript脚本(示例在textbox_blur.<em>asp</em>x) [feedback:xmzhu]。[fixed] -在页面<em>添加</em>onReady函数(<em>会</em>被系统调用),然后用javascript监视文本框值的改变。 -弹出Window默认显示的错误页面,解决方法在当前目录<em>添加</em>一个空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是"#"。[fixed] +弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时<em>会</em>有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例中alert\alert_1.<em>asp</em>x和alert\alert_2.<em>asp</em>x,总计 6 <em>行</em>代码),现在只需要 3 <em>行</em>代码就OK了。 -点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.<em>asp</em>x)[feedback:jima]。[fixed] +增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.<em>asp</em>x)。[fixed] -增加SplitButton控件。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.<em>asp</em>x。 +TabStrip中放置IFrame<em>会</em>出现渲染错误 (示例在tabstrip_iframe.<em>asp</em>x)[feedback:jima]。[fixed] -特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.<em>asp</em>x) [feedback:xmzhu]。[fixed] -FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.<em>asp</em>x)[feedback:jima]。[fixed] +表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有<em>数据</em>,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField控件。[fixed] -其实用TextBox也能模拟HiddenField的<em>行</em>为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.<em>asp</em>x)。 -模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed] +控制下拉列表某些项不可以选择(示例在dropdownlist2.<em>asp</em>x)。[fixed] -增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。 -LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.<em>asp</em>x和grid.<em>asp</em>x)。[fixed] +2008-07-07 v0.3 beta2 +增加UpdatePanelConnector控件,支持在布局构建的页面使用<em>Asp</em>.net Ajax。[fixed] -使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。 -示例在ajax3.<em>asp</em>x/content_page4.<em>asp</em>x。 -示例content_page3.<em>asp</em>x中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器控件的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工<em>添加</em>AutoHeight="true"属性。 +增加UserControlConnector,可以在其中放置用户控件(示例在page_usercontrol.<em>asp</em>x)。[fixed] -也可以在ContentPanel中放置用户控件,注意两者的区别。 +增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed] +支持<em>Asp</em>.net ajax异步加载。[fixed] -有很大局限性,只能在ContentPanel中使用,示例在ajax1.<em>asp</em>x/content_ajax2.<em>asp</em>x中。 -对于使用布局构建的页面(比如content_page1.<em>asp</em>x)还不能使用<em>Asp</em>.net ajax,因为页面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前页面已经被修改(示例在content_page1.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中<em>做</em>法一致)。 +iframe中的alert/confirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed] -在Firefox下还有问题。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.<em>asp</em>x)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.<em>asp</em>x)。[fixed] -TabStrip的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel中放置用户控件(示例在page_usercontrol.<em>asp</em>x)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox控件(示例在twintriggerbox.<em>asp</em>x)。[fixed] -Grid的<em>数据</em>库分页需要增加属性IsDatabasePaging=true,以便普通分页和<em>数据</em>库分页,否则在<em>添加</em>删除记录时总记录数不<em>会</em>变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.<em>asp</em>x)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的tab)。[fixed] +页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid中的LinkButtonField设置ConfirmText<em>会</em>出错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.<em>asp</em>x示例)。 -Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.<em>asp</em>x)。 -切换分页时清空选中的值 [feedback:jqpeng]。 -增加PreRowDataBound事件,可以在<em>数据</em>绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.<em>asp</em>x)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.<em>asp</em>x)。 +2008-06-25 v0.2 beta9 +Window窗体中的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -在simpleform.<em>asp</em>x中:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其中26是Toolbar的高度,32是窗口的标题栏和下边框的高度。 +关闭Iframe的LoadMask,所以需要Iframe页面<em>添加</em>PageLoading控件,这样效果统一。[fixed] +Grid完善。 -去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在<em>ASP</em>.NET应用中<em>会</em>有很多问题(主要是状态保持的问题)。 +EnableServerSort改名AllowSorting。(示例在grid_sorting.<em>asp</em>x) -使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件处理函数中重新绑定<em>数据</em>。 +增加AllowPaging属性。(示例在grid_paging.<em>asp</em>x) -使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件处理函数中Grid1.PageIndex = e.NewPageIndex;OK。 +<em>数据</em>库分页支持。(示例在grid_database_paging.<em>asp</em>x) -使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件处理函数中Grid1.PageIn</a></div><div data-report-view="{"mod":"popu_645","index":"2","dest":"https://download.csdn.net/download/wode2600/2726130","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAltJREFUWEdjZGBgYGhv/yD45//nEEYGBrX//xj4QWK0AoxMDB//MzDcYmHkXVNZKfCeEWz5v8/1DP8ZuGhlKVZzGRm+sTDxNjI2tz1OZfjHYEpXy2GWMTGcZmxpe9xN62DH5TlQdDA2tzyeNSC+h1o66gCyQyApUdRNSIhNGBSS7979ejtv/utd5EQl2Q7IypT0ExJiFoc44O/LadOfbxp1wPAOAWlpdr5Pn//8/Pzp70+QT3GlAX5+ZnYeHhb2p09/fiImRIhOhBYWvIo21ryWu/Z8PHDp4tdn2BxgoM8l4+IiYH/k6OdjJ058vk91B7g487swMDD8v3Hj+2VJSTYpfn5mEZAlHz/9ffPq5e+Xqqoc2iD+nr0f99DSAQQ9RhMHcHAwsYSGCtvKy7Gr4HPBo0c/b69c/fbwzx///hJ0KQMDA9FpAGaYizO/tpkZjwUTEyMTsgX//v3/d/LUl+N79368RozFMDUkOwCkUUODU8zHW9CFg4OJG8T/8ePf181b3u25efPHK1IsB6nF6gAjY25ZEWFWcNPs169/fw4c+HQD3WBBIRaOsBAhZ5D4qjXv9r5/9+cHuhoHBz4NNjYmFpD4m7e/P547+/UxuhqsDoiPE3WWlWVXgvju/5ee3qfLsfmMiZmBEST+7y/Df2zyJcXSkRwcjDwgucePf95buOj1Xqo6gFBwDw8H/P/P8O/nz//fCPkWmzw7OyMXIyMDOLeQHQXkWIxNz9BygJubgI6kBCu4tUMt8PzF75e7dn24QlQuoJalxJgzCDomA901G/DOKSieBrJ7DgCPdYFAskV/NwAAAABJRU5ErkJggg==" alt data-v-ca2d15ac> <a target="_blank" href="https://download.csdn.net/download/wode2600/2726130" data-report-click="{"mod":"popu_645","index":"2","dest":"https://download.csdn.net/download/wode2600/2726130","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="title" data-v-ca2d15ac>Ext<em>Asp</em>Net_v2.3.2_dll</a></div> <a target="_blank" href="https://download.csdn.net/download/wode2600/2726130" data-report-click="{"mod":"popu_645","index":"2","dest":"https://download.csdn.net/download/wode2600/2726130","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="desc" data-v-ca2d15ac>Ext<em>Asp</em>Net - Ext<em>JS</em> based <em>ASP</em>.NET Controls with Full AJAX Support Ext<em>Asp</em>Net是一组专业的<em>Asp</em>.net控件库,拥有原生的AJAX支持和丰富的UI效果, 目标是创建没有ViewState,没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。 支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+ 注:Ext<em>Asp</em>Net基于一些开源的程序Ext<em>JS</em>, HtmlAgilityPack, Nii.<em>JS</em>ON, YUICompressor。 示例: http://ext<em>asp</em>.net/ 开源: http://ext<em>asp</em>net.codeplex.com/ 博客: http://sanshi.cnblogs.com/ 邮箱: sanshi.ustc@gmail.com 发布历史: +2010-09-29 v2.3.2 -不绑定任何<em>数据</em>到Grid时,确保页面不<em>会</em>出错。 -修正了Grid列属性DataFormatString的一个bug,比如设置{0:yy-MM-dd HH:mm}时没有效果。 -修正下拉列表控件不能绑定DataTable的BUG(feedback:RedOcean)。 -增加土耳其语言资料文件(feedback:abdullaharslan)。 -Grid的BoundField增加NullDisplayText属性,用于处理<em>数据</em>库中的null值,如果没有设置则默认为空字符串。 -修正DatePicker中的一个bug(31/01/2010将<em>会</em>返回NULL)使用DateFormatString来生成SelectedDate属性(feedback:OktaEndy)。 -修正ext<em>js</em>最新版本(v3.2.2)中的一个bug,如果下拉列表中存在两个相同的Text,则SelectedValue返回值永远是第一个Text的值(feedback:ben.zhou)。 -应用补丁#6593, #6621(feedback:vbelyaev)。 +修正IE7下Grid分页速度慢(feedback:youwei, StevenGuan, hazardvn, gavindou, ttjacky)。 -实际上IE7下所以的回发都慢,原因是客户端的Base64编码速度慢,已经使用encodeURIComponent来代替Base64编码。 -俄语翻译(feedback:vbelyaev)。 +2010-06-30 v2.3.1 -Ext<em>Asp</em>Net控件将不在依赖ViewState,减少1/4左右的HTTP<em>数据</em>传输量。 -控件和示例的增强。 +2010-03-28 v2.2.1 +为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 -修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。 -修正basic/hello.<em>asp</em>x示例在单独浏览器打开后,不能弹出对话框的BUG。 -隐藏示例首页最外层RegionPanel的边框ShowBorder="false"。 +集成Ext<em>js</em>最新版本v3.1.1。 -增加一个新的Theme - Access。 -修正了Firefox下Zoom In/Out时页面消失的BUG。 -删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。 +2010-01-31 v2.2.0 -使得<em>Asp</em>.net的控件ImageButton具有和<em>Asp</em>.net的Button控件类似的<em>行</em>为(Ajax提交)(feedback:261629698)。 +TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件<em>动态</em>增加删除Tab。 -增加示例tabstrip/tabstrip_addtab.<em>asp</em>x。 -重构了示例网站的架构,目前只有一层IFrame结构。 -为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。 -为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal="false")(feedback:zqmars)。 -Window控件更新。 -关闭按钮默认直接关闭,不<em>会</em>弹出确认对话框。 -GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。 -增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。 -修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。 -删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon="Close",现在需要这样定义Icon="SystemClose"。 -WindowPosition默认居中,而不是黄金分割位置。 +Button, Window等控件弹出位置属性的变化。 -Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target="_self" -> Target="Self", Target="_parent" -> Target="Parent"。 -MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。 -Confirm.GetShowReference的最后一个参数target变为枚举类型。 -Alert.GetShowReference中的showInParent参数也变为Target枚举类型。 -MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。 +2010-01-06 v2.1.9 -集成Ext<em>js</em>最新版本v3.1.0。 -修正灰色皮肤的CSS问题。 -修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。 -为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。 -修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。 -Button控件将不再<em>自动</em>拥有display:inline属性,如果希望两个按钮在一<em>行</em>显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox和TwinTriggerBox增加EnableEdit属性。 -使用Hidden来显示隐藏Ext<em>Asp</em>Net控件,而不是使用Visible属性(Visible目前设置为只读属性)。 -使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。 -Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。 -增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。 -修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。 -修正HtmlEditor不能编辑的BUG(feedback:TheBox)。 -修正IE下有时<em>会</em>出现空白页面的情况(feedback:olivia919)。 +2009-12-06 v2.1.8 -修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。 -修正了IE下Grid中的一个<em>JS</em>问题(feedback:lqm4108)。 -修正Alert消息中引号未编码导致的<em>JS</em>错误(feedback:sun1299shine)。 +集成ext<em>js</em>3.0.3。 -修正弹出对话框的宽度计算错误(<em>会</em>保持最小的状态)。 -增加新的皮肤Gray。 -为示例工程<em>添加</em>改变语言和皮肤的下拉列表。 -为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。 +2009-12-01 v2.1.7 -增加示例(iframe/parent_postback_run3.<em>asp</em>x),如何通过简单的Javascript代码回发父页面(feedback:eroach)。 -修正一些书写错误(feedback:bmck)。 -从Region控件中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。 -BorderPanel更名为RegionPanel。 -DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。 -增加中国的省市县三级联动示例(data/shengshixian.<em>asp</em>x)(feedback:Blues T)。 -修正了使用IFrameUrl的Tab在切换过程中<em>会</em>重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick<em>会</em>覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。 +2009-11-26 v2.1.6 +修正<em>动态</em>创建Grid列的BUG(feedback:gxpan)。 -增加示例(data/grid_dynamic_columns.<em>asp</em>x)。 -修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。 -增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。 -为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。 -重新设计模拟树的下拉列表的实现,避免选中某项后的闪烁。 +2009-11-21 v2.1.5 +Tree优化。 -修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。 -GetNodeById更名为FindNode,保持和FindControl一致命名。 -删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。 -删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。 -增加示例(data/tree_select_run.<em>asp</em>x),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。 +TreeNode的属性NodeId被重命名为NodeID,这是Ext<em>Asp</em>Net中的一个命名约定。 -同时更名的还有GridColumn的ColumnId->ColumnID,GetColumnId->GetColumnID。 -Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。 -为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。 -为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。 -增加示例(other/custom_postback.<em>asp</em>x)(feedback:thebox)。 -如何自定义Javascript脚本和C#处理函数来响应键盘事件。 -为Tree增加AutoLeafIdentification属性。 -增加示例(tree_auto_leaf_identification.<em>asp</em>x)(feedback:wdrabbit)。 +2009-11-17 v2.1.4 -修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。 -部分Ext<em>Asp</em>Net控件的设计时支持(<em>会</em>在后续版本中逐步完善)。 -v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运<em>行</em>时是否保持状态没有关系。 -修正CheckBox控件的CheckedChanged事件<em>会</em>被触发两次的BUG(Data PostBack->AutoPostBack, Event PostBack->EnablePostBack)。 -为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。 +为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。 -为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。 +为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。 -增加示例:form/form_validate.<em>asp</em>x +2009-10-19 v2.1.3 +增加支持在AJAX时改变的控件属性列表(/ajax.<em>asp</em>x)。 -Ext<em>Asp</em>Net支持原生的AJAX,也就是说控件的属性改变在AJAX过程中<em>会</em>反映到页面中,但并不是所有的控件属性都支持AJAX改变。 -加载s.gif图片在本机进<em>行</em>,不<em>会</em>请求ext<em>js</em>.com远程资源(feedback:efrigate43,abaocoole)。 -在AJAX回发后确保<em>Asp</em>.net的按钮控件仍然具有AJAX的特性。 -更新/basic/login.<em>asp</em>x示例,使用验证图片(feedback:kedee)。 -为Grid增加AutoPostBack属性和RowClick事件,示例在/data/grid_autopostback.<em>asp</em>x(feedback:chenguizhu2006)。 -为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。 -Grid中TemplateField生成到页面中控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。 +2009-09-27 v2.1.2 -为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。 -修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。 -增加pt_BR语言,由Ujvari提供。 +为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。 -如果Panel具有IconUrl属性,则IconUrl优先于Icon。 -所有Icon的列表在icon.<em>asp</em>x。 -为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。 +2009-09-15 v2.1.1 -修正不能<em>动态</em>修改AccordionPane属性Items的BUG。 +为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。 -如果需要在父页面弹出确认对话框,需要设置ConfirmTarget="_parent"(类似Window控件的Target="_parent")。 +为Ext<em>Asp</em>Net.Alert.Show增加点击确定的JavaScript回调函数。 -一个典型应用,在Window控件中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。 -Ext<em>Asp</em>Net.Alert.Show("参数错误!", String.Empty, Ext<em>Asp</em>Net.ActiveWindow.GetCloseReference()); +TreeNode的前面的多选框可以<em>自动</em>回发了。 -为TreeNode增加AutoPostBack属性,增加事件<em>数据</em>类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://ext<em>asp</em>.net/data/tree_run.<em>asp</em>x -Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选中任何一项时在父页面弹出对话框的<em>JS</em>代码。 -修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。 -<em>添加</em>定时器控件Timer,用来定时发起AJAX请求。 +2009-09-06 v2.1.0 -Button的Pressed属性值能够正确的反映客户端的变化。 -优化Tree控件的AJAX实现。 +为页面的Form<em>添加</em>autocomplete="off"属性。 -参考http://www.cnblogs.com/sanshi/archive/2009/09/04/1560146.html#1635830 +<em>添加</em>对ext<em>js</em>3.0中所有语言的支持。 -Ext<em>Asp</em>Net扩展的多语言包在<em>js</em>\languages\ext<em>asp</em>net目录下,目前只有en,zh_CN,zh_TW三种实现 -你可以向其中<em>添加</em>自己的语言版本,并执<em>行</em><em>js</em>\languages下的pack.bat打包,最后编译工程。 +2009-09-01 v2.0.9 -为Ext<em>Asp</em>Net.Alert<em>添加</em>两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。 +在<em>asp</em>x页面中必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。 -这将<em>会</em>影响所有的<em>asp</em>x页面,所以要特别关注。 -重命名AccordionPanel为AccordionPane (这也是在<em>Asp</em>.net AJAX中使用的名称). +所有的面板默认有两个集合属性(Toolbars和Items). -尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的). -这将<em>会</em>影响所有的<em>asp</em>x页面,一定要将工具条(Toolbars)和Items区分开来。 -祝你生日快乐 - 小师妹妹。 +2009-08-29 v2.0.8 -Ext<em>Asp</em>Net支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。 -将所有的示例转化为英语版本。 -修正Tree控件的一个BUG(定义Mappings属性时)。 +PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。 -这个BUG导致<em>Asp</em>.net compatibility中的示例无法完成,现在已经修正。 +去除PageManager中方法AddAjax<em>Asp</em>netControls,增加属性Ajax<em>Asp</em>netControls。 -这个属性和Button得ValidateForms属性类似,可以查看<em>Asp</em>.net compatibility中的示例。 +2009-08-25 v2.0.7 -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。 -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。 -增加示例-如何将Grid控件导出为Excel(data\grid_excel_run.<em>asp</em>x)(feedback:503684912)。 -如果TreeNode的属性Enabled="false",则此项变灰并且不<em>会</em>被选中(feedback:your568)。 -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~/开头)的BUG。 -增加Accordion和Tree配合使用的示例(other\accordion_tree_run.<em>asp</em>x)。 -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。 +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。 -这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。 -简单方便,示例可以参考 default.<em>asp</em>x 或者 other\accordion_tree_run.<em>asp</em>x。 +2009-08-14 v2.0.6 -<em>动态</em>生成菜单实例(other\menu_dynamic_run.<em>asp</em>x和other\menu_dynamic2_run.<em>asp</em>x)(feedback:shguo)。 -优化AJAX的内部实现,每个页面保存的ViewState现在减少1/3左右(重要更新)。 -优化Tree节点的NodeId<em>自动</em>生成,减少ViewState占用。 +2009-08-09 v2.0 beta5 +Ext<em>Asp</em>Net和<em>Asp</em>.net的提交按钮兼容问题(feedback:千帆)。 -在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果<em>Asp</em>.net的按钮AJAX提交,必须设置UseSubmitBehavior="false" --也就是说生成的input的type不能是"submit",而这个限制在有些情况下是不可原谅的。 --我们<em>做</em>了优化,现在要使一个<em>Asp</em>.net的按钮能够AJAX提交,你不需要<em>做</em>任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。 +PageManager的实例方法AddAjaxUpdateControl改名为AddAjax<em>Asp</em>netControls,现在可以在Page_Load中设置需要在AJAX中需要更新的<em>Asp</em>.net控件了。 -在Page_Load中设置了哪些需要在AJAX中更新的<em>Asp</em>.net控件<em>会</em>在回发时保持状态,可以通过RemoveAjax<em>Asp</em>netControls来去除不需要更新的控件。 -示例在<em>asp</em>net\fckeditor_run.<em>asp</em>x和<em>asp</em>net\<em>asp</em>net_run.<em>asp</em>x。 -FCKEditor和上传控件兼容。示例在<em>asp</em>net\fileupload_run.<em>asp</em>x。 -修正ToolbarText的文本在AJAX下更新的BUG。 -Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。 -更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。 +2009-08-02 v2.0 beta4 +和<em>Asp</em>.Net的Forms Authentication兼容[feedback:mgzhenhong]。 -采用和<em>Asp</em>.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。 -现在支持Response.Redirect,你可以选择Response.Redirect或者Ext<em>Asp</em>Net.PageContext.Redirect重定向页面,两者效果一样。 -支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。 -Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。 -修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。 -修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。 -增加Menu和Accordion的示例。 -修正Window控件的IconUrl有时不显示(Target="_parent")的BUG[feedback:xmq&mgzhenhong]。 +2009-07-22 v2.0 beta3 -兼容FCKEditor。 -在IE8.0,Firefox3.5下测试通过。以后Ext<em>Asp</em>Net将不<em>会</em>对IE6.0提供支持。 +2009-07-13 v2.0 beta2 -集成ext<em>js</em>最新版本v3.0。 +兼容IE6.0-7.0-8.0。 -这应该是Ext<em>js</em>3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();<em>会</em>导致button的click事件无法响应(IE8下无此问题)。 -目前先禁用IE6.0-7.0的QuickTips。 -优化底层JavaScript。 +2009-07-05 v2.0 beta1 -更新ext<em>js</em>库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。 -使用YUI Compressor压缩JavaScript和CSS文件。 -Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。 -Ext<em>Asp</em>Net自身的CSS<em>会</em>紧挨着页面标签引入,这样在中自定义的样式可以覆盖Ext<em>Asp</em>Net缺省样式。 +Alert对话框<em>会</em>遮挡所有的Window窗口。 -使用一个变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。 -为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。 -因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。 -重新绑定模拟树的下拉列表后,选中项的前面有图片的HTML标签的BUG。 -更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。 -更新示例工程。 +2009-03-25 v1.3.1 -Tree在AJAX回发展开节点时<em>JS</em>错误[feedback:xlli]。[fixed] -Window中的EnableIFrame==false,则点击关闭按钮时报<em>JS</em>错误。[fixed] -页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例<em>asp</em>net/fileupload.<em>asp</em>x)[fixed] -HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed] +2009-03-03 v1.3.0 -如果弹出的窗口(Ext-Window)含有<em>ASP</em>.NET控件FileUpload,则此弹出窗口在关闭时出现<em>JS</em>错误(http://ext<em>js</em>.com/forum/showthread.php?t=8129)[feedback:xlli]。[fixed] -如果页面中存在<em>ASP</em>.NET控件(TextBox),则第二次提交表单就<em>会</em>报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed] -页面上放置Ext<em>Asp</em>Net-Button和<em>ASP</em>.NET-Button,则点击Ext<em>Asp</em>Net-Button时激发的是<em>ASP</em>.NET-Button的事件,这个BUG和Ext<em>js</em>2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed] -Ext<em>Asp</em>Net内部包含HtmlAgilityPack和Nii.<em>JS</em>ON两个开源的第三方类库。[added] +如果以前你听过不要在Ext<em>Asp</em>Net工程中使用<em>ASP</em>.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在Ext<em>Asp</em>Net控件和<em>ASP</em>.NET标准控件和平共处了。[fixed] -如果一个<em>ASP</em>.NET按钮控件要使用Ext<em>Asp</em>Net的原生AJAX,只需要设置属性 UseSubmitBehavior="false" 即可。 -如果要在一次Ext<em>Asp</em>Net的原生AJAX回发时更新<em>ASP</em>.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:<em>asp</em>net/<em>asp</em>net.<em>asp</em>x)。 +2009-02-27 v1.2 beta9 -网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed] -<em>自动</em>测试功能<em>会</em>在以后版本中逐步完善。这个版本完成测试框架,采用Ext<em>js</em>中<em>JS</em>函数进<em>行</em>大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed] +系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed] -底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。 -PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。 ---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference/GetConfirmFormModifiedCloseRefreshReference/GetConfirmFormModifiedClosePostBackReference三个方法代替。 -不<em>会</em>修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面<em>添加</em>box_parent_client_id查询字符串 -去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的<em>JS</em>方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。 ---注意:以前的项目需要在所有的<em>ASP</em>X页面中查找RegisterPageStateChangedScript属性,并删除,否则<em>会</em>运<em>行</em>错误! -A页面有Ext-Window控件弹出B页面,B页面有Ext-Window控件弹出C页面,B页面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C页面)<em>会</em>覆盖整个A页面,这是正确的。 ---当时如果用户直接访问B页面,就<em>会</em>报<em>JS</em>错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不<em>会</em>出错了。 -Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。 ---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。 ---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。 ---现在可以很方便的为Window控件的关闭按钮<em>添加</em>关闭后刷新父页面或者关闭后回发父页面的<em>行</em>为。 -如果弹出窗口(Window控件)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮<em>会</em>报<em>JS</em>错误,因为此时页面尚未加载完毕。 ---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。 -Window控件的IFrameName属性是<em>自动</em>生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。 -CurrentActiveWindow改名为ActiveWindow。 -[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values) ---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。 +2009-02-23 v1.2 beta8 -ContentPanel中内容不能<em>自动</em>扩展高度的BUG[feedback:huihuang]。[fixed] -DropDownList在Ajax回发时不能计算模拟树的<em>数据</em>[feedback:huihuang]。[fixed] -DropDownList在页面第一次加载时没有不可选择项,则回发时也不<em>会</em>有不可选择项的BUG。[fixed] -升级底层Ext<em>JS</em>类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed] -页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added] +增加部分<em>自动</em>测试支持(使用WatiN和NUnit),下个版本将<em>会</em>提供完整的<em>自动</em>测试支持。[fixed] +2008-10-28 v1.2 beta7 -DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed] -Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed] +PageContext优化。[fixed] -去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。 -去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。 -Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。 -Image控件增加ImageWidth/ImageHeight/ImageCssStyle/ImageCssClass/ImageAlt属性[feedback:jqpeng]。[fixed] -发布包中增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed] -ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed] -Row和Column布局时,修正IE下设置RowHeight="100%"时显示不正确的BUG。[fixed] -AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed] +TabStrip的Tab控件的EnablePostBack属性<em>会</em>在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都<em>会</em>回发)。[fixed] -有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后<em>会</em>回发Tab1一次。 +2008-10-20 v1.2 beta6 +使用控件的站点必须建立虚拟目录,否则<em>会</em>报<em>JS</em>错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed] -需要替换新的blowery.Web.HttpCompress.dll,解决方案见http://pohee.com/it/http-compression-in-<em>asp</em>net-20/。 +DropDownList优化。[fixed] -去除EnableFirstItem/FirstItemText/FirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。 现在可以方便的在后台DropDownList1.Items.Insert(0, new Ext<em>Asp</em>Net.ListItem("全部", "-1"));来达到同样的效果。 +如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。 -和<em>Asp</em>.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = ""; -ListItemCollection增加重载函数Add(string text, string value),这样方便后台<em>添加</em>列表项。 -处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight<em>会</em><em>自动</em>设置为false(避免开发人员发生此类错误)。[fixed] -注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding/border-width/margin)。[fixed] +为所有控件属性增加在VS中的智能提示。[fixed] -需要将Ext<em>Asp</em>Net.XML和Ext<em>Asp</em>Net.dll放在一起,这样引用dll时xml<em>会</em>被拷贝到bin目录下,提供VS的智能提示。 +控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed] -TriggerIconType.Default -> TriggerIconType.None -SystemIconType.Empty -> SystemIconType.None -RegexPattern.USER_DEFINED -> RegexPattern.None -表单验证属性名称变化(ValueToCompare->CompareValue,ControlToCompare->CompareControl)。[fixed] +注意:一个属性可以拥有多个值的情况。[fixed] -属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。 -其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。 +AccordionLink实现为控件。[fixed] -可以方便的在子页面(iframe)中通过<em>js</em>切换父页面中选中的菜单项(Accordion->AccordionLink)(示例在other/accordion_links_run.<em>asp</em>x,other/accordion_links_run_iframe_htm)[feedback:jima]。 +确认:可以方便的<em>动态</em><em>添加</em>控件,并且可以给控件<em>添加</em>服务器端事件(示例在form/form_dynamic_run.<em>asp</em>x)。[fixed] +2008-10-15 v1.2 beta5 -验证表单字段的ValueToCompare属性,为字符串时<em>会</em>出错的BUG。[fixed] +优化下拉列表。[fixed] -验证下拉列表时,应该取ListItem的Value属性进<em>行</em>验证,而不是Text属性。 -DropDownList的Items增加Insert方法(可方便的下拉列表选项<em>添加</em>“全部”)。 -DropDownList不支持EmptyText属性。 -ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(<em>ASP</em>X)中设置哪些项不可选择,以及创建模拟下拉树。 -DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则<em>自动</em>将EnableSimulateTree设置为true。 +2008-09-27 v1.2 beta4 +EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只<em>会</em>改变Accordion的标题大小,而不<em>会</em>对AccordionPanel起作用(示例见other/accordion_run.<em>asp</em>x)。[fixed] -Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。 -影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。 -AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed] +AccordionPanel增加Links属性,可以绑定列表<em>数据</em>到AccordionPanel,呈现的是链接的列表(示例在other/accordion_links_run.<em>asp</em>x)。[fixed] -原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上标签。 -适当增大AccordionPanel中链接的高度20px->22px,同时对链接的样式也<em>做</em>了微调。 -通过BodyPadding控制链接列表的边距。 -这样能大大减少<em>ASP</em>X中HTML代码和Javascript代码的书写,可以在后台<em>动态</em><em>添加</em>链接,效果很赞,此需求由马季提出。 +2008-09-25 v1.2 beta3 +代码优化与设计时支持(尚需要不断完善,目前可以在<em>ASP</em>X页切换到“设计时”,方便属性的更改和事件处理函数的<em>添加</em>)。[fixed] -Panel/GroupPanel/ContentPanel/Tree/HiddenField/PageLoading -TabStrip/Toolbar -TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed] -向Form中<em>动态</em><em>添加</em>控件的BUG,现在form/form_dynamic_run.<em>asp</em>x示例已经能正确运<em>行</em>。[fixed] +大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed] -影响的控件包括Toolbar/Accordion/AccordionPanel/GroupPanel/Panel/SimpleForm/Window等。 -保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。 -保留TabStrip的Tabs(TabCollection)属性。 -保留PageLayout/BorderLayout的Regions(RegionCollection)属性。 -预祝今晚神七发射成功。 +2008-09-22 v1.2 beta2 +Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed] -表现为对Grid进<em>行</em>多次删除<em>添加</em>操作后,SelectedRowIndexArray选中项中<em>会</em>存在当前不存在的<em>行</em>序号,导致服务器端遍历选中项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。 +代码优化与设计时支持(示例中表单控件都已支持设计)。[fixed] -PageManager/SimpleForm/Button/HyperLink/Label/Image/LinkButton/TextBox -TriggerBox/TwinTriggerBox/Window/TextArea/HtmlEditor/DatePicker/NumberBox -CheckBox/RadioButton/RadioButtonList/DropDownList -Grid +2008-09-19 v1.2 beta1 -Image/LinkButton/HyperLink增加一些Ajax可更新属性。[fixed] +隐藏的方式由HideMode属性控制Visibility/Offsets/Display。[fixed] -修正Form/SimpleForm中隐藏一个表单字段(Hidden=false)<em>会</em>占据页面空间的BUG。 -ToolbarText/ToolbarFill/ToolbarSeparator在<em>ASP</em>X中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed] -Button去除MarginRight属性(可以通过CssStyle="margin-right:5px;"达到相同的效果)[fixed] +2008-09-09 v1.1 +Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在控件中。[fixed] -网报:CssClass="toolbar-pagemenu" CssStyle="border:0px;",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(../images/pagemenu_toolbar_background.gif) repeat-x left top;}。 -Region去除默认的Layout=Fit,如果希望Region使用Fit/Anchor/Column/Row等布局的话,需要手工指定。[fixed] -ToolbarSeparator/ToolbarFill在Ajax更新Hidden属性的BUG。[fixed] +布局整理。[fixed] -新增Column/Absolute/Row三种布局,加上以前的Container/Fit/Anchor/Accordion/Border/Form六种布局,总共有9中布局可供使用。 -其中一些控件默认使用一种布局:SimpleForm(Form)/Form(Form)/Panel-GroupPanel(Container)/Accordion(Accordion)/PageLayout(Border)/BorderLayout(Border)/TabStrip(Card),所有布局控件默认的布局是Container。 -经常用到的布局控件:SimpleForm/Form/Accordion/TabStrip/BorderLayout,经常用到的布局:Fit/Row/Anchor +2008-09-08 v1.1 beta7 -MenuButton/MenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick="false" CssStyle="cursor:default;" [feedback:huayu]。[fixed] -MenuButton/MenuHyperLink/MenuSeparator/MenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed] +大部分的Ext<em>Asp</em>Net控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed] -注意Visible和Hidden的区别:Visible=false的属性不<em>会</em>渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。 -US的Ext<em>Asp</em>Net改造强烈依赖于此属性,这个版本发布后可以继续。 -网报中唯一没有用到Ext<em>Asp</em>NetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。 +2008-09-04 v1.1 beta6 -PageContext.Redirect支持普通页面转向和Ext<em>Asp</em>NetAjax下页面转向。[fixed] +模拟树的下拉列表的BUG(<em>会</em>使一些可选项变成不可选项)[feedback:xmzhu]。[fixed] -因为if("0,2,9,11,".indexOf('1,')>=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。 -解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) >= 0){ok}。 -DropDownList在Ajax时应该先更新<em>数据</em>再设置选定项 [feedback:xmzhu]。[fixed] -Button/MenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed] -Tree的Ajax支持(尚需优化)。[fixed] +2008-09-02 v1.1 beta5 -DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed] -模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有<em>数据</em>也需要设置DataTextField/DataValueField/DataSimulateTreeLevelField/DataEnableSelectField等属性的值,否则Ajax回发时<em>会</em>出错)。[fixed] -UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不<em>会</em>用<em>Asp</em>netAjax,这个控件已经完成使命)。[fixed] -不要使用<em>Asp</em>.net的控件HiddenField,而是使用Ext<em>Asp</em>Net的HiddenField,因为<em>Asp</em>.net的控件在Ajax不<em>会</em>被更新,所以<em>会</em>导致视图状态不一致的错误。[fixed] -网报Ajax整合基本完成(除了待审批->下一步[审核/归档/出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed] -IE下,RadioButtonList中项如果存在汉字,则<em>会</em>换<em>行</em>的BUG。[fixed] -增加两个Theme[Slate/Black](样式尚需完善)。[fixed] +2008-09-01 v1.1 beta4 -非当前Tab中如果有ContentPanel,则在页面上方<em>会</em>有空白(可以通过设置EnableDeferredRender=false解决,但<em>会</em>减慢页面的加载速度),现在已经解决这个问题。[fixed] -RadioButtonList去除EnableBackgroundColor/EnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm/Form)的背景色一致。[fixed] -TwinTriggerBox的第一个Trigger图标不<em>会</em>先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed] -Web.config中增加配置项FormLabelWidth="80"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm/Form的表单字段标题的宽度。[fixed] +完善Ajax。[fixed] -RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue/SelectedItem)。 -DropDownList增加Ajax可更新属性Enable/SelectedIndex(SelectedValue/SelectedItem)/DataSource。 -Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。 -ToolbarText增加Ajax可更新属性Text。 +2008-08-31 v1.1 beta3 -TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed] -重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法<em>会</em>出错。[fixed] +安全的Ajax设计。[fixed] -这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上<em>会</em>有进一步的提升。 -基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。 -整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不<em>会</em>对UI起作用,同时是安全的,不<em>会</em>有<em>js</em>错误)。 -网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed] +2008-08-29 v1.1 beta1 +Window控件是否弹出的状态在回发时维持。[fixed] -控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。 +完全抛弃<em>Asp</em>.NetAjax,Ext<em>Asp</em>Net控件内置Ajax支持。[fixed] -这是一个值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和<em>Asp</em>.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。 -不需要<em>做</em>任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。 +在这种设计下,其实可以完全抛弃Javascript。 -比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。 -第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。 -推荐的<em>做</em>法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。 +目前Ext<em>Asp</em>NetAjax的限制。 -只对Ext<em>Asp</em>Net控件起作用,对<em>Asp</em>.net控件不起作用。 -对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。 -对改变控件的Visible属性<em>会</em>有错误。 -Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。 -PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都<em>添加</em>PageLoading控件。[fixed] -Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执<em>行</em>,这样当前<em>行</em>被选中的状态在回发后<em>会</em>得到保持。[fixed] -Grid选中<em>行</em>的状态在第一次回发时不能保持的BUG。[fixed] +2008-08-26 v1.0 +已知问题:IE的ActiveX插件IE Developer Toolbar<em>会</em>对IFrame的加载造成0.5m左右的延迟。 -主要是父页面加载一个比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都<em>会</em>有500ms左右的延迟,在测试IE性能时要禁用此插件。 +优化弹出窗口中IFrame的显示速度。[fixed] -在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。 -PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor="#CADDF7",以便分隔符的颜色和Toolbar的颜色一致)[fixed] +PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed] -一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.<em>asp</em>x)。 -TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed] +TabStrip中非当前Tab<em>会</em>延迟渲染。[fixed] -这<em>会</em>明显加快页面的渲染速度,网报中一个典型的费用审批页面可以减少200ms的渲染时间。 -由于非当前Tab不<em>会</em>在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render事件中。 -不能比较两个DataPicker大小的BUG。[fixed] -TabStrip延迟加载引起的BUG(非当前Tab中的ContentPanel<em>会</em>占据页面空间,已修正)。[fixed] -全新的Ext<em>Asp</em>Net.Examples(基础知识/表单控件/<em>数据</em>绑定/容器布局/IFrame框架)。[fixed] +2008-08-19 v0.4 beta6 +PageManager增加两个属性(EnableInlineStyleJavascript/ApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe/default.<em>asp</em>x和iframe/page3.<em>asp</em>x)。[fixed] -测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。 -RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed] +ext<em>js</em>的BUG,当页面中含有iframe时,Ext.onReady<em>会</em>被调用两次(IE6/IE7)(http://www.ext<em>js</em>.net/forum/showthread.php?t=43246)(示例在test.<em>asp</em>x)[fixed] -现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true; +需要先回发页面再弹出IFrame窗口。[fixed] -在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。 -另一种<em>做</em>法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference("./simpleform.<em>asp</em>x"));。 +2008-08-15 v0.4 beta5 -点击关闭窗口的按钮,在IE6下<em>会</em>有<em>JS</em>错误。[fixed] -增加BorderLayout控件,示例在iframe/borderlayout.<em>asp</em>x。[fixed] +Radiobuttonlist显示有重影(示例在radio.<em>asp</em>x)。[fixed] -全新的样式。 -去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。 -GetValueReference取得的值不正确的BUG。 -<em>动态</em>向Form中<em>添加</em>FormRow,并<em>动态</em>的向FormRow中<em>添加</em>表单字段,以及如何取得表单字段的值。(示例在form_dynamic.<em>asp</em>x)[fixed] +IFrame弹出窗口关闭后回发父页面,则<em>会</em>多加载IFrame一次,再次打开窗口<em>会</em>重复加载IFrame2-3次[feedback:xmzhu]。[fixed] -这是一个重要的BUG,<em>会</em>严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl<em>会</em>在回发时保持状态,从而回发父页面后Window中的IFrame被<em>添加</em>到页面,而这是不需要的。 -现在"是否弹出窗口、窗口标题、IFrameUrl"在客户端的改变,不<em>会</em>影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.<em>asp</em>x) +2008-08-13 v0.4 beta4 -点击关闭窗口的按钮,在IE下<em>会</em>有<em>JS</em>错误。[fixed] -Window的右上角关闭图标增加提示,优化事件响应。[fixed] -Window的代码重构。[fixed] +修正一个的内存泄漏。[fixed] -IE7下测试,打开iframe/default.<em>asp</em>x页面,iexplorer占内存68.368M。 -内存存在泄漏时,点击iframe/page3.<em>asp</em>x页面8次后iexplorer占118.792M内存。 -修正后,点击iframe/page3.<em>asp</em>x页面8次后iexplorer占76.492M内存。 -IE窗口最小化时,IE<em>会</em><em>自动</em>进<em>行</em>垃圾回收。 +2008-08-12 v0.4 beta3 -底层的javascript框架Ext<em>js</em>升级为v2.2,Grid的渲染速度有很大提升。[fixed] -Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则<em>行</em>不可见,可以通过AutoHeight="true"解决)。[fixed] +页面正在加载的提示尽早的显示出来。[fixed] -首先在执<em>行</em><em>js</em>来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示出来。 -加载<em>js</em>脚本的script标签放置在页面的最后,放置加载<em>js</em>而阻塞PageLoading的显示。 +2008-08-08 v0.4 beta2 -TabStrip延时加载出错。[fixed] -Window的IFrameUrl处理的BUG,比如Pages_Ext<em>Asp</em>Net目录下的页面应该为./FE_ApplyEditor.<em>asp</em>x或~/Pages_Ext<em>Asp</em>Net/FE_ApplyEditor.<em>asp</em>x。[fixed] -Window的WindowPosition="Center"并且Target="_parent",则<em>会</em><em>JS</em>错误。[fixed] -实现网报首页下拉菜单和左侧菜单的导航功能。[fixed] -Window的创建在页面显示后进<em>行</em>,不计算在<em>js</em>渲染时间内。[fixed] -优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed] -button_iframe.<em>asp</em>x默认<em>会</em>加载form.<em>asp</em>x页面(Window控件的BUG)。[fixed] -Window中的保存并关闭按钮和<em>Asp</em>.netAjax冲突。[fixed] -优化关闭Window的<em>js</em>脚本,减少写到页面的<em>js</em>大小。[fixed] -加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.<em>asp</em>x)。[fixed] +2008-08-05 v0.4 beta1 -DropDownList去除Traditional属性,和传统的<em>Asp</em>.net控件一样不可编辑。[fixed] -DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed] -为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed] -将生成的<em>js</em>对象的名称简单化,这样可以减少生成的<em>js</em>内容,加快页面加载速度(一个典型页面的<em>js</em>由原来的33.0k降低为21.4k)。[fixed] +弹出窗口中,点击按钮回发然后点击关闭按钮,出现<em>js</em>错误 [feedback:xmzhu]。[fixed] -因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为<em>js</em>调用此脚本时报错。 -一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。 -另一种办法就是在PageManager控件中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(<em>会</em>在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.<em>asp</em>x/simpleform.<em>asp</em>x)。 +PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.<em>asp</em>x)。[fixed] -这个手工<em>添加</em>onReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去<em>做</em>的麻烦(已经在网报中遇到这种情况)。 -每个页面必须<em>添加</em>一个PageManager控件,否则<em>会</em>出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed] -TextField等表单字段增加Readonly属性。[fixed] +全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和<em>Asp</em>.net Ajax保持兼容)。[fixed] -最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下) +示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.<em>asp</em>x/page2.<em>asp</em>x/simpleform.<em>asp</em>x) -虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要<em>做</em>的仅仅是为Window控件增加一个属性(Target="_parent"),就完成了两种框架的转换,是不是很酷。 -显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.<em>asp</em>x(A)/page2.<em>asp</em>x(B)/simpleform.<em>asp</em>x(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我<em>会</em>通过一篇文章来揭示这一过程,敬请期待。 -示例2,Grid中弹出窗口。(default.<em>asp</em>x/page3.<em>asp</em>x/simpleform.<em>asp</em>x) +示例3,TriggerBox弹出窗口。(default.<em>asp</em>x/triggerbox.<em>asp</em>x/simpleform.<em>asp</em>x) -在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。 -示例4,弹出窗口中的弹出窗口。 -对整个Examples更新测试。[fixed] +2008-07-31 v0.3 beta12 -IE下TabStrip在Ajax回发后不<em>会</em>去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed] -对TabStrip/Panel/Window中的IFrame重新设计,如果设置IFrameUrl="#"或者"about:blank",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不<em>会</em>有残影出现。[fixed] -如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则<em>会</em>延迟加载(示例在tabstrip_iframe.<em>asp</em>x)。[fixed] -Tree控件,点击一个节点<em>自动</em>回发,则当前点击的那个节点的选中状态不<em>会</em>保持的BUG [feedback:zgjiang2]。[fixed] +规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.<em>asp</em>x/simpleform.<em>asp</em>x)。[fixed] -内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执<em>行</em>(在simpleform.<em>asp</em>x,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。 -参照Yslow的评分规则,将<em>JS</em>文件引用由head移动到body中。[fixed] -Firefox下,如果页面太长<em>会</em>出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed] +IFrame内的页面宽度和高度<em>会</em><em>自动</em>设置(是不是还在为1px/2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.<em>asp</em>x/simpleform.<em>asp</em>x/simpleform2.<em>asp</em>x)[fixed] -增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE/Firefox)。 +2008-07-24 v0.3 beta11 -web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed] -Window在回发时设置的Title不起作用的BUG。[fixed] -增加Image控件 [feedback:jima]。[fixed] -Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则<em>会</em>引起页面死循环回发 [feedback:zgjiang2]。[fixed] -Image增加ToolTipTitle/ToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.<em>asp</em>x)。[fixed] -去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed] -过滤提示消息中的换<em>行</em>符(转换为),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed] +2008-07-23 v0.3 beta10 +完善Tree控件。[fixed] -如何将<em>数据</em>库中的<em>数据</em>绑定到Tree(示例在tree2_bind_database.<em>asp</em>x)。 -ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.<em>asp</em>x)。 -更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。 -Grid的GridColumn的ID改名成ColumnId,否则同一个页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed] -Grid所有类型的列增加DataTooltipField/DataTooltipFormatString两个字段,以显示ToolTip(示例在grid.<em>asp</em>x)。[fixed] +2008-07-22 v0.3 beta9 +IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed] -发现原来ie6不能正确解析li的高度,必须手工设置才<em>行</em>(style="height:20px;")。 +IE6/IE7下,模拟树的下拉列表如果文字长度太长,则显示的文字<em>会</em>换<em>行</em>,导致错位。[fixed] -虽然最后未能解决##差旅交通费在IE和Firefox下显示的不同效果。 -但是通过用来代替,从而实现FF和IE下样式的统一。 -刚看到old9的解决方案:把“差旅交通费”改成“差旅交通费”,在IE下和FF下的都不换<em>行</em>,:-) -LinkButton增加OnClick事件 [feedback:huihuang]。[fixed] -Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed] +增加树控件(Tree)(示例在tree2.<em>asp</em>x)。[fixed] -可以在回发时维持树的状态(选中<em>行</em>,折叠/展开,CheckBox)。 -可以通过Inline的方式<em>添加</em>树节点,也可以绑定到XmlDocument/XmlDataSource/SiteMap。 -点击树节点可以链接到页面,也可以引发PostBack事件,可以<em>添加</em>自定义脚本。 +2008-07-16 v0.3 beta8 +ContentPanel中放置Ext<em>Asp</em>Net控件,则渲染时<em>会</em>出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed] -隐蔽性非常强,原来在ContentPanel中渲染Ext<em>Asp</em>Net控件,如果容器的display='none',则<em>会</em>出现各种问题(主要是大小不对)。 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。 -现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就<em>会</em>显示滚动条。 +IE6下,在应用<em>Asp</em>.NetAjax后,Form中字段的宽度渲染不正确。[fixed] -调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。 -最后发现IE6下应用<em>Asp</em>.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG: 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();): 示例在 Site.Master 页面。 +集成的<em>Asp</em>NetAjax有一个很大的BUG,只要你在页面上进<em>行</em>过ajax操作,当改变窗口大小时你<em>会</em>惊讶的发现内容区域的内容全部为空了![fixed] -解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();), 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。 +2008-07-14 v0.3 beta6 -增加FlashObject控件。[fixed] -PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed] -Accordion选中样式微调。[fixed] -预加载Form表单出错时提示信息的背景图片。[fixed] +Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(一个典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed] -因为延迟加载<em>数据</em>不<em>会</em>改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置"EnableDelayRender=false"。 -改变Grid中静态的CheckBoxField图片。[fixed] -TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.<em>asp</em>x)[fixed] +2008-07-12 v0.3 beta5 -页面菜单Toolbar的分割符和背景不相融合。[fixed] -表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.<em>asp</em>x)。[fixed] -如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和TextBox比较大小需要指定CompareType。 +如果在编辑页面使用<em>Asp</em>NetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.<em>asp</em>x/ajax_editor.<em>asp</em>x)。[fixed] -这是由于ajax后执<em>行</em>的javascript中不能有return false语句。 +在文本框失去焦点时,执<em>行</em>一些Javascript脚本(示例在textbox_blur.<em>asp</em>x) [feedback:xmzhu]。[fixed] -在页面<em>添加</em>onReady函数(<em>会</em>被系统调用),然后用javascript监视文本框值的改变。 -弹出Window默认显示的错误页面,解决方法在当前目录<em>添加</em>一个空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是"#"。[fixed] +弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时<em>会</em>有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed] -原来的调用方法太麻烦(见示例中alert\alert_1.<em>asp</em>x和alert\alert_2.<em>asp</em>x,总计 6 <em>行</em>代码),现在只需要 3 <em>行</em>代码就OK了。 -点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.<em>asp</em>x)[feedback:jima]。[fixed] +增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.<em>asp</em>x)。[fixed] -增加SplitButton控件。[fixed] +2008-07-09 v0.3 beta4 -DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed] +Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed] -增加ControlToCompare/ValueToCompare/CompareOperator/CompareMessage四个属性,示例在form_compare.<em>asp</em>x。 +TabStrip中放置IFrame<em>会</em>出现渲染错误 (示例在tabstrip_iframe.<em>asp</em>x)[feedback:jima]。[fixed] -特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。 -RadioButtonList增加AutoPostBack属性(示例在radio.<em>asp</em>x) [feedback:xmzhu]。[fixed] -FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.<em>asp</em>x)[feedback:jima]。[fixed] +表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed] -覆盖缺省样式的.x-item-disabled,设置不透明。 +2008-07-08 v0.3 beta3 -Grid没有<em>数据</em>,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed] +增加HiddenField控件。[fixed] -其实用TextBox也能模拟HiddenField的<em>行</em>为,只需要设置CssStyle="display:none;"即可。 +TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed] -最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.<em>asp</em>x)。 -模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed] +控制下拉列表某些项不可以选择(示例在dropdownlist2.<em>asp</em>x)。[fixed] -增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。 -LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.<em>asp</em>x和grid.<em>asp</em>x)。[fixed] +2008-07-07 v0.3 beta2 +增加UpdatePanelConnector控件,支持在布局构建的页面使用<em>Asp</em>.net Ajax。[fixed] -使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。 -示例在ajax3.<em>asp</em>x/content_page4.<em>asp</em>x。 -示例content_page3.<em>asp</em>x中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。 +2008-07-03 v0.3 beta1 +容器控件的AutoHeight/AutoWidth默认为false。[fixed] -使用GroupPanel的地方需要手工<em>添加</em>AutoHeight="true"属性。 +增加UserControlConnector,可以在其中放置用户控件(示例在page_usercontrol.<em>asp</em>x)。[fixed] -也可以在ContentPanel中放置用户控件,注意两者的区别。 +增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed] +支持<em>Asp</em>.net ajax异步加载。[fixed] -有很大局限性,只能在ContentPanel中使用,示例在ajax1.<em>asp</em>x/content_ajax2.<em>asp</em>x中。 -对于使用布局构建的页面(比如content_page1.<em>asp</em>x)还不能使用<em>Asp</em>.net ajax,因为页面是整体渲染的,先放弃。 +2008-07-02 v0.2 beta12 +关闭前提示当前页面已经被修改(示例在content_page1.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -支持Iframe内按钮和window右上角关闭按钮。 -删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中<em>做</em>法一致)。 +iframe中的alert/confirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed] -在Firefox下还有问题。[fix pending] +排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.<em>asp</em>x)。[fixed] -可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。 -可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。 +HyperLinkField/WindowField的链接地址支持服务器端格式(即是~/alert.<em>asp</em>x)。[fixed] -TabStrip的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed] -可以在ContentPanel中放置用户控件(示例在page_usercontrol.<em>asp</em>x)。[fixed] +2008-06-30 v0.2 beta11 -增加TwinTriggerBox控件(示例在twintriggerbox.<em>asp</em>x)。[fixed] -Grid的<em>数据</em>库分页需要增加属性IsDatabasePaging=true,以便普通分页和<em>数据</em>库分页,否则在<em>添加</em>删除记录时总记录数不<em>会</em>变化 [feedback:zgjiang2]。[fixed] -关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.<em>asp</em>x)。[fixed] -如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的tab)。[fixed] +页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.<em>asp</em>x/simpleform.<em>asp</em>x)[fixed] -目前还不支持Window右上角关闭按钮的提示保存功能。 -Master/Content的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed] -Grid中的LinkButtonField设置ConfirmText<em>会</em>出错 [feedback:huihuang]。[fixed] -增加静态类Confirm。[fixed] +2008-06-27 v0.2 beta10 +Grid完善。[fixed] -CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.<em>asp</em>x示例)。 -Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.<em>asp</em>x)。 -切换分页时清空选中的值 [feedback:jqpeng]。 -增加PreRowDataBound事件,可以在<em>数据</em>绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.<em>asp</em>x)。 -DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.<em>asp</em>x)。 +2008-06-25 v0.2 beta9 +Window窗体中的</a></div><div data-report-view="{"mod":"popu_645","index":"3","dest":"https://download.csdn.net/download/zrf139138/6207707","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAltJREFUWEdjZGBgYGhv/yD45//nEEYGBrX//xj4QWK0AoxMDB//MzDcYmHkXVNZKfCeEWz5v8/1DP8ZuGhlKVZzGRm+sTDxNjI2tz1OZfjHYEpXy2GWMTGcZmxpe9xN62DH5TlQdDA2tzyeNSC+h1o66gCyQyApUdRNSIhNGBSS7979ejtv/utd5EQl2Q7IypT0ExJiFoc44O/LadOfbxp1wPAOAWlpdr5Pn//8/Pzp70+QT3GlAX5+ZnYeHhb2p09/fiImRIhOhBYWvIo21ryWu/Z8PHDp4tdn2BxgoM8l4+IiYH/k6OdjJ058vk91B7g487swMDD8v3Hj+2VJSTYpfn5mEZAlHz/9ffPq5e+Xqqoc2iD+nr0f99DSAQQ9RhMHcHAwsYSGCtvKy7Gr4HPBo0c/b69c/fbwzx///hJ0KQMDA9FpAGaYizO/tpkZjwUTEyMTsgX//v3/d/LUl+N79368RozFMDUkOwCkUUODU8zHW9CFg4OJG8T/8ePf181b3u25efPHK1IsB6nF6gAjY25ZEWFWcNPs169/fw4c+HQD3WBBIRaOsBAhZ5D4qjXv9r5/9+cHuhoHBz4NNjYmFpD4m7e/P547+/UxuhqsDoiPE3WWlWVXgvju/5ee3qfLsfmMiZmBEST+7y/Df2zyJcXSkRwcjDwgucePf95buOj1Xqo6gFBwDw8H/P/P8O/nz//fCPkWmzw7OyMXIyMDOLeQHQXkWIxNz9BygJubgI6kBCu4tUMt8PzF75e7dn24QlQuoJalxJgzCDomA901G/DOKSieBrJ7DgCPdYFAskV/NwAAAABJRU5ErkJggg==" alt data-v-ca2d15ac> <a target="_blank" href="https://download.csdn.net/download/zrf139138/6207707" data-report-click="{"mod":"popu_645","index":"3","dest":"https://download.csdn.net/download/zrf139138/6207707","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="title" data-v-ca2d15ac>JavaScript网页特效范例宝典源码</a></div> <a target="_blank" href="https://download.csdn.net/download/zrf139138/6207707" data-report-click="{"mod":"popu_645","index":"3","dest":"https://download.csdn.net/download/zrf139138/6207707","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="desc" data-v-ca2d15ac>目录: 第1章 窗口/框架与导航条设计 1 1.1 弹出窗口控制 2 实例001 打开新窗口显示广告信息 2 实例002 定时打开窗口 4 实例003 通过按钮创建窗口 5 实例004 <em>自动</em>关闭的广告窗口 6 实例005 控制弹出窗口居中显示 7 实例006 弹出的窗口之Cookie控制 9 实例007 为弹出的窗口加入关闭按钮 11 实例008 关闭弹出窗口时刷新父窗口 12 实例009 关闭IE主窗口时,不弹出询问对话框 13 1.2 弹出网页对话框 14 实例010 弹出网页模式对话框 14 实例011 弹出全屏显示的网页模式对话框 16 实例012 网页拾色器 18 实例013 日期选择器 21 1.3 窗口的动画效果 26 实例014 页面<em>自动</em>滚动 26 实例015 打开窗口特殊效果 27 实例016 <em>动态</em>显示窗口 29 实例017 慢慢放大的窗口 30 实例018 下降式浏览器 32 实例019 旋转的窗口 33 实例020 移动的窗口 34 实例021 震动的窗口 35 实例022 弹出广告窗口 36 1.4 窗口控制 37 实例023 窗口始终在最上面 38 实例024 窗口的最小化、最大化 39 实例025 频道方式窗口 41 实例026 全屏显示 42 实例027 设置窗口大小和位置 43 实例028 刷新当前页 44 实例029 <em>自动</em>最大化 45 实例030 自定义导航控制面板 46 实例031 根据用户分辨率<em>自动</em>调整窗口 48 1.5 窗口的其他效果 49 实例032 打开窗口时显示对话框 50 实例033 使窗口背景透明 50 实例034 立体窗口 52 实例035 <em>动态</em>标题栏 53 实例036 固定大小的窗口 54 1.6 框架的应用 55 实例037 框架集的嵌套 56 实例038 在网页中应用浮动框架 58 实例039 创建空白框架 60 实例040 居中显示框架页 62 1.7 无边框窗口 63 实例041 全屏显示无边框有滚动条的窗口 63 实例042 应用CSS+DIV实现指定尺寸无边框无滚动条窗口 65 实例043 应用JavaScript实现指定尺寸无边框无滚动条窗口 67 1.8 水平导航条应用 69 实例044 图片按钮导航条 69 实例045 导航条的动画效果 71 实例046 不用图片实现质感导航条 72 1.9 下拉菜单式导航条 73 实例047 二级导航菜单 74 实例048 半透明背景的下拉菜单 76 实例049 展开式导航条 80 实例050 用层制作下拉菜单1 81 实例051 用层制作下拉菜单2 84 1.10 侧导航条设计 86 实例052 <em>自动</em>隐藏式菜单 87 实例053 收缩式导航菜单 89 实例054 树状导航菜单 91 第2章 表单及表单元素 95 2.1 文本框/编辑框/隐藏域组件 96 实例055 获取文本框/编辑框/隐藏域的值 96 实例056 <em>自动</em>计算金额 97 实例057 设置文本框的只读属性 98 实例058 限制多<em>行</em>文本域输入的字符个数 100 实例059 <em>自动</em>选择文本框/编辑框中的文字 102 实例060 按下回车键时<em>自动</em>切换焦点 103 2.2 下拉列表/菜单 104 实例061 获取下拉列表/菜单的值 104 实例062 遍历多选择下拉列表 105 实例063 在下拉列表中进<em>行</em>多选移除 106 实例064 将数组中的<em>数据</em><em>添加</em>到下拉菜单中 107 实例065 应用下拉菜单选择所要联机的网站 108 实例066 多级级联菜单 110 实例067 可以输入文字的下拉菜单 111 实例068 根据下拉菜单的值显示不同控件 112 实例069 分级下拉列表 113 2.3 单选按钮组 114 实例070 不提交表单获取单选按钮的值 114 实例071 选中单选按钮后显示其他表单元素 116 实例072 通过单选按钮控制其他表单元素是否可用 117 2.4 复选框 117 实例073 不提交表单获取复选框的值 118 实例074 控制复选框的全选或反选 118 实例075 只有一个复选框时控制复选框的全选或反选 119 2.5 密码域 120 实例076 让您的密码域更安全 120 实例077 不提交表单<em>自动</em>检测密码域是否相同 121 2.6 表单应用 122 实例078 通过JavaScript控制表单的提交与重置 122 实例079 带记忆功能的表单 123 实例080 防止表单重复提交 124 实例081 <em>自动</em>提交表单 125 实例082 通过for循环获取表单元素的中文名称 126 实例083 可以提交到不同处理页的表单 127 第3章 实用JavaScript函数 129 3.1 <em>数据</em>验证 130 实例084 通过正则表达式验证日期 130 实例085 验证输入的日期格式是否正确 132 实例086 检查表单元素是否为空 134 实例087 验证E-mail是否正确 135 实例088 通过正则表达式验证电话号码 137 实例089 验证输入的字符串是否为汉字 139 实例090 验证身份证号码 140 实例091 验证用户名和密码 142 实例092 验证车牌号码 144 实例093 验证网站地址 145 实例094 验证数量和金额 147 实例095 验证字符串是否以指定字符开头 149 实例096 限制输入字符串的长度 150 3.2 字符串处理 152 实例097 小写金额转换为大写金额 152 实例098 去除字符串中的空格 155 实例099 转换输入文本中的回车和空格 156 实例100 将数字字符串格式化为指定长度 158 实例101 把一个长数字分位显示 159 实例102 将RGB格式的颜色值转换为十六进制格式 161 实例103 将IP地址转换为对应的数值 163 实例104 从指定URL中提取文件名 164 3.3 随机函数 166 实例105 随机产生指定位数的验证码 166 实例106 生成随机字符串 167 3.4 日期与时间 169 实例107 显示长日期格式的系统日期 169 实例108 实时显示系统时间 171 第4章 日期和时间 173 4.1 日期时间显示 174 实例109 在标题栏中显示日期时间 174 实例110 使用toLocaleString()方法获取本地时间 176 实例111 全中文显示日期 176 实例112 在状态栏中显示日期时间 178 实例113 使用数组显示星期 179 实例114 在表格中显示时间 180 实例115 退出页面时显示停留时间 181 实例116 显示用户在页面的停留时间 182 实例117 显示最后修改时间 183 4.2 日期时间算法 184 实例118 计算某一天是星期几 184 实例119 判断指定年份是否为闰年 186 实例120 计算从出生到现在度过的时间 187 实例121 返回两个日期之间的间隔小时 188 实例122 倒计时 190 实例123 访问时间限制 191 实例124 计步器 192 4.3 日期时间特效 194 实例125 分时问候 194 实例126 节日提示 195 实例127 倒影时钟 196 实例128 带阴影的时钟 199 实例129 <em>动态</em>石英钟 200 实例130 生日提醒器 203 实例131 数字时钟 205 实例132 各地时间表 206 实例133 位于页面顶层的时钟 209 第5章 文字特效 213 5.1 文字的颜色变换 214 实例134 简单文字变色 214 实例135 文字变色 215 实例136 变换的文字 216 实例137 描边文字 217 实例138 霓虹灯文字 218 实例139 追逐点亮的文字 219 实例140 萤光文字 220 实例141 发光文字的闪烁效果 221 实例142 文字的舞台灯光效果 223 实例143 制作彩色渐变文字动画 224 5.2 改变文字大小 226 实例144 文字伸缩 226 实例145 动荡的文字 227 实例146 文字伸展 228 实例147 文字逐个放大 230 实例148 <em>自动</em>改变大小 231 实例149 选择字体的大小 232 5.3 文字显示效果 234 实例150 文字渐隐渐现 234 实例151 文字虚幻变化 235 实例152 文字虚幻抖动 237 5.4 指定文字位置 238 实例153 将文字置于工作区左上角 238 实例154 右上角文字 239 实例155 鼠标移动文字 241 5.5 文字<em>动态</em>移动 242 实例156 文字<em>自动</em>滚屏 242 实例157 文字上下滚动 243 5.6 文字立体效果 244 实例158 文字的旋转 244 实例159 立体旋转文字 246 实例160 文字3D效果 248 5.7 文字动画效果 249 实例161 反弹文字 249 实例162 飞舞的文字 252 实例163 飞翔的文字 254 实例164 平面旋转的文字 257 实例165 输出文字 258 实例166 文字打字效果 259 实例167 文字抖动 261 实例168 指向文字时飞出星形标记 262 实例169 文字的抛出效果 264 5.8 文字特殊效果 265 实例170 波浪文字 265 实例171 梦幻文字效果 266 实例172 屏风文字 268 实例173 文字阴影 270 5.9 其他 270 实例174 随机显示文字 270 实例175 文字加密及解密 271 第6章 超级链接特效 275 6.1 超级链接样式 276 实例176 改变超级链接字体样式 276 实例177 当鼠标移动到超级链接时改变超级链接颜色 277 实例178 改变超级链接背景色 278 6.2 超级链接控制 279 实例179 建立E-mail超级链接 280 实例180 获取页面中的全部超级链接 281 实例181 将网站设为首页 282 实例182 单击鼠标右键<em>自动</em>链接到指定网站 283 实例183 单击超级链接将本页加入收藏夹 285 实例184 访问指定的链接地址 286 实例185 返回默认主页 287 实例186 导航链接 289 6.3 超级链接特效 291 实例187 快速闪动页面中的超级链接 291 实例188 滚动的超级链接提示信息 292 实例189 公告栏中显示超级链接 294 实例190 显示超级链接站点相关信息 295 实例191 显示超级链接的提示信息 296 实例192 半透明背景的超级链接提示 297 第7章 操作表格 299 7.1 表格的颜色效果 300 实例193 闪烁的表格边框 300 实例194 单元格边框变色 301 实例195 选中的<em>行</em>变色 302 7.2 对单元格的焦点进<em>行</em>控制 303 实例196 选定表格中的单元格 303 实例197 左右移动单元格的信息 304 实例198 通过键盘使单元格焦点任意移动 306 7.3 对表格的<em>行</em>、列进<em>行</em>修改 311 实例199 <em>动态</em>制作表格 311 实例200 <em>动态</em>生成<em>行</em>或列 313 实例201 删除表中的<em>行</em> 314 7.4 单元格的相关操作 316 实例202 隐藏及显示单元格 316 实例203 编辑单元格中的文本信息 318 实例204 合并单元格 320 实例205 在表格中<em>添加</em><em>行</em>及单元格 322 实例206 删除表中的单元格 324 7.5 表格的特殊效果 325 实例207 透明表格 326 实例208 限制表格的宽度 327 实例209 表格的标题 328 实例210 表格的外阴影 329 实例211 立体表格 329 实例212 虚线边框表格 330 实例213 表格作为分割线 332 实例214 表格向下展开 332 第8章 图形图像与多媒体 335 8.1 图片大小 336 实例215 打开自定义大小的图片 336 实例216 图片放大缩小 337 实例217 通过鼠标滚轮放大缩小图片 338 8.2 图片与鼠标相关操作 339 实例218 跟随鼠标移动的图片 340 实例219 可以左右拖动的图片 340 实例220 随意拖动图片 342 实例221 当鼠标经过图片时显示图片 344 实例222 改变图片获取焦点时的状态 345 实例223 抖动的图片 346 实例224 鼠标移动放大图片 347 8.3 图片与时间相关操作 349 实例225 定时隐藏图片 349 实例226 根据时间变换页面背景 350 实例227 使图片不停闪烁 352 实例228 上下跳动的图片 352 实例229 图片左右晃动 354 实例230 飘舞的变形图片 356 8.4 图片的动画效果 358 实例231 图片翻转效果 359 实例232 水波倒影特效 360 实例233 图片渐隐渐现 361 实例234 图片的探照灯效果 362 实例235 雷达扫描图片特效 363 实例236 在页面中旋转的图片 365 实例237 改变形状的图片 366 实例238 图片在页面浮动 367 实例239 随机变化的网页背景 369 8.5 选择头像 370 实例240 在列表中选择图片 370 实例241 在弹出的新窗口中选择图片 372 8.6 在页面中播放图片 374 实例242 幻灯片式播放图片 374 实例243 无间断的图片循环滚动效果 376 8.7 图片的其他效果 377 实例244 导航地图 377 8.8 播放音乐 378 实例245 为网页设置背景音乐 378 实例246 随机播放背景音乐 380 实例247 MIDI音乐选择 381 8.9 插入Flash动画 383 实例248 插入Flash动画 383 实例249 插入背景透明的Flash动画 384 8.10 播放视频文件 385 实例250 播放AVI文件 385 实例251 自制视频播放器 387 第9章 页面特效 391 9.1 页面背景效果 392 实例252 背景固定居中 392 实例253 背景图片纵向重复显示 393 实例254 通过按钮变换背景颜色 395 实例255 背景<em>自动</em>变色 396 实例256 百叶窗 396 实例257 渐隐渐显的背景颜色 398 实例258 页面缩小 399 实例259 页面上下打开效果 400 实例260 页面左右打开效果 402 实例261 页面溶解效果 404 9.2 特殊页面 406 实例262 页首页尾切换 406 实例263 调用下载页面 408 实例264 程序加载页面 409 实例265 颜色拾取器 411 9.3 广告页面 415 实例266 图片总置于顶端 415 实例267 随机显示广告 416 实例268 广告随滚动条漂移 418 9.4 页面动画效果 419 实例269 下雪 419 实例270 飘落的枫叶 421 实例271 下雨 423 实例272 背景的烟花效果 425 实例273 变色的圆圈 427 实例274 滚动的光环 429 实例275 星空极速飞入效果 430 实例276 闪烁的星星 432 9.5 其他 434 实例277 带密码的网页 434 实例278 页面左右滚动 435 实例279 <em>动态</em>移动的层 437 实例280 在页面中显示十字光标 438 第10章 状态栏特效 441 10.1 状态栏文字动画 442 实例281 使状态栏中的文字不停闪烁 442 实例282 文字从右向左依次弹出 443 实例283 文字从中间向两边展开 445 实例284 文字跑马灯特效 447 实例285 文字依次显示后快速收缩 449 实例286 文字的展开与收缩 451 实例287 状态栏中的文字依次弹出 452 10.2 其他 453 实例288 在状态栏显示固定自定义信息 453 实例289 在状态栏显示鼠标坐标 454 实例290 在状态栏显示特定的超级链接信息 456 第11章 报表与打印 459 11.1 Web打印 460 实例291 调用IE自身的打印功能实现打印 460 实例292 打印指定框架中的内容 461 实例293 利用WebBrowser打印 462 实例294 设置页眉页脚 463 11.2 利用Word打印报表 465 实例295 将页面中的表格导出到Word并打印 465 实例296 打开指定的Word文档并打印 467 实例297 在<em>JS</em>P中利用Word<em>自动</em>打印指定格式的<em>会</em>议记录 468 实例298 在<em>ASP</em>中利用Word<em>自动</em>打印指定格式的<em>会</em>议记录 470 实例299 在PHP中调用Word<em>自动</em>打印指定格式的<em>会</em>议记录 472 11.3 利用Excel打印报表 474 实例300 将Web页面中的<em>数据</em>导出到Excel 474 实例301 将Web页面中的<em>数据</em>导出到Excel并<em>自动</em>打印 476 11.4 利用CSS样式打印 478 实例302 利用CSS样式打印页面中的指定内容 478 实例303 利用CSS样式分页打印 479 11.5 套打邮寄产品单 482 实例304 打印汇款单 482 实例305 打印快递单 484 实例306 打印信封 485 第12章 网站安全 489 12.1 禁止用户复制网页内容 490 实例307 禁止用户复制网页内容(方法一) 490 实例308 禁止用户复制网页内容(方法二) 491 实例309 禁止网页另存为 492 12.2 禁止用户刷新屏幕 493 实例310 屏蔽IE主菜单 493 实例311 屏蔽键盘相关事件 494 实例312 屏蔽鼠标右键 496 12.3 登录页面 497 实例313 具有浏览器检测功能的登录页面 497 实例314 防止SQL注入的登录页面 498 实例315 带验证码的登录页面 500 12.4 其他 501 实例316 使用Script Encoder加密工具加密 501 第13章 HTML/CSS样式 503 13.1 页面效果 504 实例317 统一站内网页风格 504 实例318 设置超级链接文字的样式 508 实例319 网页换肤 509 实例320 滚动文字 512 实例321 制作渐变背景 513 13.2 表格样式 514 实例322 只有外边框的表格 515 实例323 彩色外边框的表格 516 实例324 控制表格指定外边框不显示 518 实例325 背景颜色渐变的表格 520 实例326 表格隔<em>行</em>变色 521 13.3 鼠标及滚动条样式 522 实例327 显示自定义鼠标形状 522 实例328 动画光标 524 实例329 制作彩色滚动条 525 13.4 文字及列表样式 527 实例330 应用删除线样式标记商品特价 527 实例331 在文字上方标注说明标记 528 实例332 指定图标的列表项 529 13.5 文字滤镜特效 530 实例333 文字的发光效果 531 实例334 文字的阴影效果 532 实例335 文字的渐变阴影效果 533 实例336 文字的图案填充效果 534 实例337 文字的探照灯效果 535 实例338 文字的闪烁效果 537 实例339 文字的空心效果 538 实例340 文字的浮雕效果 539 实例341 文字的阳文效果 540 实例342 文字的雪雕效果 541 实例343 火焰字 542 实例344 文字扭曲动画 544 13.6 图片滤镜特效 545 实例345 图片的半透明效果 545 实例346 图片的模糊效果 546 实例347 图片的水波纹特效 547 实例348 图片的灰度效果 548 实例349 图片的<em>动态</em>说明文字 549 第14章 JavaScript与XML 553 14.1 读取XML文件 554 实例350 使用XML DOM对象读取XML文件 554 实例351 使用XMLHttpRequest对象读取XML文件 557 14.2 显示XML文档 559 实例352 使用CSS显示XML文档 559 实例353 使用XSL显示XML文档 562 实例354 使用IE XML<em>数据</em>岛输出XML文档 564 14.3 操作XML 565 实例355 用JavaScript控制XML文档的分页显示 565 实例356 通过操作XML<em>数据</em>岛实现<em>添加</em>、删除留言信息 567 第15章 JavaScript与<em>ASP</em>结合 573 15.1 弹出窗口/对话框控制 574 实例357 关闭弹出窗口时刷新父窗口 574 实例358 打开新窗口显示详细信息 575 实例359 弹出网页模式对话框 577 实例360 日期选择器 580 实例361 弹出提示对话框并重定向网页 584 实例362 打开指定大小的新窗口并居中显示 586 15.2 弹出确认对话框 588 实例363 删除<em>数据</em>前弹出确认对话框 588 实例364 安全退出前弹出确认对话框 590 15.3 其他 591 实例365 远程获取其他网页情报 591 实例366 树状导航菜单 594 实例367 使用XML实现不刷新页面查询<em>数据</em> 596 第16章 JavaScript与<em>JS</em>P结合 601 16.1 窗口与对话框 602 实例368 弹出提示对话框并重定向网页 602 实例369 打开新窗口显示详细信息 604 实例370 打开指定大小的新窗口并居中显示 605 实例371 弹出网页模式对话框 607 实例372 关闭弹出窗口时刷新父窗口 609 16.2 无刷新技术 611 实例373 无刷新的用户名检测 611 实例374 无刷新的级联下拉列表 614 实例375 使用XML实现不刷新页面查询<em>数据</em> 616 16.3 调用与控制 619 实例376 将查询结果导出到Word 619 实例377 调用Excel 621 实例378 调用PowerPoint 622 16.4 其他 623 实例379 树状导航菜单 623 第17章 JavaScript与<em>ASP</em>.NET结合 627 17.1 窗口与对话框 628 实例380 使用JavaScript脚本弹出对话框 628 实例381 打开新窗口显示详细信息 629 实例382 关闭弹出窗口刷新父窗口 631 实例383 弹出网页模式对话框 633 实例384 弹出全屏显示网页 635 17.2 其他 637 实例385 <em>自动</em>隐藏式菜单 637 第18章 JavaScript与PHP结合 641 18.1 窗口与对话框 642 实例386 弹出提示对话框并重定向网页 642 实例387 关闭弹出窗口时<em>自动</em>刷新父窗口 643 实例388 在弹出的网页模式对话框中选择个性头像 645 实例389 时间选择器 647 实例390 弹出提示对话框并重定向网页 649 实例391 删除<em>数据</em>前弹出确认对话框 650 18.2 其他 651 实例392 树状导航菜单 651 第19章 综合应用 657 19.1 计算器 658 实例393 简单计算器 658 实例394 复杂计算器 662 19.2 日历 667 实例395 精美日历 668 实例396 带农历的日历 674 19.3 购物车 681 实例397 <em>添加</em>至购物车 682 实例398 查看购物车 684 实例399 修改商品购买数量 686 实例400 从购物车中移去指定商品 687 实例401 清空购物车 689 JavaScript程序开发范例宝典附录 691</a></div><div data-report-view="{"mod":"popu_645","index":"4","dest":"https://download.csdn.net/download/u013013722/8220345","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAltJREFUWEdjZGBgYGhv/yD45//nEEYGBrX//xj4QWK0AoxMDB//MzDcYmHkXVNZKfCeEWz5v8/1DP8ZuGhlKVZzGRm+sTDxNjI2tz1OZfjHYEpXy2GWMTGcZmxpe9xN62DH5TlQdDA2tzyeNSC+h1o66gCyQyApUdRNSIhNGBSS7979ejtv/utd5EQl2Q7IypT0ExJiFoc44O/LadOfbxp1wPAOAWlpdr5Pn//8/Pzp70+QT3GlAX5+ZnYeHhb2p09/fiImRIhOhBYWvIo21ryWu/Z8PHDp4tdn2BxgoM8l4+IiYH/k6OdjJ058vk91B7g487swMDD8v3Hj+2VJSTYpfn5mEZAlHz/9ffPq5e+Xqqoc2iD+nr0f99DSAQQ9RhMHcHAwsYSGCtvKy7Gr4HPBo0c/b69c/fbwzx///hJ0KQMDA9FpAGaYizO/tpkZjwUTEyMTsgX//v3/d/LUl+N79368RozFMDUkOwCkUUODU8zHW9CFg4OJG8T/8ePf181b3u25efPHK1IsB6nF6gAjY25ZEWFWcNPs169/fw4c+HQD3WBBIRaOsBAhZ5D4qjXv9r5/9+cHuhoHBz4NNjYmFpD4m7e/P547+/UxuhqsDoiPE3WWlWVXgvju/5ee3qfLsfmMiZmBEST+7y/Df2zyJcXSkRwcjDwgucePf95buOj1Xqo6gFBwDw8H/P/P8O/nz//fCPkWmzw7OyMXIyMDOLeQHQXkWIxNz9BygJubgI6kBCu4tUMt8PzF75e7dn24QlQuoJalxJgzCDomA901G/DOKSieBrJ7DgCPdYFAskV/NwAAAABJRU5ErkJggg==" alt data-v-ca2d15ac> <a target="_blank" href="https://download.csdn.net/download/u013013722/8220345" data-report-click="{"mod":"popu_645","index":"4","dest":"https://download.csdn.net/download/u013013722/8220345","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="title" data-v-ca2d15ac>正则表达式</a></div> <a target="_blank" href="https://download.csdn.net/download/u013013722/8220345" data-report-click="{"mod":"popu_645","index":"4","dest":"https://download.csdn.net/download/u013013722/8220345","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="desc" data-v-ca2d15ac>正则表达式中的特殊字符 字符 含意 \ <em>做</em>为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界。 -或- 对正则表达式功能字符的还原,如"*"匹配它前面元字符0次或多次,/a*/将匹配a,aa,aaa,加了"\"后,/a\*/将只匹配"a*"。 ^ 匹配一个输入或一<em>行</em>的开头,/^a/匹配"an A",而不匹配"An a" $ 匹配一个输入或一<em>行</em>的结尾,/a$/匹配"An a",而不匹配"an A" * 匹配前面元字符0次或多次,/ba*/将匹配b,ba,baa,baaa + 匹配前面元字符1次或多次,/ba*/将匹配ba,baa,baaa ? 匹配前面元字符0次或1次,/ba*/将匹配b,ba (x) 匹配x保存x在名为$1...$9的变量中 x|y 匹配x或y {n} 精确匹配n次 {n,} 匹配n次以上 {n,m} 匹配n-m次 [xyz] 字符集(character set),匹配这个集合中的任一一个字符(或元字符) [^xyz] 不匹配这个集合中的任何一个字符 [\b] 匹配一个退格符 \b 匹配一个单词的边界 \B 匹配一个单词的非边界 \cX 这儿,X是一个控制符,/\cM/匹配Ctrl-M \d 匹配一个字数字符,/\d/ = /[0-9]/ \D 匹配一个非字数字符,/\D/ = /[^0-9]/ \n 匹配一个换<em>行</em>符 \r 匹配一个回车符 \s 匹配一个空白字符,包括\n,\r,\f,\t,\v等 \S 匹配一个非空白字符,等于/[^\n\f\r\t\v]/ \t 匹配一个制表符 \v 匹配一个重直制表符 \w 匹配一个可以组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[\w]匹配"$5.98"中的5,等于[a-zA-Z0-9] \W 匹配一个不可以组成单词的字符,如[\W]匹配"$5.98"中的$,等于[^a-zA-Z0-9]。 用re = new RegExp("pattern",["flags"]) 的方式比较好 pattern : 正则表达式 flags: g (全文查找出现的所有 pattern) i (忽略大小写) m (多<em>行</em>查找) vaScript<em>动态</em>正则表达式问题 请问正则表达式可以<em>动态</em>生成吗? 例如JavaScript中: var str = "strTemp"; 要生成: var re = /strTemp/; 如果是字符连接: var re = "/" + str + "/"即可 但是要生成表达式,可以实现吗?怎样实现? [JAVA] javascript 正则表达式 秋雨叶 发表于 2004-12-9 14:54:13 正则表达式是一个描述字符模式的对象。 JavaScript的RegExp对象和String对象定义了使用正则表达式来执<em>行</em>强大的模式匹配和文本检索与替换函数的方法. 在JavaScript中,正则表达式是由一个RegExp对象表示的.当然,可以使用一个RegExp()构造函数来创建RegExp对象, 也可以用JavaScript 1.2中的新<em>添加</em>的一个特殊语法来创建RegExp对象.就像字符串直接量被定义为包含在引号内的字符一样, 正则表达式直接量也被定义为包含在一对斜杠(/)之间的字符.所以,JavaScript可能<em>会</em>包含如下的代码: var pattern = /s$/; 这<em>行</em>代码创建一个新的RegExp对象,并将它赋给变量parttern.这个特殊的RegExp对象和所有以字母"s"结尾的字符串都匹配.用RegExp()也可以定义 一个等价的正则表达式,代码如下: var pattern = new RegExp("s$"); 无论是用正则表达式直接量还是用构造函数RegExp(),创建一个RegExp对象都是比较容易的.较为困难的任务是用正则表达式语法来描述字符的模式. JavaScript采用的是Perl语言正则表达式语法的一个相当完整的子集. 正则表达式的模式规范是由一系列字符构成的.大多数字符(包括所有字母数字字符)描述的都是按照字面意思进<em>行</em>匹配的字符.这样说来,正则表达式/java/就和 所有包含子串 "java" 的字符串相匹配.虽然正则表达式中的其它字符不是按照字面意思进<em>行</em>匹配的,但它们都具有特殊的意义.正则表达式 /s$/ 包含两个字符. 第一个特殊字符 "s" 是按照字面意思与自身相匹配.第二个字符 "$" 是一个特殊字符,它所匹配的是字符串的结尾.所以正则表达式 /s$/ 匹配的就是以字母 "s" 结尾 的字符串. 1.直接量字符 我们已经发现了,在正则表达式中所有的字母字符和数字都是按照字面意思与自身相匹配的.JavaScript的正则表达式还通过以反斜杠(\)开头的转义序列支持某些非 字母字符.例如,序列 "\n" 在字符串中匹配的是一个直接量换<em>行</em>符.在正则表达式中,许多标点符号都有特殊的含义.下面是这些字符和它们的含义: 正则表达式的直接量字符 字符 匹配 ________________________________ 字母数字字符 自身 \ f 换页符 \ n 换<em>行</em>符 \ r 回车 \ t 制表符 \ v 垂直制表符 \ / 一个 / 直接量 \ \ 一个 \ 直接量 \ . 一个 . 直接量 \ * 一个 * 直接量 \ + 一个 + 直接量 \ ? 一个 ? 直接量 \ | 一个 | 直接量 \ ( 一个 ( 直接量 \ ) 一个 ) 直接量 \ [ 一个 [ 直接量 \ ] 一个 ] 直接量 \ { 一个 { 直接量 \ } 一个 } 直接量 \ XXX 由十进制数 XXX 指 定的ASCII码字符 \ Xnn 由十六进制数 nn 指定的ASCII码字符 \ cX 控制字符^X. 例如, \cI等价于 \t, \cJ等价于 \n ___________________________________________________ 如果想在正则表达式中使用特殊的标点符号,必须在它们之前加上一个 "\" . 2.字符类 将单独的直接符放进中括号内就可以组合成字符类.一个字符类和它所包含的任何一个字符都匹配,所以正则表达式 / [abc] / 和字母 "a" , "b" , "c" 中的任何一个 都匹配.另外还可以定义否定字符类,这些类匹配的是除那些包含在中括号之内的字符外的所有字符.定义否定字符尖时,要将一个 ^ 符号作为从左中括号算起的第 一个字符.正则表达式的集合是 / [a-zA-z0-9] / . 由于某些字符类非常常用,所以JavaScript的正则表达式语法包含一些特殊字符和转义序列来表示这些常用的类.例如, \s 匹配的是空格符,制表符和其它空白符, \s 匹配的则是空白符之外的任何字符. 正则表灰式的字符类 字符 匹配 ____________________________________________________ [...] 位于括号之内的任意字符 [^...] 不在括号之中的任意字符 . 除了换<em>行</em>符之外的任意字符,等价于[^\n] \w 任何单字字符, 等价于[a-zA-Z0-9] \W 任何非单字字符,等价于[^a-zA-Z0-9] \s 任何空白符,等价于[\ t \ n \ r \ f \ v] \S 任何非空白符,等价于[^\ t \ n \ r \ f \ v] \d 任何数字,等价于[0-9] \D 除了数字之外的任何字符,等价于[^0-9] [\b] 一个退格直接量(特例) ________________________________________________________________ 3.复制 用以上的正则表式的语法,可以把两位数描述成 / \ d \ d /,把四位数描述成 / \d \ d \ d \ d /.但我们还没有一种方法可以用来描述具有任意多数位的数字或者是一个 字符串.这个串由三个字符以及跟随在字母之后的一位数字构成.这些复杂的模式使用的正则表达式语法指定了该表达式中每个元素要重复出现的次数. 指定复制的字符总是出现在它们所作用的模式后面.由于某种复制类型相当常用.所以有一些特殊的字符专门用于表示它们.例如: +号匹配的就是复制前一模式一次 或多次的模式.下面的表列出了复制语法.先看一个例子: /\d{2, 4}/ //匹配2到4间的数字. /\w{3} \d?/ //匹配三个单字字符和一个任意的数字. /\s+java\s+/ //匹配字符串"java" ,并且该串前后可以有一个或多个空格. /[^"] * / //匹配零个或多个非引号字符. 正则表达式的复制字符 字符 含义 __________________________________________________________________ {n, m} 匹配前一项至少n次,但是不能超过m次 {n, } 匹配前一项n次,或者多次 {n} 匹配前一项恰好n次 ? 匹配前一项0次或1次,也就是说前一项是可选的. 等价于 {0, 1} + 匹配前一项1次或多次,等价于{1,} * 匹配前一项0次或多次.等价于{0,} ___________________________________________________________________ 4.选择,分组和引用 正则表达式的语法还包括指定选择项,对子表达式分组和引用前一子表达式的特殊字符.字符| 用于分隔供选择的字符.例如: /ab|cd|ef/ 匹配的是字符串 "ab",或者是 字符串 "cd",又或者 "ef". /\d{3}|[a-z]{4}/ 匹配的是要么是一个三位数,要么是四个小写字母.在正则表达式中括号具有几种作用.它的主要作用是把单独的项目分组 成子表达式,以便可以像处理一个独立的单元那种用 *、+或? 来处理那些项目.例如: /java(script) ?/ 匹配的是字符串 "java",其后既可以有 "script",也可以没有. / (ab|cd) + |ef) / 匹配的既可以是字符串 "ef",也可以是字符串"ab" 或者 "cd" 的一次或多次重复. 在正则表达式中,括号的第二个用途是在完整的模式中定义子模式。当一个正则表达式成功地和目标字符串相匹配时,可以从目标串中抽出和括号中的子模式相匹配 的部分.例如,假定我们正在检索的模式是一个或多个字母后面跟随一位或多位数字,那么我们可以使用模式 / [a-z] + \ d+/.但是由于假定我们真正关心的是每个匹配 尾部的数字,那么如果我们将模式的数字部分放在括号中 (/ [a-z] + (\d+)/) ,我们就可以从所检索到的任何匹配中抽取数字了,之后我们<em>会</em>对此进<em>行</em>解析的. 代括号的子表达式的另一个用途是,允许我们在同一正则表达式的后面引用前面的子表达式.这是通过在字符串 \ 后加一位或多位数字来实现的.数字指的是代括号的 子表达式在正则表达式中的位置.例如: \1 引用的是第一个代括号的子表达式. \3 引用的是第三个代括号的子表达式.注意,由于子表达式可以嵌套在其它子表达式中, 所以它的位置是被计数的左括号的位置. 例如:在下面的正则表达式被指定为 \2: /([Jj]ava([Ss]cript)) \sis \s (fun\w*) / 对正则表达式中前一子表达式的引用所指定的并不是那个子表达式的模式,而是与那个模式相匹配的文本.这样,引用就不只是帮助你输入正则表达式的重复部分的快 捷方式了,它还实施了一条规约,那就是一个字符串各个分离的部分包含的是完全相同的字符.例如:下面的正则表达式匹配的就是位于单引号或双引号之内的所有字 符.但是,它要求开始和结束的引号匹配(例如两个都是双引号或者都是单引号): /[' "] [^ ' "]*[' "]/ 如果要求开始和结束的引号匹配,我们可以使用如下的引用: /( [' "] ) [^ ' "] * \1/ \1匹配的是第一个代括号的子表达式所匹配的模式.在这个例子中,它实施了一种规约,那就是开始的引号必须和结束的引号相匹配.注意,如果反斜杠后跟随的数字比 代括号的子表达式数多,那么它就<em>会</em>被解析为一个十进制的转义序列,而不是一个引用.你可以坚持使用完整的三个字符来表示转义序列,这们就可以避免混淆了.例如, 使用 \044,而不是\44.下面是正则表达式的选择、分组和引用字符: 字符 含义 ____________________________________________________________________ | 选择.匹配的要么是该符号左边的子表达式,要么它右边的子表达式 (...) 分组.将几个项目分为一个单元.这个单元可由 *、+、?和|等符号使用,而且还可以记住和这个组匹配的字符以供此后引 用使用 \n 和第n个分组所匹配的字符相匹配.分组是括号中的子表达式(可能是嵌套的).分组号是从左到右计数的左括号数 ____________________________________________________________________ 5.指定匹配的位置 我们已经看到了,一个正则表达式中的许多元素才能够匹配字符串的一个字符.例如: \s 匹配的只是一个空白符.还有一些正则表达式的元素匹配的是字符之间宽度为 0的空间,而不是实际的字符例如: \b 匹配的是一个词语的边界,也就是处于一个/w字字符和一个\w非字字符之间的边界.像\b 这样的字符并不指定任何一个匹配了的 字符串中的字符,它们指定的是匹配所发生的合法位置.有时我们称这些元素为正则表达式的锚.因为它们将模式定位在检索字符串中的一个特定位置.最常用的锚元 素是 ^, 它使模式依赖于字符串的开头,而锚元素$则使模式定位在字符串的末尾. 例如:要匹配词 "javascript" ,我们可以使用正则表达式 /^ javascript $/. 如果我们想检索 "java" 这个词自身 (不像在 "javascript" 中那样作为前缀),那么我们可以使 用模式 /\s java \s /, 它要求在词语java之前和之后都有空格.但是这样作有两个问题.第一: 如果 "java" 出现在一个字符的开头或者是结尾.该模式就不<em>会</em>与之匹配,除 非在开头和结尾处有一个空格. 第二: 当这个模式找到一个与之匹配的字符时,它返回的匹配的字符串前端和后端都有空格,这并不是我们想要的.因此,我们使用词语 的边界 \b 来代替真正的空格符 \s 进<em>行</em>匹配. 结果表达式是 /\b java \b/. 下面是正则表达式的锚字符: 字符 含义 ____________________________________________________________________ ^ 匹配的是字符的开头,在多<em>行</em>检索中,匹配的是一<em>行</em>的开头 $ 匹配的是字符的结尾,在多<em>行</em>检索中,匹配的是一<em>行</em>的结尾 \b 匹配的是一个词语的边界.简而言之就是位于字符\w 和 \w之间的位置(注意:[\b]匹配的是退格符) \B 匹配的是非词语的边界的字符 _____________________________________________________________________ 6.属性 有关正则表达式的语法还有最后一个元素,那就是正则表达式的属性,它说明的是高级模式匹配的规则.和其它正则表达式语法不同,属性是在 / 符号之外说明的.即它 们不出现在两个斜杠之间,而是位于第二个斜杠之后.javascript 1.2支持两个属性.属性 i 说明模式匹配应该是大小写不敏感的.属性 g 说明模式匹配应该是全局的.也 就是说,应该找出被检索的字符串中所有的匹配.这两种属性联合起来就可以执<em>行</em>一个全局的,大小写不敏感的匹配. 例如: 要执<em>行</em>一个大小不敏感的检索以找到词语 "java" (或者是 "java" 、"JAVA"等) 的第一个具体值,我们可以使用大小不敏感的正则表达式 /\b java\b/i .如果要在 一个字符串中找到 "java" 所有的具体值,我们还可以<em>添加</em>属性 g, 即 /\b java \b/gi . 以下是正则表达式的属性: 字符 含义 _________________________________________ i 执<em>行</em>大小写不敏感的匹配 g 执<em>行</em>一个全局的匹配,简而言之,就是找到所有的匹配,而不是在找到第一个之后就停止了 _________________________________________ 除属性 g 和 i 之外,正则表达式就没有其它像属性一样的特性了.如果将构造函数 RegExp 的静态属性 multiline 设置为 true ,那么模式匹配将以多<em>行</em>的模式进<em>行</em>.在这 种模式下,锚字符 ^ 和 $ 匹配的不只是检索字符串的开头和结尾,还匹配检索字符串内部的一<em>行</em>的开头和结尾.例如: 模式 /Java$/ 匹配的是 "Java",但是并不匹配 "Java\nis fun" .如果我们设置了 multiline 属性,那么后者也将被匹配: RegExp.multiline = true; 在JAVASCRIPT里面判断一个字符串是否是电子邮件的格式: if(formname.email.value!=formname.email.value.match(/^\w +[@]\w +[.][\w.] +$/)) { alert("您的电子邮件格式错误!"); formname.email.focus(); return false; } 阅读全文(42) | 回复(0) | 引用(0) | [用365key收藏此日志] [RED]function dateVerify(date){ var reg = /^(\d{4})(-)(\d{2})\2(\d{2})$/; var r = date.match(reg); if(r==null) return false; var d= new Date(r[1], r[3]-1,r[4]); var newStr=d.getFullYear()+r[2]+(d.getMonth()+1)+r[2]+d.getDate(); date=r[1]+r[2]+((r[3]-1)+1)+r[2]+((r[4]-1)+1); return newStr==date; }[/RED] javascript的17种正则表达式 作者: 不祥  时间: 2004-6-9 "^\\d+$"  //非负整数(正整数 + 0) "^[0-9]*[1-9][0-9]*$"  //正整数 "^((-\\d+)|(0+))$"  //非正整数(负整数 + 0) "^-[0-9]*[1-9][0-9]*$"  //负整数 "^-?\\d+$"    //整数 "^\\d+(\\.\\d+)?$"  //非负浮点数(正浮点数 + 0) "^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮点数 "^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$"  //非正浮点数(负浮点数 + 0) "^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //负浮点数 "^(-?\\d+)(\\.\\d+)?$"  //浮点数 "^[A-Za-z]+$"  //由26个英文字母组成的字符串 "^[A-Z]+$"  //由26个英文字母的大写组成的字符串 "^[a-z]+$"  //由26个英文字母的小写组成的字符串 "^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串 "^\\w+$"  //由数字、26个英文字母或者下划线组成的字符串 "^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$"    //email地址 "^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$"  //url JavaScript中的正则表达式(2) 作者 :中国论坛网收集 来源 :http://www.51one.net 加入时间 :2004-8-25   正则表达式对象的属性及方法    预定义的正则表达式拥有有以下静态属性:input, multiline, lastMatch, lastParen, leftContext, rightContext和$1到$9。其中input和multiline可以预设置。其他属性的值在执<em>行</em>过exec或test方法后被根据不同条件赋以不同的值。许多属性同时拥有长和短(perl风格)的两个名字,并且,这两个名字指向同一个值。(JavaScript模拟perl的正则表达式) 正则表达式对象的属性 属性 含义 $1...$9 如果它(们)存在,是匹配到的子串 $_ 参见input $* 参见multiline $& 参见lastMatch $+ 参见lastParen $` 参见leftContext $''          参见rightContext constructor    创建一个对象的一个特殊的函数原型 global       是否在整个串中匹配(bool型) ignoreCase     匹配时是否忽略大小写(bool型) input        被匹配的串 lastIndex     最后一次匹配的索引 lastParen     最后一个括号括起来的子串 leftContext    最近一次匹配以左的子串 multiline     是否进<em>行</em>多<em>行</em>匹配(bool型) prototype     允许附加属性给对象 rightContext    最近一次匹配以右的子串 source       正则表达式模式 lastIndex     最后一次匹配的索引 正则表达式对象的方法 方法 含义 compile      正则表达式比较 exec        执<em>行</em>查找 test        进<em>行</em>匹配 toSource      返回特定对象的定义(literal representing),其值可用来创建一个新的对象。重载Object.toSource方法得到的。 toString      返回特定对象的串。重载Object.toString方法得到的。 valueOf      返回特定对象的原始值。重载Object.valueOf方法得到 例子 var myReg = /(w+)s(w+)/; var str = "John Smith"; var newstr = str.replace(myReg, "$2, $1"); document.write(newstr); 将输出"Smith, John" javascript正则表达式检验 /********************************************************************************* * EO_<em>JS</em>Lib.<em>js</em> * javascript正则表达式检验 **********************************************************************************/ //校验是否全由数字组成 function isDigit(s) { var patrn=/^[0-9]{1,20}$/; if (!patrn.exec(s)) return false return true } //校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串 function isRegisterUserName(s) { var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/; if (!patrn.exec(s)) return false return true } //校验用户姓名:只能输入1-30个以字母开头的字串 function isTrueName(s) { var patrn=/^[a-zA-Z]{1,30}$/; if (!patrn.exec(s)) return false return true } //校验密码:只能输入6-20个字母、数字、下划线 function isPasswd(s) { var patrn=/^(\w){6,20}$/; if (!patrn.exec(s)) return false return true } //校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-” function isTel(s) { //var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/; var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/; if (!patrn.exec(s)) return false return true } //校验手机号码:必须以数字开头,除数字外,可含有“-” function isMobil(s) { var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/; if (!patrn.exec(s)) return false return true } //校验邮政编码 function isPostalCode(s) { //var patrn=/^[a-zA-Z0-9]{3,12}$/; var patrn=/^[a-zA-Z0-9 ]{3,12}$/; if (!patrn.exec(s)) return false return true } //校验搜索关键字 function isSearch(s) { var patrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,./?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;'\,.?]{0,19}$/; if (!patrn.exec(s)) return false return true } function isIP(s) //by zergling { var patrn=/^[0-9.]{1,20}$/; if (!patrn.exec(s)) return false return true } 正则表达式regular expression详述(一) http://www.kymita.com/888.<em>asp</em> 2002-12-15 蓝箭工作室 正则表达式是regular expression,看来英文比中文要好理解多了,就是检查表达式符 不符合规定!!正则表达式有一个功能十分强大而又十分复杂的对象RegExp,在JavaScript1.2 版本以 上提供。 下面我们看看有关正则表达式的介绍: 正则表达式对象用来规范一个规范的表达式(也就是表达式符不符合特定的要求,比如是不是Email 地址格式等),它具有用来检查给出的字符串是否符合规则的属性和方法。 除此之外,你用RegExp构造器建立的个别正则表达式对象的属性,就已经预先定义好了正则表达式 对象的静态属性,你可以随时使用它们。 核心对象: 在JavaScript 1.2, NES 3.0以上版本提供。 在JavaScript 1.3以后版本增加了toSource方法。 建立方法: 文字格式或RegExp构造器函数。 文字建立格式使用以下格式: /pattern/flags即/模式/标记 构造器函数方法使用方法如下: new RegExp("pattern"[, "flags"])即new RegExp("模式"[,"标记"]) 参数: pattern(模式) 表示正则表达式的文本 flags(标记) 如果指定此项,flags可以是下面值之一: g: global match(全定匹配) i: ignore case(忽略大小写) gi: both global match and ignore case(匹配所有可能的值,也忽略大小写) 注意:文本格式中的参数不要使用引号标记,而构造器函数的参数则要使用引号标记。所以下面的 表达式建立同样的正则表达式: /ab+c/i    new RegExp("ab+c", "i") 描述: 当使用构造函数的时候,必须使用正常的字符串避开规则(在字符串中加入前导字符\ )是必须的。 例如,下面的两条语句是等价的: re = new RegExp("\\w+") re = /\w+/ 下面的提供了在正则表达式中能够使用的完整对特殊字符的一个完整的列表和描述。 表1.3:正则表达式中的特殊字符: 字符\ 意义:对于字符,通常表示按字面意义,指出接着的字符为特殊字符,\不作解释。 例如:/b/匹配字符'b',通过在b 前面加一个反斜杠\,也就是/\b/,则该字符变成特殊字符,表示 匹配一个单词的分界线。 或者: 对于几个字符,通常说明是特殊的,指出紧接着的字符不是特殊的,而应该按字面解释。 例如:*是一个特殊字符,匹配任意个字符(包括0个字符);例如:/a*/意味匹配0个或多个a。 为了匹配字面上的*,在a前面加一个反斜杠;例如:/a\*/匹配'a*'。 字符^ 意义:表示匹配的字符必须在最前边。 例如:/^A/不匹配"an A,"中的'A',但匹配"An A."中最前面的'A'。 字符$ 意义:与^类似,匹配最末的字符。 例如:/t$/不匹配"eater"中的't',但匹配"eat"中的't'。 字符* 意义:匹配*前面的字符0次或n次。 例如:/bo*/匹配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b',但不匹配"A goat g runted"中的任何字符。 字符+ 意义:匹配+号前面的字符1次或n次。等价于{1,}。 例如:/a+/匹配"candy"中的'a'和"caaaaaaandy."中的所有'a'。 字符? 意义:匹配?前面的字符0次或1次。 例如:/e?le?/匹配"angel"中的'el'和"angle."中的'le'。 字符. 意义:(小数点)匹配除换<em>行</em>符外的所有单个的字符。 例如:/.n/匹配"nay, an apple is on the tree"中的'an'和'on',但不匹配'nay'。 字符(x) 意义:匹配'x'并记录匹配的值。 例如:/(foo)/匹配和记录"foo bar."中的'foo'。匹配子串能被结果数组中的素[1], ..., [n] 返 回,或被RegExp对象的属性$1, ..., $9返回。 字符x|y 意义:匹配'x'或者'y'。 例如:/green|red/匹配"green apple"中的'green'和"red apple."中的'red'。 字符{n} 意义:这里的n是一个正整数。匹配前面的n个字符。 例如:/a{2}/不匹配"candy,"中的'a',但匹配"caandy," 中的所有'a'和"caaandy."中前面的两个 'a'。 字符{n,} 意义:这里的n是一个正整数。匹配至少n个前面的字符。 例如:/a{2,}不匹配"candy"中的'a',但匹配"caandy"中的所有'a'和"caaaaaaandy."中的所有'a' 字符{n,m} 意义:这里的n和m都是正整数。匹配至少n个最多m个前面的字符。 例如:/a{1,3}/不匹配"cndy"中的任何字符,但匹配 "candy,"中的'a',"caandy," 中的前面两个 'a'和"caaaaaaandy"中前面的三个'a',注意:即使"caaaaaaandy" 中有很多个'a',但只匹配前面的三 个'a'即"aaa"。 字符[xyz] 意义:一字符列表,匹配列出中的任一字符。你可以通过连字符-指出一个字符范围。 例如:[abcd]跟[a-c]一样。它们匹配"brisket"中的'b'和"ache"中的'c'。 字符[^xyz] 意义:一字符补集,也就是说,它匹配除了列出的字符外的所有东西。 你可以使用连字符-指出一 字符范围。 例如:[^abc]和[^a-c]等价,它们最早匹配"brisket"中的'r'和"chop."中的'h'。 字符[\b] 意义:匹配一个空格(不要与\b混淆) 字符\b 意义:匹配一个单词的分界线,比如一个空格(不要与[\b]混淆) 例如:/\bn\w/匹配"noonday"中的'no',/\wy\b/匹配"possibly yesterday."中的'ly'。 字符\B 意义:匹配一个单词的非分界线 例如:/\w\Bn/匹配"noonday"中的'on',/y\B\w/匹配"possibly yesterday."中的'ye'。 字符\cX 意义:这里的X是一个控制字符。匹配一个字符串的控制字符。 例如:/\cM/匹配一个字符串中的control-M。 字符\d 意义:匹配一个数字,等价于[0-9]。 例如:/\d/或/[0-9]/匹配"B2 is the suite number."中的'2'。 字符\D 意义:匹配任何的非数字,等价于[^0-9]。 例如:/\D/或/[^0-9]/匹配"B2 is the suite number."中的'B'。 字符\f 意义:匹配一个表单符 字符\n 意义:匹配一个换<em>行</em>符 字符\r 意义:匹配一个回车符 字符\s 意义:匹配一个单个white空格符,包括空格,tab,form feed,换<em>行</em>符,等价于[ \f\n\r\t\v]。 例如:/\s\w*/匹配"foo bar."中的' bar'。 字符\S 意义:匹配除white空格符以外的一个单个的字符,等价于[^ \f\n\r\t\v]。 例如:/\S/\w*匹配"foo bar."中的'foo'。 字符\t 意义:匹配一个制表符 字符\v 意义:匹配一个顶头制表符 字符\w 意义:匹配所有的数字和字母以及下划线,等价于[A-Za-z0-9_]。 例如:/\w/匹配"apple,"中的'a',"$5.28,"中的'5'和"3D."中的'3'。 字符\W 意义:匹配除数字、字母外及下划线外的其它字符,等价于[^A-Za-z0-9_]。 例如:/\W/或者/[^$A-Za-z0-9_]/匹配"50%."中的'%'。 字符\n 意义:这里的n是一个正整数。匹配一个正则表达式的最后一个子串的n的值(计数左圆括号)。 例如:/apple(,)\sorange\1/匹配"apple, orange, cherry, peach."中的'apple, orange',下面 有一个更加完整的例子。 注意:如果左圆括号中的数字比\n指定的数字还小,则\n取下一<em>行</em>的八进制escape作为描述。 字符\ooctal和\xhex 意义:这里的\ooctal是一个八进制的escape值,而\xhex是一个十六进制的escape值,允许在一个 正则表达式中嵌入ASCII码。 当表达式被检查的时候,文字符号提供了编辑正则表达式的方法。利用文字符号可以使到正则表达 式保持为常数。例如,如果你在一个循环中使用文字符号来构造一个正则表达式,正则表达式不需进<em>行</em> 反复编译。 正则表达式对象构造器,例如,new RegExp("ab+c"),提供正则表达式的运<em>行</em>时编译。当你知道正 则表达式的模式<em>会</em>变化的时候,应该使用构造函数,或者你不知道正则表达式的模式,而它们是从另外 的源获得的时候,比如由用户输入时。一旦你定义好了正则表达式,该正则表达式可在任何地方使用, 并且可以改变,你可以使用编译方法来编译一个新的正则表达式以便重新使用。 一个分离预先定义的RegExp对象可以在每个窗口中使用;也就是说,每个分离的JavaScript线程运 <em>行</em>以获得自己的RegExp对象。因为每个脚本在一个线程中是不可中断的,这就确保了不同的脚本不<em>会</em>覆 盖RegExp对象的值。 预定义的RegExp对象包含的静态属性:input, multiline, lastMatch,lastParen, leftContext, rightContext, 以及从$1到$9。input和multiline属性能被预设。其它静态属性的值是在执<em>行</em>个别正则 表达式对象的exec和test方法后,且在执<em>行</em>字符串的match和replace方法后设置的。 属性 注意RegExp对象的几个属性既有长名字又有短名字(象Perl)。这些名字都是指向相同的值。Perl是 一种编程语言,而JavaScript模仿了它的正则表达式。 属性$1, ..., $9 取得匹配的子串,如果有的话 属性$_ 参考input 属性$* 参考multiline 属性$& 参考lastMatch 属性$+ 参考lastParen 属性$` 参考leftContext 属性$' 参考rightContext 属性constructor 指定用来建立对象原型函 属性global 决定是否测试正则表达式是否不能匹配所有的字符串,或者只是与最先的冲突。 属性ignoreCase 决定试图匹配字符串的时候是否忽略大小写 属性input 当正则表达式被匹配的时候,为相反的字符串。 属性lastIndex 决定下一次匹配从那里开始 属性lastMatch 最后一个匹配的字符 属性lastParen 子串匹配的时候,最后一个parenthesized,如果有的话。 属性leftContext 最近一次匹配前的子串。 属性multiline 是否在串的多<em>行</em>中搜索。 属性prototype 允许附加属性到所有的对象 属性rightContext 最近一次匹配后的的子串。 属性source 模式文本 方法 compile方法 编译一个正则表达式对象 exec方法 运<em>行</em>正则表达式匹配 test方法 测试正则达式匹配 toSource方法 返回一个对象的文字描述指定的对象;你可以使用这个值来建立一个新的对象。不考虑Object.toS ource方法。 toString方法 返回一个字符串描述指定的对象,不考虑Object.toString对象。 valueOf方法 返回指定对角的原始值。不考虑Object.valueOf方法。  另外,这个对象继承了对象的watch和unwatch方法    例子:    例1、下述示例脚本使用replace方法来转换串中的单词。在替换的文本中,脚本使用全局 RegExp 对象的$1和$2属性的值。注意,在作为第二个参数传递给replace方法的时候,RegExp对象的$属性的名 称。 re = /(\w+)\s(\w+)/; str = "John Smith"; newstr=str.replace(re,"$2, $1"); document.write(newstr) 显示结果:"Smith, John".   例2、下述示例脚本中,RegExp.input由Change事件处理句柄设置。在getInfo函数中,exec 方法 使用RegExp.input的值作为它的参数,注意RegExp预置了$属性。 function getInfo(abc) { re = /(\w+)\s(\d+)/; re.exec(abc.value); window.alert(RegExp.$1 + ", your age is " + RegExp.$2); }   请输入你的姓和年龄,输入完后按回车键。       $1, ..., $9属性 用圆括号括着的匹配子串,如果有的话。 是RegExp的属性 静态,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述:因为input是静态属性,不是个别正则表达式对象的属性。你可以使用RegExp.input 访问该 属性。 能加上圆括号的子串的数量不受限制,但正则表达式对象只能保留最后9 条。如果你要访问所有的 圆括号内的匹配字串,你可以使用返回的数组。 这些属性能用在RegExp.replace方法替换后的字符串(输出结果)。当使用这种方式的时候,不用预 先考虑RegExp对象。下面给出例子。当正则表达式中没有包含圆括号的时候,该脚本解释成$n的字面意 义。(这里的n是一个正整数)。 例如: 下例脚本使用replace 方法来交换串中单词的位置。在替换后的文本字串中,脚本使用正则表达式 RegExp对象的$1和$2属性的值。注意:当它们向replace方法传递参数的时候,这里没有考虑 $ 属性的 RegExp对象的名称。 re = /(\w+)\s(\w+)/; str = "John Smith"; newstr=str.replace(re,"$2, $1"); document.write(newstr) 显示的输出结果为:Smith, John。 正则表达式regular expression详述(二) http://www.kymita.com/888.<em>asp</em> 2002-12-15 蓝箭工作室 正则表达式详述(二) 以下这些不是正则表达式的新增对象请参阅对应的JavaScript对象的属性 $_属性 参考input $*属性 参考multiline $&属性 参考lastMatch $+属性 参考lastParen $`属性 参考leftContext $'属性 参考rightContext compile方法 在脚本运<em>行</em>期间编译正则表达式对象 属于RegExp的方法 在JavaScript 1.2, NES 3.0以上版本提供 语法: regexp.compile(pattern[, flags]) 以数: regexp 正则表达式的名称,可以是变量名或文字串。 pattern 正则表达式的定义文本。 flags 如果指定的话,可以是下面其中的一个: "g": 匹配所有可能的字串 "i": 忽略大小写 "gi": 匹配所有可能的字串及忽略大小写 描述: 使用compile方法来编译一个正则表达式 created with the RegExp constructor function。这样 就强制正则表达式只编译一次,而不是每次遇到正则表达式的时候都编译一次。当你确认正则表达式能 保持不变的时候可使用compile 方法来编译它(在获得它的匹配模式后),这样就可以在脚本中重复多次使用它。 你亦可以使用compile 方法来改变在运<em>行</em>期间改变正则表达式。例如,假如正则表达式发生变化, 你可以使用compile方法来重新编译该对象来提高使用效率。 使用该方法将改变正则表达式的source, global和ignoreCasesource属性的值。 constructor 指出建立对象原型的function。注意这个属性的值由函数本身提供,而不是一个字串包含RegExp的name.Property提供。 在JavaScript 1.1, NES 2.0以上版本提供 ECMA版本ECMA-262 描述:参考Object.constructor. exec方法 在指定的字符串运<em>行</em>匹配搜索。返回一个结果数组。 是RegExp的方法 在JavaScript 1.2, NES 3.0以上版本提供 语法: regexp.exec([str])regexp([str]) 参数: regexp,正则表达式的名称,可以是一个变量名或文字定义串。 str,要匹配正则表达式的字符串,如果省略,将使用RegExp.input的值。 描述:就如在语法描述中的一样,正则表达工的exec方法能够被直接调用(使用regexp.exec(str))或者间接调用(使用regexp(str))。 假如你只是运<em>行</em>以找出是否匹配,可以使用String搜索方法。 假如匹配成功,exec方法返回一个数组并且更新正则表达式对象属性的值和预先定义的正则表达式对象、RegExp。如果匹配失败,exec方法返回null。 请看下例: //匹配一个b接着一个或多个d,再接着一个b //忽略大小写 myRe=/d(b+)(d)/ig; myArray = myRe.exec("cdbBdbsbz"); 下面是该脚本的返回值:对象 属性/Index 描述 例子 myArray myArray的内容 ["dbBd", "bB", "d"] index 基于0的匹配index 1 input 原始字符串 cdbBdbsbz [0] 最后匹配的字符 dbBd [1], ...[n] 用圆括号括住的匹配字符串,如果有的话。不限制括号的个数。 [1] = bB [2] = d myRe lastIndex 开始下次匹配操作的index值 5 ignoreCase 指出"i"是否使用以忽略大小写 true global 指出是否使用"g"标记来进<em>行</em>匹配所有可能的字串 true source 定义模式的文本字符串 d(b+)(d) RegExp lastMatch$& 最后匹配的字符 dbBd leftContext$\Q 最新匹配前面的子串 c rightContext$' 最新匹配后面的子串 bsbz $1, ...$9 圆括号内的匹配子串,如果有的话。圆括号的个数不受限制,但RegExp只能保留最后9个 $1 = bB $2 = d lastParen $+ 最后一个加上圆括号的匹配子串,如果有的话 d 假如你的正则表达式使用了"g"标记,你可以多次使用exec 方法来连续匹配相同的串。当你这样<em>做</em> 的时候,新的匹配将从由正则表达式的lastIndex 属性值确定的子串中开始。例如,假定你使用下面的脚本: myRe=/ab*/g;str = "abbcdefabh" myArray = myRe.exec(str); document.writeln("Found "+myArray[0]+". Next match starts at "+myRe.lastIndex) mySecondArray = myRe.exec(str); document.writeln("Found "+mySecondArray[0]+". Next match starts at "+myRe.lastIndex) 这个脚本显示如下结果: Found abb. Next match starts at 3 Found ab. Next match starts at 9 例子: 在下面的例子中,用户输入一个名字,脚本根据输入执<em>行</em>匹配操作。接着检查数组看是否和其它用户的名字匹配。 本脚本假定已注册的用户的姓已经存进了数组A中,或许从一个<em>数据</em>库中取得。 A = ["zhao","qian","sun","li","liang"] function lookup() { firstName = /\w+/i(); if (!firstName) window.alert (RegExp.input + "非法输入"); else { count=0; for (i=0;i 输入你的姓然后按回车键。 global属性 正则表达式中是否使用了"g"标记。 RegExp属性,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述: global是一个个别正则表达式对象的属性 如果使用了"g"标记,global的值为true;否则为 false。"g"标记指定正则表达式测试所有可能的匹配。 你不能直接改变该属性的值,但可以调用compile方法来改变它。 ignoreCase 检查正则表达式是否使用了"i"标记 RegExp属性,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述: ignoreCase是个别正则表达式对象的一个属性。 如果使用了"i"标记,则返回true,否则返回false。"i"标记指示在进<em>行</em>匹配的时候忽略大小写。 你不能直接改变该属性的值,但可以通过调用compile方法来改变它 input 指出正则表达式要测试那个字串。$_是这个属性的另一个名字。 RegExp的属性,静态 在JavaScript 1.2, NES 3.0以上版本提供 描述:因为input是静态的,不是某个个别的正则表达式对象的属性。你也可以使用 RegExp.input来表示。 如果没有给正则表达式的exec或test方法提供字符串,并且RegExp.input中有值,则使用它的值来调用该方法。 脚本或浏览器能够预置input属性。如果被预置了值且调用exec或 test方法的时候没有提供字符串 则调用exec或test的时候使用input的值。input可以被浏览器以下面的方式设置: 当text表单域处理句柄被调用的时候,input被设置为该text输入的字串。 当textarea表单域处理句柄被调用的时候,input被设置为textarea域内输入的字串。注意multili ne亦被设置成true从而能匹配多<em>行</em>文本。 当select表单域处理句柄被调用的时候,input被设置成selected text的值。 当链接对象的处理句柄被调用的时候,input被设置成和之间的字符串。 事件理现句柄处理完毕后,input属性的值被清除。 lastIndex 可读/可写的一个整数属性,指出下一次匹配从哪里开始。 RegExp的属性 在JavaScript 1.2, NES 3.0以上版本提供 描述:lastIndex 是个别的正则表达式对象的属性。 这个属性只有当正则表达式的"g"标记被使用以进<em>行</em>全串匹配的时候才被设置。实<em>行</em>以下规则: 如果lastIndex大小字符串的长度,regexp.test和regexp.exec失败,且lastIndex被设为0。 如果lastIndex等于字串的长度且正则表达式匹配空字符串,则正则表达式从lastIndex的位置开始匹配。 如果lastIndex等于字符串的长度且正则表达式不匹配空字符串,则正则表达式不匹配input,且lastIndex被置为0。 否则,lastIndex被设置成最近一次匹配的下一点。 例如,按下面的顺序执<em>行</em>脚本: re = /(hi)?/g 匹配空字符串 re("hi") 返回["hi", "hi"],lastIndex置为2 re("hi") 返回[""],一个空数组,它的下标为0的元素就是匹配字符串。在这种情况下,返回空 串是因为lastIndex等于2(且仍然是2),并且"hi"的长度也是2。 lastMatch 最后一次匹配字符串,$&是同样的意思。 RegExp的属性,静态,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述:因为lastMatch是静态的,所以它不是个别指定正则表达式的属性。你也可以使用RegExp.lastMatch。 lastParen 最后一次加上括号的匹配字符串,如果有的话。$+是同样的意思。 RegExp属性,静态,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述:因为lastParen是静态的,它不是某个个别正则式的属性,你可以使用RegExp.lastParen 表达同样的意思。 leftContext 最近一次匹配前面的子串,$`具有相同的意思。 RegExp的属性,静态,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述:因为leftContext是静态的,不是某一个正则表达式的属性,所以可以使用RegExp.leftContext来表达想同的意思。 multiline 反映是否匹配多<em>行</em>文本,$*是相同的意思。 RegExp的属性,静态 在JavaScript 1.2, NES 3.0以上版本提供 描述:因为multiline是静态的,而不是某个个别正则表达式的属性,所以能够用RegExp.multiline表达相同的意思。 如果允许匹配多<em>行</em>文本,则multiline为true,如果搜索必须在换<em>行</em>时停止,则为false。 脚本或浏览器能够设置multiline属性。当一个textarea的事件处理句柄被调用的时候,multiline 被置为true。在事件处理句柄处理完毕后,multiline属性值被清除。也就是说,如果你设置了multili ne为true,则执<em>行</em>任何的事件处理句柄后,multiline被置为false。 prototype 描绘类的原型。你可以根据要求使用prototype来增加类的属性或方法。为了获得prototypes 的资 料,请参阅RegExp的Function.prototype.Property属性。 从JavaScript 1.1, NES 2.0版本开始提供 ECMA版本ECMA-262 rightContext 最后一次匹配的右边的字符串,$'是同样的效果。 RegExp的属性,静态,只读 从 JavaScript 1.2, NES 3.0以上版本开始提供 描述:因为rightContext是静态的,不是某个个别正则表达工的属性,可以使用RegExp.rightContext来达到相同的效果。 source 一个只读属性,包含正则表达式定义的模式,不包侨forward slashes和"g"或"i"标记。 RegExp的属性,只读 从JavaScript 1.2, NES 3.0以上版本开始提供 描述:source是个别正则表达式对象的属性,你不能直接改变它的值,但可以通过调用compile 方法来改变它。 test 执<em>行</em>指定字符串的正则表达式匹配搜索,返回true或false。 RegExp的方法 从JavaScript 1.2, NES 3.0以上版本开始提供 语法:regexp.test([str]) 参数:regexp,正则表达式的名称,可以是变量名或正则表达式定义文字串 str,要匹配的字符串,如果省略,将使用RegExp.input的值为作参数 描述:当你需要知道一个字符串能否匹配某个正则表达工,可以使用test方法(与String.search方 法类似); 为了获得更多的信息(但速度将变慢),可以使用exec方法(与String.match方法类似)。 例子:下面的例子显示test是否成功的提示: function testinput(re, str){ if (re.test(str)) midstring = " contains "; else midstring = " does not contain "; document.write (str + midstring + re.source); } toSource 返回一个字符串象征对象的源码 RegExp的方法 从JavaScript 1.3以上版本开始提供 语法:toSource() 参数:没有 描述:toSource方法返回下述的值: 对于内置的RegExp对象,toSource返回下面的字符象征源码不可用: function Boolean(){ [native code] } 在RegExp场合中, toSource返回象征源码的字符串,通常这个方法是由JavaScript内部<em>自动</em>调用而不是不代码中显式调用。 更多请看Object.toSource toString 返回描绘指定对象的字符串。 RegExp的方法 从JavaScript 1.1, NES 2.0开始提供 ECMA版本ECMA-262 语法:toString() 参数:无 描述:RegExp对象不考虑Object对象的toString方法;它不继承Object.toString,对于RegExp 对 象,toString方法返回一个代表该对象的字符串。 例如:下面的例子显示象征RegExp对象的字符串 myExp = new RegExp("a+b+c"); alert(myExp.toString()) displays "/a+b+c/" 更多请看:Object.toString valueOf 返回一个RegExp对象的原始值 RegExp的方法 从JavaScript 1.1版本开始提供 ECMA版本:ECMA-262 语法:valueOf() 参数:无 描述:RegExp的valueOf方法以字符串形式返回RegExp对象的原始值,这个值与RegExp.toString相等。 该方法通常由JavaScript内部<em>自动</em>调用而不是显式调用 例子: myExp = new RegExp("a+b+c"); alert(myExp.valueOf()) displays "/a+b+c/" 正则表达式在javascript中的几个实例1(转) ! 去除字符串两端空格的处理 如果采用传统的方式,就要可能就要采用下面的方式了 //清除左边空格 function <em>js</em>_ltrim(deststr) { if(deststr==null)return ""; var pos=0; var retStr=new String(deststr); if (retStr.lenght==0) return retStr; while (retStr.substring(pos,pos+1)==" ") pos++; retStr=retStr.substring(pos); return(retStr); } //清除右边空格 function <em>js</em>_rtrim(deststr) { if(deststr==null)return ""; var retStr=new String(deststr); var pos=retStr.length; if (pos==0) return retStr; while (pos && retStr.substring(pos-1,pos)==" " ) pos--; retStr=retStr.substring(0,pos); return(retStr); } //清除左边和右边空格 function <em>js</em>_trim(deststr) { if(deststr==null)return ""; var retStr=new String(deststr); var pos=retStr.length; if (pos==0) return retStr; retStr=<em>js</em>_ltrim(retStr); retStr=<em>js</em>_rtrim(retStr); return retStr; } 采用正则表达式,来去除两边的空格,只需以下代码 String.prototype.trim = function() { return this.replace(/(^\s*)|(\s*$)/g, ""); } 一句就搞定了, 可见正则表达式为我们节省了相当的编写代码量 ! 移动手机号的校验 如果采用传统的校验方式至少就要完成下面三步的校验, (1). 是否是数字 (2).是否是11位 (3).数字的第三位是否是5,6,7,8,9 如果采用正则表达式校验,只需以下代码 function checkMobile1(form) { if (form.mobile.value > "") { var reg=/13[5,6,7,8,9]\d{8}/; if ( form.mobile.value.match(reg)== null) { alert("请输入正确的移动手机号码!"); form.mobile.focus(); return false; } } return true; } 从上面的代码可以看出校验移动手机号只需定义一个var reg=/13[5,6,7,8,9]\d{8}/;模式匹配串就可以完成合法性校验了 ! URL的校验, 条件:必须以http:// 或 https:// 开头, 端口号必须为在1-65535 之间, 以下代码完成了合法性校验 //obj:<em>数据</em>对象 //dispStr :失败提示内容显示字符串 function checkUrlValid( obj, dispStr) { if(obj == null) { alert("传入对象为空"); return false; } var str = obj.value; var urlpatern0 = /^https?:\/\/.+$/i; if(!urlpatern0.test(str)) { alert(dispStr+"不合法:必须以'http:\/\/'或'https:\/\/'开头!"); obj.focus(); return false; } var urlpatern2= /^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?.+$/i; if(!urlpatern2.test(str)) { alert(dispStr+"端口号必须为数字且应在1-65535之间!"); obj.focus(); return false; } var urlpatern1 =/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i; if(!urlpatern1.test(str)) { alert(dispStr+"不合法,请检查!"); obj.focus(); return false; } var s = "0"; var t =0; var re = new RegExp(":\\d+","ig"); while((arr = re.exec(str))!=null) { s = str.substring(RegExp.index+1,RegExp.lastIndex); if(s.substring(0,1)=="0") { alert(dispStr+"端口号不能以0开头!"); obj.focus(); return false; } t = parseInt(s); if(t65535) { alert(dispStr+"端口号必须为数字且应在1-65535之间!"); obj.focus(); return false; } } return true; } 对url的校验,看上去有很多的代码,这是因为要给予出错提示, 否则只需var urlpatern1 =/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i; 一句就可以校验出url合法性了 正则表达式在JavaScript应用 时间戳: 2004-11-30 15:29:30 人气: 23 作者: AnyRock 来源:www.mending.cn -------------------------------------------------------------- 去掉字符串头尾多余的空格 /g是全文查找所有匹配 function String.prototype.Trim(){return this.replace(/(^\s*)|(\s*$)/g, "");} function String.prototype.LTrim(){return this.replace(/(^\s*)/g, "");} function String.prototype.RTrim(){return this.replace(/(\s*$)/g, "");} -------------------------------------------------------------- 应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;} -------------------------------------------------------------- 应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下: String.prototype.trim = function() { return this.replace(/(^\s*)|(\s*$)/g, ""); } 得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1 s="http://www.9499.net/page1.htm" s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2") alert(s) ##利用正则表达式限制网页表单里的文本框输入内容: -------------------------------------------------------------- 用正则表达式限制只能输入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,'))" -------------------------------------------------------------- 用正则表达式限制只能输入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,'))" -------------------------------------------------------------- 用正则表达式限制只能输入数字:onkeyup="value=value.replace(/[^\d]/g,') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,'))" -------------------------------------------------------------- 用正则表达式限制只能输入数字和英文:onkeyup="value=value.replace(/[\W]/g,') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,'))" 用正则表达式和javascript对表单进<em>行</em>全面验证 代码:<!-- 使用时请将下面的javascript代码存到一个单一的<em>js</em>文件中。 1、表单要求 将对表单中的所有以下类型的域依次验证,所有验证是去除了前导和后缀空格的,要注意是区分大小写的。 2、空值验证 表单中任意域加上emptyInfo属性将对此域是否为空进<em>行</em>验证(可以和最大长度验证\一般验证方式同时使用)。 无此属性视为此域允许空值。    如: 3、最大长度验证(可以和空值验证、一般验证方式同时使用): 或, 3、一般验证方式(不对空值<em>做</em>验证):    如: 4、标准验证(不与其它验证方式同时使用): 全部通过来实现,并且不需要name属性以免提交到服务器。    4.1、合法日期验证: 注:这里也可以是,以下同 yearfieldName、monthfieldName、dayfieldName分别为年月日字段,月和日可以是两位(MM)或一位格式(M), 此处不对每个字段分别检验(如果要检验,请在年月日三个域分别使用前面的一般验证方式),只对日期的最大值是否合法检查; 4.2、日期格式验证(请注意,此验证不对日期是否有效进<em>行</em>验证,还未找到从格式中得到年月日<em>数据</em>的方法^_^): 其中格式仅对y、M、d、H、m、s进<em>行</em>支持(其它字符视为非时间的字符) 4.3、列表验证: 检验列表(checkbox、redio、select)是否至少选中了一条记录(对select主要用于多项选择) 其中validatorType可以是Checkbox、R、Select; 对于一个select表单,如果要求选择一条不能是第一条的记录,请用下列方式: ==请选择== 1 4.4、Email验证: 其中separator为可选项,表示输入多个email时的分隔符(无此选项只能是一个地址) 4.5、加入其它javascript操作: function functionname(){ 自定义方法 } 表单中加入(此时emptyInfo等属性无效) 时将调用function属性中指定的javascript方法(要求方法返回true或false,返回false将不再验证表单,也不提交表单)。 5、在表单通过验证提交前disable一个按钮(也可将其它域disable,不能与其它验证同在一个域),不要求按钮是表单中的最后一个 6、不验证表单    当validator域值为0时不对表单进<em>行</em>验证,直接提交表单或执<em>行</em>指定function并返回true后提交表单 functionName为可选 --> function getStringLength(str){ var endvalue=0; var sourcestr=new String(str); var tempstr; for (var strposition = 0; strposition 255 || tempstr.charCodeAt(0)<0) { endvalue=endvalue+2; } else { endvalue=endvalue+1; } } return(endvalue); } function trim(str){ if(str==null) return ""; if(str.length==0) return ""; var i=0,j=str.length-1,c; for(;i-1;j--){ c=str.charAt(j); if(c!=' ') break; } if(i>j) return ""; return str.substring(i,j+1); } function validateDate(date,format,alt){ var time=trim(date.value); if(time=="") return; var reg=format; var reg=reg.replace(/yyyy/,"[0-9]{4}"); var reg=reg.replace(/yy/,"[0-9]{2}"); var reg=reg.replace(/MM/,"((0[1-9])|1[0-2])"); var reg=reg.replace(/M/,"(([1-9])|1[0-2])"); var reg=reg.replace(/dd/,"((0[1-9])|([1-2][0-9])|30|31)"); var reg=reg.replace(/d/,"([1-9]|[1-2][0-9]|30|31))"); var reg=reg.replace(/HH/,"(([0-1][0-9])|20|21|22|23)"); var reg=reg.replace(/H/,"([0-9]|1[0-9]|20|21|22|23)"); var reg=reg.replace(/mm/,"([0-5][0-9])"); var reg=reg.replace(/m/,"([0-9]|([1-5][0-9]))"); var reg=reg.replace(/ss/,"([0-5][0-9])"); var reg=reg.replace(/s/,"([0-9]|([1-5][0-9]))"); reg=new RegExp("^"+reg+"$"); if(reg.test(time)==false){//验证格式是否合法 alert(alt); date.focus(); return false; } return true; } function validateDateGroup(year,month,day,alt){ var array=new Array(31,28,31,30,31,30,31,31,30,31,30,31); var y=parseInt(year.value); var m=parseInt(month.value); var d=parseInt(day.value); var maxday=array[m-1]; if(m==2){ if((y%4==0&&y0!=0)||y%400==0){ maxday=29; } } if(d>maxday){ alert(alt); return false; } return true; } function validateCheckbox(obj,alt){ var rs=false; if(obj!=null){ if(obj.length==null){ return obj.checked; } for(i=0;i<obj.length;i++){ if(obj[i].checked==true){ return true; } } } alert(alt); return rs; } function validateRadio(obj,alt){ var rs=false; if(obj!=null){ if(obj.length==null){ return obj.checked; } for(i=0;i<obj.length;i++){ if(obj[i].checked==true){ return true; } } } alert(alt); return rs; } function validateSelect(obj,alt){ var rs=false; if(obj!=null){ for(i=0;i<obj.options.length;i++){ if(obj.options[i].selected==true){ return true; } } } alert(alt); return rs; } function validateEmail(email,alt,separator){ var mail=trim(email.value); if(mail=="") return; var em; var myReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/; if(separator==null){ if(myReg.test(email.value)==false){ alert(alt); email.focus(); return false; } } else{ em=email.value.split(separator); for(i=0;i0&&myReg.test(em[i])==false){ alert(alt); email.focus(); return false; } } } return true; } function validateForm(theForm){// 若验证通过则返回true var disableList=new Array(); var field = theForm.elements; // 将表单中的所有元素放入数组 for(var i = 0; i field[i].maxLength){ alert(lengthInfo); field[i].focus(); return false; } var validatorType=field[i].validatorType; if(validatorType!=null){//其它javascript var rs=true; if(validatorType=="javascript"){ eval("rs="+field[i].functionName+"()"); if(rs==false){ return false; } else{ continue; } } else if(validatorType=="disable"){//提交表单前disable的按钮 disableList.length++; disableList[disableList.length-1]=field[i]; continue; } else if(validatorType=="Date"){ rs=validateDate(theForm.elements(field[i].fieldName),field[i].format,field[i].errorInfo); } else if(validatorType=="DateGroup"){ rs=validateDateGroup(theForm.elements(field[i].year),theForm.elements(field[i].month),theForm.elements(field[i].day),field[i].errorInfo); } else if(validatorType=="Checkbox"){ rs=validateCheckbox(theForm.elements(field[i].fieldName),field[i].errorInfo); } else if(validatorType=="Radio"){ rs=validateRadio(theForm.elements(field[i].fieldName),field[i].errorInfo); } else if(validatorType=="Select"){ rs=validateSelect(theForm.elements(field[i].fieldName),field[i].errorInfo); } else if(validatorType=="Email"){ rs=validateEmail(theForm.elements(field[i].fieldName),field[i].errorInfo); } else{ alert("验证类型不被支持, fieldName: "+field[i].name); return false; } if(rs==false){ return false; } } else{//一般验证 if(empty==false){ var v = field[i].validator; // 获取其validator属性 if(!v) continue; // 如果该属性不存在,忽略当前元素 var reg=new RegExp(v); if(reg.test(field[i].value)==false){ alert(field[i].errorInfo); field[i].focus(); return false; } } } } for(i=0;i<disableList.length;i++){ disableList[i].disabled=true; } return true; } </a></div><div data-report-view="{"mod":"popu_645","index":"5","dest":"https://download.csdn.net/download/a525235942/2284257","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" class="list-item" data-v-ca2d15ac><div class="recommend-title" data-v-ca2d15ac><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAltJREFUWEdjZGBgYGhv/yD45//nEEYGBrX//xj4QWK0AoxMDB//MzDcYmHkXVNZKfCeEWz5v8/1DP8ZuGhlKVZzGRm+sTDxNjI2tz1OZfjHYEpXy2GWMTGcZmxpe9xN62DH5TlQdDA2tzyeNSC+h1o66gCyQyApUdRNSIhNGBSS7979ejtv/utd5EQl2Q7IypT0ExJiFoc44O/LadOfbxp1wPAOAWlpdr5Pn//8/Pzp70+QT3GlAX5+ZnYeHhb2p09/fiImRIhOhBYWvIo21ryWu/Z8PHDp4tdn2BxgoM8l4+IiYH/k6OdjJ058vk91B7g487swMDD8v3Hj+2VJSTYpfn5mEZAlHz/9ffPq5e+Xqqoc2iD+nr0f99DSAQQ9RhMHcHAwsYSGCtvKy7Gr4HPBo0c/b69c/fbwzx///hJ0KQMDA9FpAGaYizO/tpkZjwUTEyMTsgX//v3/d/LUl+N79368RozFMDUkOwCkUUODU8zHW9CFg4OJG8T/8ePf181b3u25efPHK1IsB6nF6gAjY25ZEWFWcNPs169/fw4c+HQD3WBBIRaOsBAhZ5D4qjXv9r5/9+cHuhoHBz4NNjYmFpD4m7e/P547+/UxuhqsDoiPE3WWlWVXgvju/5ee3qfLsfmMiZmBEST+7y/Df2zyJcXSkRwcjDwgucePf95buOj1Xqo6gFBwDw8H/P/P8O/nz//fCPkWmzw7OyMXIyMDOLeQHQXkWIxNz9BygJubgI6kBCu4tUMt8PzF75e7dn24QlQuoJalxJgzCDomA901G/DOKSieBrJ7DgCPdYFAskV/NwAAAABJRU5ErkJggg==" alt data-v-ca2d15ac> <a target="_blank" href="https://download.csdn.net/download/a525235942/2284257" data-report-click="{"mod":"popu_645","index":"5","dest":"https://download.csdn.net/download/a525235942/2284257","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="title" data-v-ca2d15ac>网管教程 从入门到精通软件篇.txt</a></div> <a target="_blank" href="https://download.csdn.net/download/a525235942/2284257" data-report-click="{"mod":"popu_645","index":"5","dest":"https://download.csdn.net/download/a525235942/2284257","strategy":"2~default~OPENSEARCH~Rate","extra":"{\"utm_medium\":\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\",\"dist_request_id\":\"1713939179176_97254\"}","spm":"1035.2023.3001.6557"}" data-report-query="spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default" class="desc" data-v-ca2d15ac>网管教程 从入门到精通软件篇 ★一。★详细的xp修复控制台命令和用法!!! 放入xp(2000)的光盘,安装时候选R,修复! Windows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令<em>做</em>个总结,这次辛苦老范给我们整理了这份实用的秘笈。   Bootcfg   bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。   含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。   用法:   bootcfg /default  设置默认引导项。   bootcfg /add    向引导列表中<em>添加</em> Windows 安装。   bootcfg /rebuild  重复全部 Windows 安装过程并允许用户选择要<em>添加</em>的内容。   注意:使用 bootcfg /rebuild 之前,应先通过 bootcfg /copy 命令备份 boot.ini 文件。   bootcfg /scan    扫描用于 Windows 安装的所有磁盘并显示结果。   注意:这些结果被静态存储,并用于本次<em>会</em>话。如果在本次<em>会</em>话期间磁盘配置发生变化,为获得更新的扫描,必须先重新启动计算机,然后再次扫描磁盘。   bootcfg /list   列出引导列表中已有的条目。   bootcfg /disableredirect 在启动引导程序中禁用重定向。   bootcfg /redirect [ PortBaudRrate] |[ useBiosSettings]   在启动引导程序中通过指定配置启用重定向。   范例: bootcfg /redirect com1 115200 bootcfg /redirect useBiosSettings   hkdsk   创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。   含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。   vol [drive:] [ chkdsk [drive:] [/p] [/r]   参数  无   如果不带任何参数,chkdsk 将显示当前驱动器中的磁盘状态。 drive: 指定要 chkdsk 检查的驱动器。 /p   即使驱动器不在 chkdsk 的检查范围内,也执<em>行</em>彻底检查。该参数不对驱动器<em>做</em>任何更改。 /r   找到坏扇区并恢复可读取的信息。隐含着 /p 参数。   注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)中找到该文件,将试着在 Windows 安装 CD 中找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 Diskpart   创建和删除硬盘驱动器上的分区。diskpart 命令仅在使用故障恢复控制台时才可用。   diskpart [ /add |/delete] [device_name |drive_name |partition_name] [size]   参数 无   如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。   /add   创建新的分区。   /delete   删除现有分区。   device_name   要创建或删除分区的设备。设备名称可从 map 命令的输出获得。例如,设备名称:   DeviceHardDisk0   drive_name   以驱动器号表示的待删除分区。仅与 /delete 同时使用。以下是驱动器名称的范例:   D:   partition_name   以分区名称表示的待删除分区。可代替 drive_name 使用。仅与 /delete 同时使用。以下是分区名称的范例:   DeviceHardDisk0Partition1    大小   要创建的分区大小,以兆字节 (MB)表示。仅与 /add 同时使用。   范例   下例将删除分区: diskpart /delete Device HardDisk0 Partition3 diskpart /delete F:   下例将在硬盘上<em>添加</em>一个 20 MB 的分区:   diskpart /add Device HardDisk0 20   Fixboot </a></div></div></div></div> <div class="public_pc_right_footer2020" style="display:none;" data-v-4a5a7f56></div></div> <div id="right-floor-user-content_562" data-editor="{"type":"floor","pageId":143,"floorId":562}" class="user-right-floor right-box main-box detail-user-right" data-v-229a00b0><div class="__vuescroll" style="height:100%;width:100%;padding:0;position:relative;overflow:hidden;"><div class="__panel __hidebar" style="position:relative;box-sizing:border-box;height:100%;overflow-y:hidden;overflow-x:hidden;transform-origin:;transform:;"><div class="__view" style="position:relative;box-sizing:border-box;min-width:100%;min-height:100%;"><!----><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="introduce" data-v-4722a3ae><div class="introduce-title" data-v-4722a3ae><div class="img-info" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/ASP" class="community-img" data-v-4722a3ae><img src="https://img-community.csdnimg.cn/avatar/ad08cc95e8b74fc1b22d8708cf8764f6.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt data-v-4722a3ae> <div title="ASP" class="community-name" data-v-4722a3ae> ASP </div></a></div></div> <div class="content" data-v-4722a3ae><div class="detail" data-v-4722a3ae><div title="28391" class="item" data-v-4722a3ae><p class="num" data-v-4722a3ae> 28,391 </p> <p class="desc" data-v-4722a3ae> 社区成员 </p></div> <div title="357060" class="item" data-v-4722a3ae><a href="https://bbs.csdn.net/forums/ASP" target="_blank" data-v-4722a3ae><p class="num" data-v-4722a3ae> 357,060 </p> <p class="desc" data-v-4722a3ae> 社区内容 </p></a></div></div> <div class="detail-btns" data-v-4722a3ae><div class="community-ctrl-btns_wrapper" data-v-0ebf603c data-v-4722a3ae><div class="community-ctrl-btns" data-v-0ebf603c><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-160be461 data-v-0ebf603c><div data-report-click="{"spm":"3001.5975"}" data-v-160be461><img src="https://csdnimg.cn/release/cmsfe/public/img/topic.427195d5.png" alt="" class="img sendTopic" data-v-160be461 data-v-0ebf603c> <span data-v-160be461 data-v-0ebf603c>发帖</span></div> <!----> <!----></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/me.40a70ab0.png" alt="" class="img me" data-v-0ebf603c> <span data-v-0ebf603c>与我相关</span></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/task.87b52881.png" alt="" class="img task" data-v-0ebf603c> <span data-v-0ebf603c>我的任务</span></div></div><div class="community-ctrl-btns_item" data-v-0ebf603c><div class="community-share" data-v-4ca34db9 data-v-0ebf603c><div class="handle-item share" data-v-ca030a68 data-v-4ca34db9><span height="384" data-v-ca030a68><div role="tooltip" id="el-popover-1412" aria-hidden="true" class="el-popover el-popper popo share-popover" style="width:265px;display:none;"><!----><div id="tool-QRcode" class="QRcode" data-v-ca030a68><img src="https://csdnimg.cn/release/cmsfe/public/img/shareBg2.05330abf.png" alt="" class="share-bg" data-v-ca030a68> <div class="share-bg-box" data-v-ca030a68><div class="share-content" data-v-ca030a68><img src="https://img-community.csdnimg.cn/avatar/ad08cc95e8b74fc1b22d8708cf8764f6.png?x-oss-process=image/resize,m_fixed,h_88,w_88" alt="" class="share-avatar" data-v-ca030a68> <div class="share-tit" data-v-ca030a68>ASP</div> <div class="share-dec" data-v-ca030a68>ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。</div> <span class="copy-share-url" data-v-ca030a68>复制链接</span> <div class="shareText" data-v-ca030a68> </div></div> <div class="share-code" data-v-ca030a68><div class="qrcode" data-v-ca030a68></div> <div class="share-code-text" data-v-ca030a68>扫一扫</div></div></div></div> </div><span class="el-popover__reference-wrapper"><div data-v-0ebf603c><img src="https://csdnimg.cn/release/cmsfe/public/img/share-circle.3e0b7822.png" alt="" class="img share" data-v-0ebf603c> <span data-v-0ebf603c>分享</span></div></span></span></div> <!----></div></div></div> <!----> <div data-v-4fb59baf data-v-0ebf603c><div class="el-dialog__wrapper ccloud-pop-outer2" style="display:none;" data-v-4fb59baf><div role="dialog" aria-modal="true" aria-label="dialog" class="el-dialog el-dialog--center" style="margin-top:15vh;width:70%;"><div class="el-dialog__header"><span class="el-dialog__title"></span><!----></div><!----><div class="el-dialog__footer"><span class="dialog-footer clearfix" data-v-4fb59baf><div class="confirm-btm fr" data-v-4fb59baf>确定</div></span></div></div></div></div></div></div></div> <div style="display:none;" data-v-4722a3ae data-v-4722a3ae><!----> <div class="introduce-desc" data-v-4722a3ae><div class="introduce-desc-title" data-v-4722a3ae>社区描述</div> <span data-v-4722a3ae> ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。 </span></div></div> <div class="introduce-text" data-v-4722a3ae><div class="label-box" data-v-4722a3ae><!----> <!----> <!----></div></div> <!----> <div class="manage" data-v-4722a3ae><div class="manage-inner" data-v-4722a3ae><span data-v-4722a3ae>社区管理员</span> <ul data-v-4722a3ae><li data-v-4722a3ae><a href="https://blog.csdn.net/community_24" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/default.jpg!1" alt="ASP" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li><li data-v-4722a3ae><a href="https://blog.csdn.net/sysdzw" target="_blank" class="start-img" data-v-4722a3ae><img src="https://profile-avatar.csdnimg.cn/45dcec50fd694b578374e7167ff7914a_sysdzw.jpg!1" alt="无·法" class="el-tooltip item" data-v-4722a3ae data-v-4722a3ae></a></li></ul></div></div> <div class="actions" data-v-4722a3ae><!----> <div style="flex:1;" data-v-4722a3ae><div class="join-btn" data-v-4722a3ae> 加入社区 </div></div> <!----> <!----></div> <div class="el-dialog__wrapper" style="display:none;" data-v-38c57799 data-v-4722a3ae><div role="dialog" aria-modal="true" aria-label="获取链接或二维码" class="el-dialog join-qrcode-dialog" style="margin-top:15vh;width:600px;"><div class="el-dialog__header"><span class="el-dialog__title">获取链接或二维码</span><button type="button" aria-label="Close" class="el-dialog__headerbtn"><i class="el-dialog__close el-icon el-icon-close"></i></button></div><!----><div class="el-dialog__footer"><span class="dialog-footer" data-v-38c57799></span></div></div></div> <div class="collapse-btn" data-v-4722a3ae><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAgCAYAAACFM/9sAAAAAXNSR0IArs4c6QAAAi1JREFUaEPtl01u01AUhc+N8wMSO4AxzJAqwQpKQsdtbMOICmKnwCKQ2ACDIgotrYKiduIiVZ10B0CBAjtAbICfooomJr3IcUoTiVLb15GNuG/67nm65/M5AxP0iAiQSK1iKEBhCBSgAhQSEMo1gQpQSEAo1wQqQCEBoVwT+K8CnLnWvER8cOHMaf95q9Xaj+vDtp3LPeD83u6p9a2t+U5cfVrzmSTQNOfOgg4+ATDAeNHp/Jza3Fz5HtWUZbl3GXjYn2e+53lL96Nq057LBOD0dOOcUSx8BFAcGHpZLlWmVlfnd08yaJrubRAe/Z77HwEG5kdS1E8StgFc9bzFb8dBrNtukxgLwOAXNEF6T/pAce8zSeDhknXbuUNMQRUHe/BrMNX+BNGyHIdBT45m6VVn36/FqX5cOFHmMwUYJrE5x+CgkuEujLe+361ubLS+HhowzeYtEC8NzWyXy5ValMpHgSCZyRxgsLxpui4Ij4/ShZ1S0aiurS18sSznJoOeDt29AaP6t6pLgMTV5gJgsHTddhvEWBwC9Y6AZww8AFA4Lp1xDac9nxuAYZ37aQuqGgIbPTt+t3tluNppw0jyXq4AhnV2ZkG0PAKR8b5UMiaDSicxOU5N7gCGSXRvMLAygPgB3Jv0vOXP4wSR9O1cAgzMzFxvXDR6hYlK5cd6u93eS2pw3LrcAhy38bTeV4BCkgpQAQoJCOWaQAUoJCCUawIVoJCAUK4JVIBCAkL5L1yapyGdIBwvAAAAAElFTkSuQmCC" alt data-v-4722a3ae></div></div><!----><!----><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="floor-user-right-rank" data-v-3d3affee><div class="el-tabs el-tabs--top" data-v-3d3affee><div class="el-tabs__header is-top"><div class="el-tabs__nav-wrap is-top"><div class="el-tabs__nav-scroll"><div role="tablist" class="el-tabs__nav is-top" style="transform:translateX(-0px);"><div class="el-tabs__active-bar is-top" style="width:0px;transform:translateX(0px);ms-transform:translateX(0px);webkit-transform:translateX(0px);"></div></div></div></div></div><div class="el-tabs__content"><div role="tabpanel" id="pane-integral" aria-labelledby="tab-integral" class="el-tab-pane" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-3" aria-labelledby="tab-3" class="el-tab-pane" style="display:none;" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-5" aria-labelledby="tab-5" class="el-tab-pane" style="display:none;" data-v-3d3affee></div><div role="tabpanel" aria-hidden="true" id="pane-6" aria-labelledby="tab-6" class="el-tab-pane" style="display:none;" data-v-3d3affee></div></div></div> <div class="floor-user-right-rank-score" data-v-608528ce data-v-3d3affee><div class="floor-user-right-rank-score-tabs" data-v-608528ce><ul data-v-608528ce><li data-v-608528ce> 近7日 </li><li data-v-608528ce> 近30日 </li><li class="active" data-v-608528ce> 至今 </li></ul></div> <div class="floor-user-right-rank-common" data-v-46cf600d data-v-608528ce><div class="rank-list" data-v-46cf600d><!----> <div class="no-data loading" data-v-46cf600d><i class="el-icon-loading" data-v-46cf600d></i> <p data-v-46cf600d>加载中</p></div> <!----> <a href="https:///ASP/rank/list/total" target="_blank" class="show-more" data-v-46cf600d> 查看更多榜单 </a></div></div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="floor comunity-rule" data-v-3cfa4dbd><div class="title" data-v-3cfa4dbd> 社区公告 </div> <div class="contain" data-v-3cfa4dbd><div class="inner-content" data-v-3cfa4dbd>暂无公告</div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="user-right-adimg empty-arr" data-v-15c6aa4f><div class="adImgs" data-v-2a6389b9 data-v-15c6aa4f><!----> <div data-v-2a6389b9><div data-v-2a6389b9></div></div></div></div><div comp-data="[object Object]" baseInfo="[object Object]" community="[object Object]" class="content-right-recommend" data-v-0f781e88><div data-v-3798762e data-v-0f781e88><!----> <!----></div></div><div comp-data="[object Object]" baseInfo="[object Object]" typePage="detail" community="[object Object]" class="ai-entrance" data-v-eb1c454c><p data-v-eb1c454c>试试用AI创作助手写篇文章吧</p> <div class="entrance-btn-line" data-v-eb1c454c><a href="https://mp.csdn.net/edit?guide=1" target="_blank" data-report-click="{"spm":"3001.9712"}" data-report-query="spm=3001.9712" class="entrance-btn" data-v-eb1c454c>+ 用AI写文章</a></div></div></div></div></div></div></div></div></div></div></div></div></div> <div> <script type="text/javascript" src="https://g.csdnimg.cn/common/csdn-footer/csdn-footer.js" data-isfootertrack="false" defer></script> </div></div></div><script> window.__INITIAL_STATE__= {"csrf":"1JjKRKoC-z87J5_HpNtz7Qwb2APgtUCsNlSc","origin":"http:\u002F\u002Fbbs.csdn.net","isMobile":false,"cookie":"uuid_tt_dd=10_3097079930-1713939179138-859379;","ip":"18.117.196.217","pageData":{"page":{"pageId":143,"title":"社区详情","keywords":"社区详情","description":"社区详情","ext":{"isMd":"true","armsfe1":"{pid:\"dyiaei5ihw@1a348e4d05c2c78\",appType:\"web\",imgUrl:\"https:\u002F\u002Farms-retcode.aliyuncs.com\u002Fr.png?\",sendResource:true,enableLinkTrace:true,behavior:true}","redPacketCfg":"{\"presetTitle\":[\"成就一亿技术人!\",\"大吉大利\",\"节日快乐\",\"Bug Free\",\"Hello World\",\"Be Greater Than Average!!\"],\"defaultTitle\":\"成就一亿技术人!\",\"preOpenSty\":{},\"redCardSty\":{}}","blogStar":"[{\"year\":\"2021\",\"enable\":true,\"communityIds\":[3859],\"url\":\"https:\u002F\u002Fbbs.csdn.net\u002Fsummary2021\"},{\"year\":\"2022\",\"enable\":true,\"communityIds\":[3860],\"url\":\"https:\u002F\u002Fbbs.csdn.net\u002Fsummary2022\"}]","mdVersion":"https:\u002F\u002Fcsdnimg.cn\u002Frelease\u002Fmarkdown-editor\u002F1.1.0\u002Fmarkdown-editor.js","componentSortCfg":"{ \"right\":[\"ratesInfo\",\"cty-profile\",\"pub-comp\",\"user-right-introduce\",\"post-event\",\"my-mission\",\"user-recommend\",\"user-right-rank\",\"user-right-rule\",\"user-right-adimg\"] }","show_1024":"{\"enable\":false,\"useWhitelist\":false,\"whitelist\":[76215],\"home\":\"https:\u002F\u002F1111.csdn.net\u002F\",\"logo\":\"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221104102741.png\",\"hideLive\":true}","iframes":"[\"3859\"]","pageCfg":"{\"disableDownloadPDF\": false,\"hideSponsor\":false}"}},"template":{"templateId":71,"templateComponentName":"ccloud-detail","title":"ccloud-detail","floorList":[{"floorId":562,"floorComponentName":"floor-user-content","title":"社区详情页","description":"社区详情页","indexOrder":3,"componentList":[{"componentName":"baseInfo","componentDataId":"cloud-detail1","componentConfigData":{},"relationType":3},{"componentName":"user-right-introduce","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-recommend","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-rank","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-rule","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"user-right-adimg","componentDataId":"","componentConfigData":{},"relationType":2},{"componentName":"default2014LiveRoom","componentDataId":"20221024DefaultLiveRoom","componentConfigData":{},"relationType":3}]}]},"data":{"baseInfo":{"customDomain":"","uriName":"ASP","communityHomePage":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP","owner":{"userName":"community_24","nickName":"ASP","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","position":"","companyName":""},"user":{"userRole":3,"userName":null,"nickName":null,"avatarUrl":null,"rank":null,"follow":2,"communityBase":null,"joinCollege":null,"isVIP":null},"community":{"name":"ASP","description":"ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。","avatarUrl":"https:\u002F\u002Fimg-community.csdnimg.cn\u002Favatar\u002Fad08cc95e8b74fc1b22d8708cf8764f6.png?x-oss-process=image\u002Fresize,m_fixed,h_88,w_88","qrCode":"","createTime":"2007-09-28","communityAvatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","communityNotice":null,"userCount":28391,"contentCount":357060,"followersCount":19106,"communityRule":"","communityId":143,"bgImage":"","hashId":"o3noovng","domain":"","uriName":"ASP","externalDisplay":1,"adBanner":{"img":"","url":"","adType":0,"adCon":null},"rightBanner":{"img":"","url":"","adType":0,"adCon":null},"tagId":null,"tagName":null,"communityType":1,"communityApplyUrl":"https:\u002F\u002Fmarketing.csdn.net\u002Fquestions\u002FQ2106040308026533763","joinType":0,"visibleType":0,"collapse":0,"topicMoveAble":0,"allowActions":{},"communityOwner":"community_24","tagNameInfo":{"provinceTag":null,"areaTag":null,"technologyTags":null,"customTags":null}},"tabList":[{"tabId":1302,"tabName":"全部","tabUrl":"","tabSwitch":1,"tabType":4,"tabContribute":0,"cardType":0,"indexOrder":-1,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP?typeId=1302","iframe":false,"sortType":1},{"tabId":4057698,"tabName":"博文收录","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":19,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP?typeId=4057698","iframe":false,"sortType":1},{"tabId":1617830,"tabName":"Ada助手","tabUrl":"","tabSwitch":1,"tabType":2,"tabContribute":0,"cardType":0,"indexOrder":20,"url":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP?typeId=1617830","iframe":false,"sortType":1}],"dataResource":{"mediaType":"c_cloud","subResourceType":"8_c_cloud_long_text","showType":"long_text","tabId":0,"communityName":"ASP","communityHomePageUrl":"https:\u002F\u002Fbbs.csdn.net\u002Fforums\u002FASP","communityType":1,"content":{"id":"392175119","contentId":392175119,"cateId":0,"cateName":null,"url":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F392175119","shareUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F392175119","createTime":"2017-06-01 10:18:34","updateTime":"2021-05-28 20:13:31","resourceUsername":"fszyhzg","best":0,"top":0,"text":null,"publishDate":"2017-06-01","lastReplyDate":"2017-06-05","type":"13","nickname":"狐猫","avatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","username":"fszyhzg","commentCount":8,"diggNum":0,"digg":false,"viewCount":427,"hit":false,"resourceSource":6,"status":10,"taskStatus":null,"expired":false,"taskCate":0,"taskAward":0,"taskExpired":null,"checkRedPacket":null,"avgScore":0,"totalScore":0,"topicTitle":"asp+js做的动态添加数据行,为何数据表会自动多添加一空白行","insertFirst":false,"likeInfo":null,"description":"前台代码: 件数: 单件重量 总重量 操作 \u003Ctr style=\"display:none\" id=\"trUserInfo\" align=\"center\" bgcolor=\"#FFFFFF\"","coverImg":"https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221027062552.png","content":"前台代码:\u003Cbr \u002F\u003E\n<table width="99%" border="0" id="tabUserInfo" cellpadding="0" cellspacing="1">\u003Cbr \u002F\u003E\n \t<tr class="bb02" align="center">\u003Cbr \u002F\u003E\n<td>件数:<\u002Ftd>\u003Cbr \u002F\u003E\n<td>单件重量<\u002Ftd>\u003Cbr \u002F\u003E\n<td>总重量<\u002Ftd>\u003Cbr \u002F\u003E\n<td>操作<\u002Ftd>\u003Cbr \u002F\u003E\n<\u002Ftr>\u003Cbr \u002F\u003E\n<tr style="display:none" id="trUserInfo" align="center" bgcolor="#FFFFFF"> \u003Cbr \u002F\u003E\n<td id="tdUserInfo" bgcolor="#FFFFFF"><input id="dhsl" name="dhsl" value="<%=dhsl%>" type="text"><\u002Ftd> \u003Cbr \u002F\u003E\n<td id="tdUserInfo" bgcolor="#FFFFFF"><input id="dhck" name="dhck" value="<%=dhck%>" type="text"><\u002Ftd> \u003Cbr \u002F\u003E\n<td id="tdUserInfo" bgcolor="#FFFFFF"><input id="xlh" name="xlh" value="<%=xlh%>" type="text"><\u002Ftd>\u003Cbr \u002F\u003E\n<td id="tdUserInfo" bgcolor="#FFFFFF"><input type="button" value="删除" onclick="deleteRow(document.all.tabUserInfo,1,this)"><\u002Ftd> \u003Cbr \u002F\u003E\n<\u002Ftr>\u003Cbr \u002F\u003E\n<tr><td id="tdUserInfo"><input type="button" value="新增" onclick="addRow(document.all.tabUserInfo,null,1,1)" class="submit1"><\u002Ftd><\u002Ftr>\u003Cbr \u002F\u003E\n <\u002Ftable>\u003Cbr \u002F\u003E\n后台代码:\u003Cbr \u002F\u003E\n'------------------------------添加和修改信息部分--------------------------------------\u003Cbr \u002F\u003E\nmoduleid=0\u003Cbr \u002F\u003E\nif request("moduleid")<>"" then\u003Cbr \u002F\u003E\nmoduleid=cint(request("moduleid"))\u003Cbr \u002F\u003E\nend if\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nconn.beginTrans ' Start a transaction \u003Cbr \u002F\u003E\nsql = "insert into rc_qt(sbmc,txm) values('"& request("sbmc") &"','"& request("txm") &"')" \u003Cbr \u002F\u003E\nconn.execute(sql) \u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nif request("dhsl").count>0 then \u003Cbr \u002F\u003E\ndim maxid \u003Cbr \u002F\u003E\nmaxid = 1\u003Cbr \u002F\u003E\nsql = "select max(qtid) as maxid from rc_qt" \u003Cbr \u002F\u003E\nset rs = conn.execute(sql) \u003Cbr \u002F\u003E\nmaxid = rs("maxid") \u003Cbr \u002F\u003E\nrs.close \u003Cbr \u002F\u003E\nset rs = nothing \u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\nfor i =1 to request("dhsl").count \u003Cbr \u002F\u003E\nsql = "insert into rc_qtt(qtid,dhsl,dhck,xlh) values("& maxid &",'"& request("dhsl")(i) &"','"& request("dhck")(i) &"','"& request("xlh")(i) &"')" \u003Cbr \u002F\u003E\nconn.execute(sql) \u003Cbr \u002F\u003E\nnext \u003Cbr \u002F\u003E\nend if \u003Cbr \u002F\u003E\n以上代码就是点击保存后sql数据表会自动多增加了一行,但我明明只增加两行,现在变成三行,求高手们指教","mdContent":null,"pictures":null,"videoInfo":null,"linkInfo":null,"student":{"isCertification":false,"org":"","bala":""},"employee":{"isCertification":false,"org":"","bala":"系统开发"},"userCertification":[],"dependId":"0","dependSubType":null,"videoUrl":null,"favoriteCount":0,"favoriteStatus":false,"taskType":null,"defaultScore":null,"syncAsk":false,"videoPlayLength":null},"communityUser":null,"allowPost":false,"submitHistory":[{"user":{"registerurl":"https:\u002F\u002Fg.csdnimg.cn\u002Fstatic\u002Fuser-reg-year\u002F1x\u002F15.png","avatarurl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","nickname":"狐猫","selfdesc":"大智若愚","createdate":"2009-09-25 09:45:00","days":"5326","years":"15","username":"fszyhzg","school":null,"company":null,"job":null},"userName":"fszyhzg","event":"创建了帖子","body":"2017-06-01 10:18","editId":null}],"resourceExt":{}},"contentReply":{"pageNo":1,"pageSize":20,"totalPages":1,"totalCount":8,"total":0,"list":[{"hit":null,"hitMsg":null,"content":"保存的时候验证附表table中的值,要是为空则跳过,不为空就保存。","topicTitle":null,"description":"保存的时候验证附表table中的值,要是为空则跳过,不为空就保存。","id":402402060,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"happybebe","userNickName":"华丽丽的小低调","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F3f0abe4c4203404bb6f9f1eb6d9e1631_happybebe.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2004569611,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-05 10:28:35","updateTime":"2017-06-05 11:15:08","formatTime":"2017-06-05","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"原来真的是隐藏了一行呀\n<tr style="display:none" id="trUserInfo" align="center" bgcolor="#FFFFFF">\n\n新增按钮的代码:\n<td id="tdUserInfo"><input type="button" value="新增" onClick="addRow(document.all.tabUserInfo,null,1,1)" class="submit1"><\u002Ftd>\n","topicTitle":null,"description":"原来真的是隐藏了一行呀 \u003Ctr style=\"display:none\" id=\"trUserInfo\" align=\"center\" bgcolor=\"#FFFFFF\"\u003E 新增按钮的代码: \u003Ctd id=\"tdUserInfo\"\u003E\u003Cinput type=\"button\" value=\"新增\" onClick=\"addRow(document.all.tabUserInfo,null,1,1)\" class=\"submit1\"\u003E\u003C\u002Ftd\u003E ","id":402403494,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"fszyhzg","userNickName":"狐猫","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2091692037,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-05 04:16:29","updateTime":"2017-06-05 04:48:21","formatTime":"2017-06-05","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"请问怎么写代码呀------ “保存的时候验证附表table中的值,要是为空则跳过,不为空就保存。”\n我的保存代码是:\n<%\nif request("tj")="保 存" then \n set rs=server.CreateObject("adodb.RecordSet")\n strsql="select * from rc_qtt"\n rs.open strsql,conn,2,3\n for i =1 to request("dhsl").count \n rs.addnew()\n rs("dhsl")=request("dhsl")(i)\n rs("dhck")=request("dhck")(i)\n rs("xlh")=request("xlh")(i)\n rs("name")=request("name")(i)\n rs("sex")=request("sex")(i)\n rs.update\n next\n end if\n%>","topicTitle":null,"description":"请问怎么写代码呀------ “保存的时候验证附表table中的值,要是为空则跳过,不为空就保存。” 我的保存代码是: \u003C% if request(\"tj\")=\"保 存\" then set rs=server.CreateObject(\"adodb.RecordSet\") strsql=\"select * from rc_qtt\" rs.open strsql,conn,2,3 for i =1 to request(\"dhsl\").count rs.addnew() rs(\"dhsl\")=re","id":402403215,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"fszyhzg","userNickName":"狐猫","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2091692037,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-05 03:24:59","updateTime":"2017-06-05 03:43:28","formatTime":"2017-06-05","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"在前台点击新增时后台数据表是没有新增行的,只有前台点击保存后才会在数据表新增,因为是两个数据表,一个主表,另一个副表,有id关联的,主表是前台数据字段,副表是前台新增那里的数据字段,一保存两表同时新增并关联","topicTitle":null,"description":"在前台点击新增时后台数据表是没有新增行的,只有前台点击保存后才会在数据表新增,因为是两个数据表,一个主表,另一个副表,有id关联的,主表是前台数据字段,副表是前台新增那里的数据字段,一保存两表同时新增并关联","id":402398394,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"fszyhzg","userNickName":"狐猫","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2091692037,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-02 04:01:34","updateTime":"2017-06-02 04:11:05","formatTime":"2017-06-02","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"你可以加个判断试试。\n加一个保存按钮\n保存时间 进行遍历table\n如果table 某一字段是空的不允许保存\n你点新增一行应该是前台新增了一行tr,并没有在数据表插入一条记录把?","topicTitle":null,"description":"你可以加个判断试试。 加一个保存按钮 保存时间 进行遍历table 如果table 某一字段是空的不允许保存 你点新增一行应该是前台新增了一行tr,并没有在数据表插入一条记录把?","id":402393834,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"happybebe","userNickName":"华丽丽的小低调","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F3f0abe4c4203404bb6f9f1eb6d9e1631_happybebe.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2004569175,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-01 11:50:47","updateTime":"2017-06-01 12:18:16","formatTime":"2017-06-01","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"我是参照http:\u002F\u002Fwww.jb51.net\u002Farticle\u002F72775.htm来做的\u003Cbr \u002F\u003E\n\u003Cimg src=\"https:\u002F\u002Fimg-bbs.csdn.net\u002Fupload\u002F201706\u002F01\u002F1496283624_806258.jpg\" alt=\"\" \u002F\u003E\u003Cbr \u002F\u003E\n\u003Cbr \u002F\u003E\n数据表就是多增加了一行\u003Cbr \u002F\u003E\n\u003Cimg src=\"https:\u002F\u002Fimg-bbs.csdn.net\u002Fupload\u002F201706\u002F01\u002F1496283610_931081.jpg\" alt=\"\" \u002F\u003E\u003Cbr \u002F\u003E\n","topicTitle":null,"description":"我是参照http:\u002F\u002Fwww.jb51.net\u002Farticle\u002F72775.htm来做的 数据表就是多增加了一行 ","id":402393343,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"fszyhzg","userNickName":"狐猫","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2091692037,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-01 10:20:26","updateTime":"2017-06-01 10:40:24","formatTime":"2017-06-01","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"以下是新增行的js代码:\nfunction addRow(tabObj,colNum,sorPos,targPos){ \nvar nTR = tabObj.insertRow(tabObj.rows.length-targPos); \u002F\u002F Insert a new row into appointed table on the \n\u002F\u002Fappointed position. \nvar TRs = tabObj.getElementsByTagName('TR'); \u002F\u002F Get TRs collection from the appointed table \nvar sorTR = TRs[sorPos]; \u002F\u002F Positioned the sorTR \nvar TDs = sorTR.getElementsByTagName('TD'); \u002F\u002F Get TDs collection from the appointed row \nif(colNum==0 || colNum==undefined || colNum==isNaN){ \ncolNum=tabObj.rows[0].cells.length; \n} \n\nvar ntd = new Array(); \u002F\u002F Create a new TDs array \nfor(var i=0; i< colNum; i++){ \u002F\u002F Traverl the TDs in row \nntd[i] = nTR.insertCell(); \u002F\u002F Create new cell \nntd[i].id = TDs[0].id; \u002F\u002F copy the TD's id to new cell. | Attention! The TDs's \n\u002F\u002Fsuffix must be appointed \nntd[i].innerHTML = TDs[i].innerHTML; \u002F\u002F copy the value in ntd[i]'s innerHTML from corresponding TDs \n} \n\n} \n\u002F**\u002F\u002F* This function is use to remove appointed row in appointed table \n* tabObj: the appointed table \n* targPos: target row position \n* btnObj: currently clicked delete image button \n* \n*\u002F \nfunction deleteRow(tabObj,targPos,btnObj){ \u002F\u002FRemove table row \nfor(var i =0; i<tabObj.rows.length;i++){ \nif(tabObj.getElementsByTagName('img')[i]==btnObj){ \ntabObj.deleteRow(i+targPos); \n} \n} \n} ","topicTitle":null,"description":"以下是新增行的js代码: function addRow(tabObj,colNum,sorPos,targPos){ var nTR = tabObj.insertRow(tabObj.rows.length-targPos); \u002F\u002F Insert a new row into appointed table on the \u002F\u002Fappointed position. var TRs = tabObj.getElementsByTagName('TR'); \u002F\u002F Get TRs collecti","id":402394465,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"fszyhzg","userNickName":"狐猫","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2091692037,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-01 02:53:35","updateTime":"2017-06-01 03:02:03","formatTime":"2017-06-01","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null},{"hit":null,"hitMsg":null,"content":"前台页面是有代码先隐藏一行的,但这代码是没错的呀","topicTitle":null,"description":"前台页面是有代码先隐藏一行的,但这代码是没错的呀","id":402394344,"contentResourceId":392175119,"bindContentResourceId":0,"communityId":143,"username":"fszyhzg","userNickName":"狐猫","userAvatar":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F02b9ee31142c482995bafd807fc5b6d0_fszyhzg.jpg!1","mdContent":null,"parentId":0,"replyName":"","replyNickName":"","bizNo":"bbs","ip":2091692037,"status":10,"childCount":0,"topStatus":0,"recommendStatus":0,"userLike":false,"diggCount":0,"childIds":"","createTime":"2017-06-01 02:25:37","updateTime":"2017-06-01 03:02:10","formatTime":"2017-06-01","userRoleHonorary":{"userName":null,"roleId":null,"roleType":null,"roleStatus":null,"honoraryId":null,"roleName":null,"honoraryName":null,"communityNickname":null,"communitySignature":null},"child":null,"communityNickname":null,"communityReplyNickname":null,"rewardInfo":null,"checkRedPacketVO":null,"noDiggCount":null}],"maxPageSize":3000},"defaultActiveTab":1302,"recommends":[{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657","title":"Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet v2.2.1 (2009-4-1) 值得一看","desc":"Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet v2.2.1\n\t\nExt\u003Cem\u003EAsp\u003C\u002Fem\u003ENet是一组专业的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件库,拥有原生的AJAX支持和丰富的UI效果,\n目标是创建没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。\n\n支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+\n\n注:Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet基于一些开源的程序Ext\u003Cem\u003EJS\u003C\u002Fem\u003E, HtmlAgilityPack, Nii.\u003Cem\u003EJS\u003C\u002Fem\u003EON, YUICompressor。\n\n示例: http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003E.net\u002F\n开源: http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003Enet.codeplex.com\u002F\n博客: http:\u002F\u002Fsanshi.cnblogs.com\u002F\n邮箱: sanshi.ustc@gmail.com\n\n\n发布历史:\n\n+2010-03-28 v2.2.1\n\t+为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首页最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本v3.1.1。\n\t\t-增加一个新的Theme - Access。\n\t\t-修正了Firefox下Zoom In\u002FOut时页面消失的BUG。\n\t\t-删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。\n\n\n\n+2010-01-31 v2.2.0\n\t-使得\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件ImageButton具有和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的Button控件类似的\u003Cem\u003E行\u003C\u002Fem\u003E为(Ajax提交)(feedback:261629698)。\n\t+TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件\u003Cem\u003E动态\u003C\u002Fem\u003E增加删除Tab。\n\t\t-增加示例tabstrip\u002Ftabstrip_addtab.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window控件更新。\n\t\t-关闭按钮默认直接关闭,不\u003Cem\u003E会\u003C\u002Fem\u003E弹出确认对话框。\n\t\t-GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居中,而不是黄金分割位置。\n\t+Button, Window等控件弹出位置属性的变化。\n\t\t-Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target=\"_self\" -\u003E Target=\"Self\", Target=\"_parent\" -\u003E Target=\"Parent\"。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。\n\t\t-Confirm.GetShowReference的最后一个参数target变为枚举类型。\n\t\t-Alert.GetShowReference中的showInParent参数也变为Target枚举类型。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。\n\n\n\n+2010-01-06 v2.1.9\n\t-集成Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本v3.1.0。\n\t-修正灰色皮肤的CSS问题。\n\t-修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button控件将不再\u003Cem\u003E自动\u003C\u002Fem\u003E拥有display:inline属性,如果希望两个按钮在一\u003Cem\u003E行\u003C\u002Fem\u003E显示,请为第一个按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。\n\t-增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。\n\t-修正HtmlEditor不能编辑的BUG(feedback:TheBox)。\n\t-修正IE下有时\u003Cem\u003E会\u003C\u002Fem\u003E出现空白页面的情况(feedback:olivia919)。\n\t\n\t\n\n+2009-12-06 v2.1.8\n\t-修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。\n\t-修正了IE下Grid中的一个\u003Cem\u003EJS\u003C\u002Fem\u003E问题(feedback:lqm4108)。\n\t-修正Alert消息中引号未编码导致的\u003Cem\u003EJS\u003C\u002Fem\u003E错误(feedback:sun1299shine)。\n\t+集成ext\u003Cem\u003Ejs\u003C\u002Fem\u003E3.0.3。\n\t\t-修正弹出对话框的宽度计算错误(\u003Cem\u003E会\u003C\u002Fem\u003E保持最小的状态)。\n\t\t-增加新的皮肤Gray。\n\t-为示例工程\u003Cem\u003E添加\u003C\u002Fem\u003E改变语言和皮肤的下拉列表。\n\t-为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。\t\n\n\n\n+2009-12-01 v2.1.7\n\t-增加示例(iframe\u002Fparent_postback_run3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex),如何通过简单的Javascript代码回发父页面(feedback:eroach)。\n\t-修正一些书写错误(feedback:bmck)。\n\t-从Region控件中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。\n\t-BorderPanel更名为RegionPanel。\n\t-DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。\n\t-增加中国的省市县三级联动示例(data\u002Fshengshixian.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的Tab在切换过程中\u003Cem\u003E会\u003C\u002Fem\u003E重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。\n\t-修正了启用AutoPostBack的Grid,其RowClick\u003Cem\u003E会\u003C\u002Fem\u003E覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。\n\t\n\t\n\t\n+2009-11-26 v2.1.6\n\t+修正\u003Cem\u003E动态\u003C\u002Fem\u003E创建Grid列的BUG(feedback:gxpan)。\n\t\t-增加示例(data\u002Fgrid_dynamic_columns.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的实现,避免选中某项后的闪烁。\n\t\t\t\n\n\n+2009-11-21 v2.1.5\n\t+Tree优化。\n\t\t-修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。\n\t\t-GetNodeById更名为FindNode,保持和FindControl一致命名。\n\t\t-删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。\n\t\t-删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。\n\t\t-增加示例(data\u002Ftree_select_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet中的一个命名约定。\n\t\t\t-同时更名的还有GridColumn的ColumnId-\u003EColumnID,GetColumnId-\u003EGetColumnID。\n\t\t\t-Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。\n\t\t-为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。\n\t-为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#处理函数来响应键盘事件。\n\t-为Tree增加AutoLeafIdentification属性。\n\t\t-增加示例(tree_auto_leaf_identification.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:wdrabbit)。\n\t\n\t\n\n+2009-11-17 v2.1.4\n\t-修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。\n\t-部分Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件的设计时支持(\u003Cem\u003E会\u003C\u002Fem\u003E在后续版本中逐步完善)。\n\t-v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运\u003Cem\u003E行\u003C\u002Fem\u003E时是否保持状态没有关系。\n\t-修正CheckBox控件的CheckedChanged事件\u003Cem\u003E会\u003C\u002Fem\u003E被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:form\u002Fform_validate.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的控件属性列表(\u002Fajax.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet支持原生的AJAX,也就是说控件的属性改变在AJAX过程中\u003Cem\u003E会\u003C\u002Fem\u003E反映到页面中,但并不是所有的控件属性都支持AJAX改变。\n\t-加载s.gif图片在本机进\u003Cem\u003E行\u003C\u002Fem\u003E,不\u003Cem\u003E会\u003C\u002Fem\u003E请求ext\u003Cem\u003Ejs\u003C\u002Fem\u003E.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮控件仍然具有AJAX的特性。\n\t-更新\u002Fbasic\u002Flogin.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例,使用验证图片(feedback:kedee)。\n\t-为Grid增加AutoPostBack属性和RowClick事件,示例在\u002Fdata\u002Fgrid_autopostback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(feedback:chenguizhu2006)。\n\t-为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。\n\t-Grid中TemplateField生成到页面中控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。\n\t\t-如果Panel具有IconUrl属性,则IconUrl优先于Icon。\n\t\t-所有Icon的列表在icon.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。\n\t\n\t\n\n+2009-09-15 v2.1.1\n\t-修正不能\u003Cem\u003E动态\u003C\u002Fem\u003E修改AccordionPane属性Items的BUG。\n\t+为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。\n\t\t-如果需要在父页面弹出确认对话框,需要设置ConfirmTarget=\"_parent\"(类似Window控件的Target=\"_parent\")。\n\t+为Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-一个典型应用,在Window控件中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert.Show(\"参数错误!\", String.Empty, Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以\u003Cem\u003E自动\u003C\u002Fem\u003E回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件\u003Cem\u003E数据\u003C\u002Fem\u003E类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003E.net\u002Fdata\u002Ftree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选中任何一项时在父页面弹出对话框的\u003Cem\u003EJS\u003C\u002Fem\u003E代码。\n\t-修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。\n\t-\u003Cem\u003E添加\u003C\u002Fem\u003E定时器控件Timer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree控件的AJAX实现。\n\t+为页面的Form\u003Cem\u003E添加\u003C\u002Fem\u003Eautocomplete=\"off\"属性。\n\t\t-参考http:\u002F\u002Fwww.cnblogs.com\u002Fsanshi\u002Farchive\u002F2009\u002F09\u002F04\u002F1560146.html#1635830\n\t+\u003Cem\u003E添加\u003C\u002Fem\u003E对ext\u003Cem\u003Ejs\u003C\u002Fem\u003E3.0中所有语言的支持。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet扩展的多语言包在\u003Cem\u003Ejs\u003C\u002Fem\u003E\\languages\\ext\u003Cem\u003Easp\u003C\u002Fem\u003Enet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其中\u003Cem\u003E添加\u003C\u002Fem\u003E自己的语言版本,并执\u003Cem\u003E行\u003C\u002Fem\u003E\u003Cem\u003Ejs\u003C\u002Fem\u003E\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert\u003Cem\u003E添加\u003C\u002Fem\u003E两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。\n\t+在\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面中必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将\u003Cem\u003E会\u003C\u002Fem\u003E影响所有的\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在\u003Cem\u003EAsp\u003C\u002Fem\u003E.net AJAX中使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将\u003Cem\u003E会\u003C\u002Fem\u003E影响所有的\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree控件的一个BUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。\n\t -这个BUG导致\u003Cem\u003EAsp\u003C\u002Fem\u003E.net compatibility中的示例无法完成,现在已经修正。\n\t+去除PageManager中方法AddAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls,增加属性Ajax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls。\n\t -这个属性和Button得ValidateForms属性类似,可以查看\u003Cem\u003EAsp\u003C\u002Fem\u003E.net compatibility中的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。\n -增加示例-如何将Grid控件导出为Excel(data\\grid_excel_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不\u003Cem\u003E会\u003C\u002Fem\u003E被选中(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。\n +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。\n\t\t-简单方便,示例可以参考 default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex 或者 other\\accordion_tree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n \n \n\n+2009-08-14 v2.0.6\n\t-\u003Cem\u003E动态\u003C\u002Fem\u003E生成菜单实例(other\\menu_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和other\\menu_dynamic2_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:shguo)。\n\t-优化AJAX的内部实现,每个页面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId\u003Cem\u003E自动\u003C\u002Fem\u003E生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的提交按钮兼容问题(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮AJAX提交,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们\u003Cem\u003E做\u003C\u002Fem\u003E了优化,现在要使一个\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮能够AJAX提交,你不需要\u003Cem\u003E做\u003C\u002Fem\u003E任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件了。\n\t\t-在Page_Load中设置了哪些需要在AJAX中更新的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件\u003Cem\u003E会\u003C\u002Fem\u003E在回发时保持状态,可以通过RemoveAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls来去除不需要更新的控件。\n\t\t-示例在\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\fckeditor_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\\u003Cem\u003Easp\u003C\u002Fem\u003Enet_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t\t-FCKEditor和上传控件兼容。示例在\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\fileupload_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-修正ToolbarText的文本在AJAX下更新的BUG。\n\t-Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。\n\t-更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。\n\t\n\n\n+2009-08-02 v2.0 beta4\n\t+和\u003Cem\u003EAsp\u003C\u002Fem\u003E.Net的Forms Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和\u003Cem\u003EAsp\u003C\u002Fem\u003E.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.PageContext.Redirect重定向页面,两者效果一样。\n\t\t-支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。\n\t-Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。\n\t-修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。\n\t-修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。\n\t-增加Menu和Accordion的示例。\n\t-修正Window控件的IconUrl有时不显示(Target=\"_parent\")的BUG[feedback:xmq&mgzhenhong]。\n\t\n\n\n+2009-07-22 v2.0 beta3\n\t-兼容FCKEditor。\n\t-在IE8.0,Firefox3.5下测试通过。以后Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet将不\u003Cem\u003E会\u003C\u002Fem\u003E对IE6.0提供支持。\n\t\n\n\n+2009-07-13 v2.0 beta2\n\t-集成ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本v3.0。\n\t+兼容IE6.0-7.0-8.0。\n\t\t-这应该是Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();\u003Cem\u003E会\u003C\u002Fem\u003E导致button的click事件无法响应(IE8下无此问题)。\n\t\t-目前先禁用IE6.0-7.0的QuickTips。\n\t-优化底层JavaScript。\n\t\n\t\n\t\n+2009-07-05 v2.0 beta1\n\t-更新ext\u003Cem\u003Ejs\u003C\u002Fem\u003E库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet自身的CSS\u003Cem\u003E会\u003C\u002Fem\u003E紧挨着页面\u003Ctitle\u003E标签引入,这样在\u003Chead\u003E中自定义的样式可以覆盖Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet缺省样式。\n\t+Alert对话框\u003Cem\u003E会\u003C\u002Fem\u003E遮挡所有的Window窗口。\n\t\t-使用一个变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。\t\n\t-为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。\n\t-因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。\n\t-重新绑定模拟树的下拉列表后,选中项的前面有图片的HTML标签的BUG。\n\t-更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。\n\t-更新示例工程。\n\t\n\t\n\n+2009-03-25 v1.3.1\n\t-Tree在AJAX回发展开节点时\u003Cem\u003EJS\u003C\u002Fem\u003E错误[feedback:xlli]。[fixed]\n\t-Window中的EnableIFrame==false,则点击关闭按钮时报\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例\u003Cem\u003Easp\u003C\u002Fem\u003Enet\u002Ffileupload.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t-HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed]\n\t\n\t\n\n+2009-03-03 v1.3.0\n\t-如果弹出的窗口(Ext-Window)含有\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件FileUpload,则此弹出窗口在关闭时出现\u003Cem\u003EJS\u003C\u002Fem\u003E错误(http:\u002F\u002Fext\u003Cem\u003Ejs\u003C\u002Fem\u003E.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果页面中存在\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件(TextBox),则第二次提交表单就\u003Cem\u003E会\u003C\u002Fem\u003E报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed]\n\t-页面上放置Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet-Button和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET-Button,则点击Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet-Button时激发的是\u003Cem\u003EASP\u003C\u002Fem\u003E.NET-Button的事件,这个BUG和Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed]\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet内部包含HtmlAgilityPack和Nii.\u003Cem\u003EJS\u003C\u002Fem\u003EON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet工程中使用\u003Cem\u003EASP\u003C\u002Fem\u003E.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET标准控件和平共处了。[fixed]\n\t\t-如果一个\u003Cem\u003EASP\u003C\u002Fem\u003E.NET按钮控件要使用Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的原生AJAX回发时更新\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:\u003Cem\u003Easp\u003C\u002Fem\u003Enet\u002F\u003Cem\u003Easp\u003C\u002Fem\u003Enet.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed]\n\t-\u003Cem\u003E自动\u003C\u002Fem\u003E测试功能\u003Cem\u003E会\u003C\u002Fem\u003E在以后版本中逐步完善。这个版本完成测试框架,采用Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E中\u003Cem\u003EJS\u003C\u002Fem\u003E函数进\u003Cem\u003E行\u003C\u002Fem\u003E大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference\u002FGetConfirmFormModifiedCloseRefreshReference\u002FGetConfirmFormModifiedClosePostBackReference三个方法代替。\n\t\t-不\u003Cem\u003E会\u003C\u002Fem\u003E修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面\u003Cem\u003E添加\u003C\u002Fem\u003Ebox_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的\u003Cem\u003EJS\u003C\u002Fem\u003E方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的\u003Cem\u003EASP\u003C\u002Fem\u003EX页面中查找RegisterPageStateChangedScript属性,并删除,否则\u003Cem\u003E会\u003C\u002Fem\u003E运\u003Cem\u003E行\u003C\u002Fem\u003E错误!\n\t\t-A页面有Ext-Window控件弹出B页面,B页面有Ext-Window控件弹出C页面,B页面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C页面)\u003Cem\u003E会\u003C\u002Fem\u003E覆盖整个A页面,这是正确的。\n\t\t---当时如果用户直接访问B页面,就\u003Cem\u003E会\u003C\u002Fem\u003E报\u003Cem\u003EJS\u003C\u002Fem\u003E错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不\u003Cem\u003E会\u003C\u002Fem\u003E出错了。\n\t\t-Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。\n\t\t---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window控件的关闭按钮\u003Cem\u003E添加\u003C\u002Fem\u003E关闭后刷新父页面或者关闭后回发父页面的\u003Cem\u003E行\u003C\u002Fem\u003E为。\n\t\t-如果弹出窗口(Window控件)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮\u003Cem\u003E会\u003C\u002Fem\u003E报\u003Cem\u003EJS\u003C\u002Fem\u003E错误,因为此时页面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window控件的IFrameName属性是\u003Cem\u003E自动\u003C\u002Fem\u003E生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。\n\t\t-CurrentActiveWindow改名为ActiveWindow。\n\t\t-[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values)\n\t\t---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel中内容不能\u003Cem\u003E自动\u003C\u002Fem\u003E扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的\u003Cem\u003E数据\u003C\u002Fem\u003E[feedback:huihuang]。[fixed]\n\t-DropDownList在页面第一次加载时没有不可选择项,则回发时也不\u003Cem\u003E会\u003C\u002Fem\u003E有不可选择项的BUG。[fixed]\n\t-升级底层Ext\u003Cem\u003EJS\u003C\u002Fem\u003E类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed]\n\t-页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added]\n\t+增加部分\u003Cem\u003E自动\u003C\u002Fem\u003E测试支持(使用WatiN和NUnit),下个版本将\u003Cem\u003E会\u003C\u002Fem\u003E提供完整的\u003Cem\u003E自动\u003C\u002Fem\u003E测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed]\n\t-Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed]\n\t+PageContext优化。[fixed]\n\t\t-去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。\n\t\t-去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。\n\t\t-Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image控件增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包中增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed]\n\t-ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed]\n\t-Row和Column布局时,修正IE下设置RowHeight=\"100%\"时显示不正确的BUG。[fixed]\n\t-AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed]\n\t+TabStrip的Tab控件的EnablePostBack属性\u003Cem\u003E会\u003C\u002Fem\u003E在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都\u003Cem\u003E会\u003C\u002Fem\u003E回发)。[fixed]\n\t\t-有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后\u003Cem\u003E会\u003C\u002Fem\u003E回发Tab1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用控件的站点必须建立虚拟目录,否则\u003Cem\u003E会\u003C\u002Fem\u003E报\u003Cem\u003EJS\u003C\u002Fem\u003E错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-\u003Cem\u003Easp\u003C\u002Fem\u003Enet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemText\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。\n\t\t\t-和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string text, string value),这样方便后台\u003Cem\u003E添加\u003C\u002Fem\u003E列表项。\n\t-处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003E自动\u003C\u002Fem\u003E设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有控件属性增加在VS中的智能提示。[fixed]\n\t\t-需要将Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.XML和Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.dll放在一起,这样引用dll时xml\u003Cem\u003E会\u003C\u002Fem\u003E被拷贝到bin目录下,提供VS的智能提示。\n\t+控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed]\n\t\t-TriggerIconType.Default -\u003E TriggerIconType.None\n\t\t-SystemIconType.Empty -\u003E SystemIconType.None\n\t\t-RegexPattern.USER_DEFINED -\u003E RegexPattern.None\n\t-表单验证属性名称变化(ValueToCompare-\u003ECompareValue,ControlToCompare-\u003ECompareControl)。[fixed]\n\t+注意:一个属性可以拥有多个值的情况。[fixed]\n\t\t-属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。\n\t\t-其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。\n\t+AccordionLink实现为控件。[fixed]\n\t\t-可以方便的在子页面(iframe)中通过\u003Cem\u003Ejs\u003C\u002Fem\u003E切换父页面中选中的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的\u003Cem\u003E动态\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E控件,并且可以给控件\u003Cem\u003E添加\u003C\u002Fem\u003E服务器端事件(示例在form\u002Fform_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-10-15 v1.2 beta5\n\t-验证表单字段的ValueToCompare属性,为字符串时\u003Cem\u003E会\u003C\u002Fem\u003E出错的BUG。[fixed]\n\t+优化下拉列表。[fixed]\n\t\t-验证下拉列表时,应该取ListItem的Value属性进\u003Cem\u003E行\u003C\u002Fem\u003E验证,而不是Text属性。\n\t\t-DropDownList的Items增加Insert方法(可方便的下拉列表选项\u003Cem\u003E添加\u003C\u002Fem\u003E“全部”)。\n\t\t-DropDownList不支持EmptyText属性。\n\t\t-ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(\u003Cem\u003EASP\u003C\u002Fem\u003EX)中设置哪些项不可选择,以及创建模拟下拉树。\n\t\t-DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则\u003Cem\u003E自动\u003C\u002Fem\u003E将EnableSimulateTree设置为true。\n\t\n\t\n\n+2008-09-27 v1.2 beta4\n\t+EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只\u003Cem\u003E会\u003C\u002Fem\u003E改变Accordion的标题大小,而不\u003Cem\u003E会\u003C\u002Fem\u003E对AccordionPanel起作用(示例见other\u002Faccordion_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。\n\t\t-影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。\n\t-AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed]\n\t+AccordionPanel增加Links属性,可以绑定列表\u003Cem\u003E数据\u003C\u002Fem\u003E到AccordionPanel,呈现的是链接的列表(示例在other\u002Faccordion_links_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上\u003CItems\u003E标签。\n\t\t-适当增大AccordionPanel中链接的高度20px-\u003E22px,同时对链接的样式也\u003Cem\u003E做\u003C\u002Fem\u003E了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少\u003Cem\u003EASP\u003C\u002Fem\u003EX中HTML代码和Javascript代码的书写,可以在后台\u003Cem\u003E动态\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在\u003Cem\u003EASP\u003C\u002Fem\u003EX页切换到“设计时”,方便属性的更改和事件处理函数的\u003Cem\u003E添加\u003C\u002Fem\u003E)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-TabStrip\u002FToolbar\n\t-TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向Form中\u003Cem\u003E动态\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E控件的BUG,现在form\u002Fform_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例已经能正确运\u003Cem\u003E行\u003C\u002Fem\u003E。[fixed]\n\t+大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的控件包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimpleForm\u002FWindow等。\n\t\t-保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留TabStrip的Tabs(TabCollection)属性。\n\t\t-保留PageLayout\u002FBorderLayout的Regions(RegionCollection)属性。\n\t-预祝今晚神七发射成功。\n\t\n\t\n\t\n+2008-09-22 v1.2 beta2\n\t+Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进\u003Cem\u003E行\u003C\u002Fem\u003E多次删除\u003Cem\u003E添加\u003C\u002Fem\u003E操作后,SelectedRowIndexArray选中项中\u003Cem\u003E会\u003C\u002Fem\u003E存在当前不存在的\u003Cem\u003E行\u003C\u002Fem\u003E序号,导致服务器端遍历选中项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例中表单控件都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimpleForm\u002FButton\u002FHyperLink\u002FLabel\u002FImage\u002FLinkButton\u002FTextBox\n\t\t-TriggerBox\u002FTwinTriggerBox\u002FWindow\u002FTextArea\u002FHtmlEditor\u002FDatePicker\u002FNumberBox\n\t\t-CheckBox\u002FRadioButton\u002FRadioButtonList\u002FDropDownList\n\t\t-Grid\n\n\n\n+2008-09-19 v1.2 beta1\n\t-Image\u002FLinkButton\u002FHyperLink增加一些Ajax可更新属性。[fixed]\n\t+隐藏的方式由HideMode属性控制Visibility\u002FOffsets\u002FDisplay。[fixed]\n\t\t-修正Form\u002FSimpleForm中隐藏一个表单字段(Hidden=false)\u003Cem\u003E会\u003C\u002Fem\u003E占据页面空间的BUG。\n\t-ToolbarText\u002FToolbarFill\u002FToolbarSeparator在\u003Cem\u003EASP\u003C\u002Fem\u003EX中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed]\n\t-Button去除MarginRight属性(可以通过CssStyle=\"margin-right:5px;\"达到相同的效果)[fixed]\n\t\n\t\n\t\n+2008-09-09 v1.1\n\t+Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在控件中。[fixed]\n\t\t-网报:CssClass=\"toolbar-pagemenu\" CssStyle=\"border:0px;\",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(..\u002Fimages\u002Fpagemenu_toolbar_background.gif) repeat-x left top;}。\n\t-Region去除默认的Layout=Fit,如果希望Region使用Fit\u002FAnchor\u002FColumn\u002FRow等布局的话,需要手工指定。[fixed]\n\t-ToolbarSeparator\u002FToolbarFill在Ajax更新Hidden属性的BUG。[fixed]\n\t+布局整理。[fixed]\n\t\t-新增Column\u002FAbsolute\u002FRow三种布局,加上以前的Container\u002FFit\u002FAnchor\u002FAccordion\u002FBorder\u002FForm六种布局,总共有9中布局可供使用。\n\t\t-其中一些控件默认使用一种布局:SimpleForm(Form)\u002FForm(Form)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002FTabStrip(Card),所有布局控件默认的布局是Container。\n\t\t-经常用到的布局控件:SimpleForm\u002FForm\u002FAccordion\u002FTabStrip\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不\u003Cem\u003E会\u003C\u002Fem\u003E渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。\n\t\t-US的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报中唯一没有用到Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageContext.Redirect支持普通页面转向和Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax下页面转向。[fixed]\n\t+模拟树的下拉列表的BUG(\u003Cem\u003E会\u003C\u002Fem\u003E使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。\n\t\t-解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) \u003E= 0){ok}。\n\t-DropDownList在Ajax时应该先更新\u003Cem\u003E数据\u003C\u002Fem\u003E再设置选定项 [feedback:xmzhu]。[fixed]\n\t-Button\u002FMenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed]\n\t-Tree的Ajax支持(尚需优化)。[fixed]\n\t\n\t\n\n+2008-09-02 v1.1 beta5\n\t-DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed]\n\t-模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有\u003Cem\u003E数据\u003C\u002Fem\u003E也需要设置DataTextField\u002FDataValueField\u002FDataSimulateTreeLevelField\u002FDataEnableSelectField等属性的值,否则Ajax回发时\u003Cem\u003E会\u003C\u002Fem\u003E出错)。[fixed]\n\t-UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不\u003Cem\u003E会\u003C\u002Fem\u003E用\u003Cem\u003EAsp\u003C\u002Fem\u003EnetAjax,这个控件已经完成使命)。[fixed]\n\t-不要使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件HiddenField,而是使用Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的HiddenField,因为\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件在Ajax不\u003Cem\u003E会\u003C\u002Fem\u003E被更新,所以\u003Cem\u003E会\u003C\u002Fem\u003E导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList中项如果存在汉字,则\u003Cem\u003E会\u003C\u002Fem\u003E换\u003Cem\u003E行\u003C\u002Fem\u003E的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前Tab中如果有ContentPanel,则在页面上方\u003Cem\u003E会\u003C\u002Fem\u003E有空白(可以通过设置EnableDeferredRender=false解决,但\u003Cem\u003E会\u003C\u002Fem\u003E减慢页面的加载速度),现在已经解决这个问题。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm\u002FForm)的背景色一致。[fixed]\n\t-TwinTriggerBox的第一个Trigger图标不\u003Cem\u003E会\u003C\u002Fem\u003E先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config中增加配置项FormLabelWidth=\"80\"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm\u002FForm的表单字段标题的宽度。[fixed]\n\t+完善Ajax。[fixed]\n\t\t-RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue\u002FSelectedItem)。\n\t\t-DropDownList增加Ajax可更新属性Enable\u002FSelectedIndex(SelectedValue\u002FSelectedItem)\u002FDataSource。\n\t\t-Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。\n\t\t-ToolbarText增加Ajax可更新属性Text。\n\t\t\n\t\t\n\t\t\n+2008-08-31 v1.1 beta3\n\t-TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed]\n\t-重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法\u003Cem\u003E会\u003C\u002Fem\u003E出错。[fixed]\n\t+安全的Ajax设计。[fixed]\n\t\t-这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上\u003Cem\u003E会\u003C\u002Fem\u003E有进一步的提升。\n\t\t-基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。\n\t\t-整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不\u003Cem\u003E会\u003C\u002Fem\u003E对UI起作用,同时是安全的,不\u003Cem\u003E会\u003C\u002Fem\u003E有\u003Cem\u003Ejs\u003C\u002Fem\u003E错误)。\n\t-网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed]\n\t\n\t\n\t\n+2008-08-29 v1.1 beta1\n\t+Window控件是否弹出的状态在回发时维持。[fixed]\n\t\t-控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax,Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件内置Ajax支持。[fixed]\n\t\t-这是一个值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和\u003Cem\u003EAsp\u003C\u002Fem\u003E.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要\u003Cem\u003E做\u003C\u002Fem\u003E任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的\u003Cem\u003E做\u003C\u002Fem\u003E法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax的限制。\n\t\t\t-只对Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件起作用,对\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件不起作用。\n\t\t\t-对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。\n\t\t\t-对改变控件的Visible属性\u003Cem\u003E会\u003C\u002Fem\u003E有错误。\n\t\t\t-Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都\u003Cem\u003E添加\u003C\u002Fem\u003EPageLoading控件。[fixed]\n\t-Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执\u003Cem\u003E行\u003C\u002Fem\u003E,这样当前\u003Cem\u003E行\u003C\u002Fem\u003E被选中的状态在回发后\u003Cem\u003E会\u003C\u002Fem\u003E得到保持。[fixed]\n\t-Grid选中\u003Cem\u003E行\u003C\u002Fem\u003E的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知问题:IE的ActiveX插件IE Developer Toolbar\u003Cem\u003E会\u003C\u002Fem\u003E对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父页面加载一个比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都\u003Cem\u003E会\u003C\u002Fem\u003E有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口中IFrame的显示速度。[fixed]\n\t\t-在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed]\n\t\t-一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+TabStrip中非当前Tab\u003Cem\u003E会\u003C\u002Fem\u003E延迟渲染。[fixed]\n\t\t-这\u003Cem\u003E会\u003C\u002Fem\u003E明显加快页面的渲染速度,网报中一个典型的费用审批页面可以减少200ms的渲染时间。\n\t\t-由于非当前Tab不\u003Cem\u003E会\u003C\u002Fem\u003E在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render事件中。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-TabStrip延迟加载引起的BUG(非当前Tab中的ContentPanel\u003Cem\u003E会\u003C\u002Fem\u003E占据页面空间,已修正)。[fixed]\n\t-全新的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Examples(基础知识\u002F表单控件\u002F\u003Cem\u003E数据\u003C\u002Fem\u003E绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe\u002Fdefault.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+ext\u003Cem\u003Ejs\u003C\u002Fem\u003E的BUG,当页面中含有iframe时,Ext.onReady\u003Cem\u003E会\u003C\u002Fem\u003E被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.ext\u003Cem\u003Ejs\u003C\u002Fem\u003E.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true;\n\t+需要先回发页面再弹出IFrame窗口。[fixed]\n\t\t-在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。\n\t\t-另一种\u003Cem\u003E做\u003C\u002Fem\u003E法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference(\".\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下\u003Cem\u003E会\u003C\u002Fem\u003E有\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-增加BorderLayout控件,示例在iframe\u002Fborderlayout.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。[fixed]\n\t+Radiobuttonlist显示有重影(示例在radio.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-全新的样式。\n\t\t-去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。\n\t\t-GetValueReference取得的值不正确的BUG。\n\t-\u003Cem\u003E动态\u003C\u002Fem\u003E向Form中\u003Cem\u003E添加\u003C\u002Fem\u003EFormRow,并\u003Cem\u003E动态\u003C\u002Fem\u003E的向FormRow中\u003Cem\u003E添加\u003C\u002Fem\u003E表单字段,以及如何取得表单字段的值。(示例在form_dynamic.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t+IFrame弹出窗口关闭后回发父页面,则\u003Cem\u003E会\u003C\u002Fem\u003E多加载IFrame一次,再次打开窗口\u003Cem\u003E会\u003C\u002Fem\u003E重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是一个重要的BUG,\u003Cem\u003E会\u003C\u002Fem\u003E严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl\u003Cem\u003E会\u003C\u002Fem\u003E在回发时保持状态,从而回发父页面后Window中的IFrame被\u003Cem\u003E添加\u003C\u002Fem\u003E到页面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不\u003Cem\u003E会\u003C\u002Fem\u003E影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\n\t\n\t\n+2008-08-13 v0.4 beta4\n\t-点击关闭窗口的按钮,在IE下\u003Cem\u003E会\u003C\u002Fem\u003E有\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-Window的右上角关闭图标增加提示,优化事件响应。[fixed]\t\n\t-Window的代码重构。[fixed]\t\n\t+修正一个的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面8次后iexplorer占76.492M内存。\n\t\t-IE窗口最小化时,IE\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003E自动\u003C\u002Fem\u003E进\u003Cem\u003E行\u003C\u002Fem\u003E垃圾回收。\n\t\n\t\n\t\n+2008-08-12 v0.4 beta3\n\t-底层的javascript框架Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E升级为v2.2,Grid的渲染速度有很大提升。[fixed]\n\t-Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则\u003Cem\u003E行\u003C\u002Fem\u003E不可见,可以通过AutoHeight=\"true\"解决)。[fixed]\n\t+页面正在加载的提示尽早的显示出来。[fixed]\n\t\t-首先在执\u003Cem\u003E行\u003C\u002Fem\u003E\u003Cem\u003Ejs\u003C\u002Fem\u003E来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示出来。\n\t\t-加载\u003Cem\u003Ejs\u003C\u002Fem\u003E脚本的script标签放置在页面的最后,放置加载\u003Cem\u003Ejs\u003C\u002Fem\u003E而阻塞PageLoading的显示。\n\t\n\t\n\t\n+2008-08-08 v0.4 beta2\n\t-TabStrip延时加载出错。[fixed]\n\t-Window的IFrameUrl处理的BUG,比如Pages_Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet目录下的页面应该为.\u002FFE_ApplyEditor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex或~\u002FPages_Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet\u002FFE_ApplyEditor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-实现网报首页下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在页面显示后进\u003Cem\u003E行\u003C\u002Fem\u003E,不计算在\u003Cem\u003Ejs\u003C\u002Fem\u003E渲染时间内。[fixed]\n\t-优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex默认\u003Cem\u003E会\u003C\u002Fem\u003E加载form.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面(Window控件的BUG)。[fixed]\n\t-Window中的保存并关闭按钮和\u003Cem\u003EAsp\u003C\u002Fem\u003E.netAjax冲突。[fixed]\n\t-优化关闭Window的\u003Cem\u003Ejs\u003C\u002Fem\u003E脚本,减少写到页面的\u003Cem\u003Ejs\u003C\u002Fem\u003E大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件一样不可编辑。[fixed]\n\t-DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的\u003Cem\u003Ejs\u003C\u002Fem\u003E对象的名称简单化,这样可以减少生成的\u003Cem\u003Ejs\u003C\u002Fem\u003E内容,加快页面加载速度(一个典型页面的\u003Cem\u003Ejs\u003C\u002Fem\u003E由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口中,点击按钮回发然后点击关闭按钮,出现\u003Cem\u003Ejs\u003C\u002Fem\u003E错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为\u003Cem\u003Ejs\u003C\u002Fem\u003E调用此脚本时报错。\n\t\t-一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。\n\t\t-另一种办法就是在PageManager控件中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(\u003Cem\u003E会\u003C\u002Fem\u003E在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t+PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-这个手工\u003Cem\u003E添加\u003C\u002Fem\u003EonReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去\u003Cem\u003E做\u003C\u002Fem\u003E的麻烦(已经在网报中遇到这种情况)。\n\t-每个页面必须\u003Cem\u003E添加\u003C\u002Fem\u003E一个PageManager控件,否则\u003Cem\u003E会\u003C\u002Fem\u003E出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed]\n\t-TextField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fpage2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要\u003Cem\u003E做\u003C\u002Fem\u003E的仅仅是为Window控件增加一个属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(A)\u002Fpage2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(B)\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我\u003Cem\u003E会\u003C\u002Fem\u003E通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid中弹出窗口。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Ftriggerbox.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\t\n\t\t\t-在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口中的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下TabStrip在Ajax回发后不\u003Cem\u003E会\u003C\u002Fem\u003E去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed]\n\t-对TabStrip\u002FPanel\u002FWindow中的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不\u003Cem\u003E会\u003C\u002Fem\u003E有残影出现。[fixed]\n\t-如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则\u003Cem\u003E会\u003C\u002Fem\u003E延迟加载(示例在tabstrip_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-Tree控件,点击一个节点\u003Cem\u003E自动\u003C\u002Fem\u003E回发,则当前点击的那个节点的选中状态不\u003Cem\u003E会\u003C\u002Fem\u003E保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执\u003Cem\u003E行\u003C\u002Fem\u003E(在simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将\u003Cem\u003EJS\u003C\u002Fem\u003E文件引用由head移动到body中。[fixed]\n\t-Firefox下,如果页面太长\u003Cem\u003E会\u003C\u002Fem\u003E出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed]\n\t+IFrame内的页面宽度和高度\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003E自动\u003C\u002Fem\u003E设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image控件 [feedback:jima]。[fixed]\n\t-Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则\u003Cem\u003E会\u003C\u002Fem\u003E引起页面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息中的换\u003Cem\u003E行\u003C\u002Fem\u003E符(转换为\u003Cbr\u002F\u003E),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree控件。[fixed]\n\t\t-如何将\u003Cem\u003E数据\u003C\u002Fem\u003E库中的\u003Cem\u003E数据\u003C\u002Fem\u003E绑定到Tree(示例在tree2_bind_database.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同一个页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltipFormatString两个字段,以显示ToolTip(示例在grid.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才\u003Cem\u003E行\u003C\u002Fem\u003E(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列表如果文字长度太长,则显示的文字\u003Cem\u003E会\u003C\u002Fem\u003E换\u003Cem\u003E行\u003C\u002Fem\u003E,导致错位。[fixed]\n\t\t-虽然最后未能解决\u003Cdiv style=\"width: 60px; white-space: nowrap; overflow: hidden; border: solid 1px red;\"\u003E\u003Cdiv style=\"width: 16px; height: 18px; float: left;\"\u003E##\u003C\u002Fdiv\u003E差旅交通费\u003C\u002Fdiv\u003E在IE和Firefox下显示的不同效果。\n\t\t-但是通过用\u003Cimg src=\"##\" \u002F\u003E来代替\u003Cdiv style=\"background:url(##)\" \u002F\u003E,从而实现FF和IE下样式的统一。\n\t\t-刚看到old9的解决方案:把“差旅交通费”改成“\u003Cspan style=\"margin-right: -1000px;\"\u003E差旅交通费\u003C\u002Fspan\u003E”,在IE下和FF下的都不换\u003Cem\u003E行\u003C\u002Fem\u003E,:-)\n\t-LinkButton增加OnClick事件 [feedback:huihuang]。[fixed]\n\t-Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed]\n\t+增加树控件(Tree)(示例在tree2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-可以在回发时维持树的状态(选中\u003Cem\u003E行\u003C\u002Fem\u003E,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式\u003Cem\u003E添加\u003C\u002Fem\u003E树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到页面,也可以引发PostBack事件,可以\u003Cem\u003E添加\u003C\u002Fem\u003E自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel中放置Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,则渲染时\u003Cem\u003E会\u003C\u002Fem\u003E出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel中渲染Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,如果容器的display='none',则\u003Cem\u003E会\u003C\u002Fem\u003E出现各种问题(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就\u003Cem\u003E会\u003C\u002Fem\u003E显示滚动条。\n\t+IE6下,在应用\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax后,Form中字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。\n\t\t-最后发现IE6下应用\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();):\n\t\t 示例在 Site.Master 页面。\n\t+集成的\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax有一个很大的BUG,只要你在页面上进\u003Cem\u003E行\u003C\u002Fem\u003E过ajax操作,当改变窗口大小时你\u003Cem\u003E会\u003C\u002Fem\u003E惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();),\n\t\t 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。\n\t\n\t\n\t\n+2008-07-14 v0.3 beta6\n\t-增加FlashObject控件。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选中样式微调。[fixed]\n\t-预加载Form表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(一个典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载\u003Cem\u003E数据\u003C\u002Fem\u003E不\u003Cem\u003E会\u003C\u002Fem\u003E改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid中静态的CheckBoxField图片。[fixed]\n\t-TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-页面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和TextBox比较大小需要指定CompareType。\n\t+如果在编辑页面使用\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fajax_editor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-这是由于ajax后执\u003Cem\u003E行\u003C\u002Fem\u003E的javascript中不能有return false语句。\n\t+在文本框失去焦点时,执\u003Cem\u003E行\u003C\u002Fem\u003E一些Javascript脚本(示例在textbox_blur.\u003Cem\u003Easp\u003C\u002Fem\u003Ex) [feedback:xmzhu]。[fixed]\n\t\t-在页面\u003Cem\u003E添加\u003C\u002Fem\u003EonReady函数(\u003Cem\u003E会\u003C\u002Fem\u003E被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误页面,解决方法在当前目录\u003Cem\u003E添加\u003C\u002Fem\u003E一个空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是\"#\"。[fixed]\n\t+弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时\u003Cem\u003E会\u003C\u002Fem\u003E有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例中alert\\alert_1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和alert\\alert_2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,总计 6 \u003Cem\u003E行\u003C\u002Fem\u003E代码),现在只需要 3 \u003Cem\u003E行\u003C\u002Fem\u003E代码就OK了。\n\t-点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t+增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-增加SplitButton控件。[fixed]\n\t\n\t\n\t\n+2008-07-09 v0.3 beta4\n\t-DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed]\n\t+Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed]\n\t\t-增加ControlToCompare\u002FValueToCompare\u002FCompareOperator\u002FCompareMessage四个属性,示例在form_compare.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t+TabStrip中放置IFrame\u003Cem\u003E会\u003C\u002Fem\u003E出现渲染错误 (示例在tabstrip_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t\t-特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.\u003Cem\u003Easp\u003C\u002Fem\u003Ex) [feedback:xmzhu]。[fixed]\n\t-FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t+表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed]\n\t\t-覆盖缺省样式的.x-item-disabled,设置不透明。\n\t\n\t\n\t\n+2008-07-08 v0.3 beta3\n\t-Grid没有\u003Cem\u003E数据\u003C\u002Fem\u003E,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed]\n\t+增加HiddenField控件。[fixed]\n\t\t-其实用TextBox也能模拟HiddenField的\u003Cem\u003E行\u003C\u002Fem\u003E为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed]\n\t+控制下拉列表某些项不可以选择(示例在dropdownlist2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。\n\t-LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和grid.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-07-07 v0.3 beta2\n\t+增加UpdatePanelConnector控件,支持在布局构建的页面使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net Ajax。[fixed]\n\t\t-使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。\n\t\t-示例在ajax3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fcontent_page4.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t\t-示例content_page3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器控件的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工\u003Cem\u003E添加\u003C\u002Fem\u003EAutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其中放置用户控件(示例在page_usercontrol.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-也可以在ContentPanel中放置用户控件,注意两者的区别。\n\t+增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed]\n\t+支持\u003Cem\u003EAsp\u003C\u002Fem\u003E.net ajax异步加载。[fixed]\n\t\t-有很大局限性,只能在ContentPanel中使用,示例在ajax1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fcontent_ajax2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex中。\n\t\t-对于使用布局构建的页面(比如content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)还不能使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net ajax,因为页面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前页面已经被修改(示例在content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中\u003Cem\u003E做\u003C\u002Fem\u003E法一致)。\n\t+iframe中的alert\u002Fconfirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed]\n\t\t-在Firefox下还有问题。[fix pending]\n\t+排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。\n\t\t-可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。\n\t+HyperLinkField\u002FWindowField的链接地址支持服务器端格式(即是~\u002Falert.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-TabStrip的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed]\n\t-可以在ContentPanel中放置用户控件(示例在page_usercontrol.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t\n\t\n\t\n+2008-06-30 v0.2 beta11\n\t-增加TwinTriggerBox控件(示例在twintriggerbox.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-Grid的\u003Cem\u003E数据\u003C\u002Fem\u003E库分页需要增加属性IsDatabasePaging=true,以便普通分页和\u003Cem\u003E数据\u003C\u002Fem\u003E库分页,否则在\u003Cem\u003E添加\u003C\u002Fem\u003E删除记录时总记录数不\u003Cem\u003E会\u003C\u002Fem\u003E变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的tab)。[fixed]\n\t+页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid中的LinkButtonField设置ConfirmText\u003Cem\u003E会\u003C\u002Fem\u003E出错 [feedback:huihuang]。[fixed]\n\t-增加静态类Confirm。[fixed]\n\t\n\t\n\t\n+2008-06-27 v0.2 beta10\n\t+Grid完善。[fixed]\n\t\t-CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例)。\n\t\t-Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-切换分页时清空选中的值 [feedback:jqpeng]。\n\t\t-增加PreRowDataBound事件,可以在\u003Cem\u003E数据\u003C\u002Fem\u003E绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\n\t\n\t\n+2008-06-25 v0.2 beta9\n\t+Window窗体中的Iframe只让内容区域滚动,而Toolbar不滚动的规则。(示例在content_page2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-在simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex中:Panel[BodyPadding=5](Toolbar,Panel[Height=450 Layout=Fit](SimpleForm[AutoScroll=true])),则外面窗口的高度=450 + 5*2 + 26 + 32,其中26是Toolbar的高度,32是窗口的标题栏和下边框的高度。\n\t+关闭Iframe的LoadMask,所以需要Iframe页面\u003Cem\u003E添加\u003C\u002Fem\u003EPageLoading控件,这样效果统一。[fixed]\n\t+Grid完善。\n\t\t-去除EnableClientPaging和EnableClientSort属性,客户端排序和客户端分页在\u003Cem\u003EASP\u003C\u002Fem\u003E.NET应用中\u003Cem\u003E会\u003C\u002Fem\u003E有很多问题(主要是状态保持的问题)。\n\t\t+EnableServerSort改名AllowSorting。(示例在grid_sorting.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-使用非常简单:设置AllowSorting=true,注册OnSort事件,在事件处理函数中重新绑定\u003Cem\u003E数据\u003C\u002Fem\u003E。\n\t\t+增加AllowPaging属性。(示例在grid_paging.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-使用非常简单:设置AllowPaging=true,PageSize=3,注册OnPageIndexChange事件,在事件处理函数中Grid1.PageIndex = e.NewPageIndex;OK。\n\t\t+\u003Cem\u003E数据\u003C\u002Fem\u003E库分页支持。(示例在grid_database_paging.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-使用也非常简单:设置AllowPaging=true,PageSize=3,在绑定时设置RecordCount为总的记录数,在OnPageIndexChange事件处理函数中Grid1.PageIn","createTime":"2010-04-01 09:41:27","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-2190657-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-2190657-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-2190657-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"1\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fsuper_zhaowenke\u002F2190657\",\"strategy\":\"2~default~OPENSEARCH~Paid\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Paid-1-2190657-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130","title":"Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet_v2.3.2_dll","desc":"Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet - Ext\u003Cem\u003EJS\u003C\u002Fem\u003E based \u003Cem\u003EASP\u003C\u002Fem\u003E.NET Controls with Full AJAX Support\n\t\nExt\u003Cem\u003EAsp\u003C\u002Fem\u003ENet是一组专业的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件库,拥有原生的AJAX支持和丰富的UI效果,\n目标是创建没有ViewState,没有JavaScript,没有CSS,没有UpdatePanel,没有WebServices的Web应用程序。\n\n支持的浏览器: IE 7.0+, Firefox 3.0+, Chrome 2.0+, Opera 9.5+, Safari 3.0+\n\n注:Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet基于一些开源的程序Ext\u003Cem\u003EJS\u003C\u002Fem\u003E, HtmlAgilityPack, Nii.\u003Cem\u003EJS\u003C\u002Fem\u003EON, YUICompressor。\n\n示例: http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003E.net\u002F\n开源: http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003Enet.codeplex.com\u002F\n博客: http:\u002F\u002Fsanshi.cnblogs.com\u002F\n邮箱: sanshi.ustc@gmail.com\n\n\n发布历史:\n\n+2010-09-29 v2.3.2\n\t-不绑定任何\u003Cem\u003E数据\u003C\u002Fem\u003E到Grid时,确保页面不\u003Cem\u003E会\u003C\u002Fem\u003E出错。\n\t-修正了Grid列属性DataFormatString的一个bug,比如设置{0:yy-MM-dd HH:mm}时没有效果。\n\t-修正下拉列表控件不能绑定DataTable的BUG(feedback:RedOcean)。\n\t-增加土耳其语言资料文件(feedback:abdullaharslan)。\n\t-Grid的BoundField增加NullDisplayText属性,用于处理\u003Cem\u003E数据\u003C\u002Fem\u003E库中的null值,如果没有设置则默认为空字符串。\n\t-修正DatePicker中的一个bug(31\u002F01\u002F2010将\u003Cem\u003E会\u003C\u002Fem\u003E返回NULL)使用DateFormatString来生成SelectedDate属性(feedback:OktaEndy)。\n\t-修正ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本(v3.2.2)中的一个bug,如果下拉列表中存在两个相同的Text,则SelectedValue返回值永远是第一个Text的值(feedback:ben.zhou)。\n\t-应用补丁#6593, #6621(feedback:vbelyaev)。\n\t+修正IE7下Grid分页速度慢(feedback:youwei, StevenGuan, hazardvn, gavindou, ttjacky)。\n\t\t-实际上IE7下所以的回发都慢,原因是客户端的Base64编码速度慢,已经使用encodeURIComponent来代替Base64编码。\n\t-俄语翻译(feedback:vbelyaev)。\n\t\n\t\n\n+2010-06-30 v2.3.1\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件将不在依赖ViewState,减少1\u002F4左右的HTTP\u003Cem\u003E数据\u003C\u002Fem\u003E传输量。\n\t-控件和示例的增强。\n\t\n\t\n\n+2010-03-28 v2.2.1\n\t+为TabStrip的GetAddTabReference函数增加重载方法,以便指定Tab的图标(feedback:mmdcup)。 \n\t\t-修正此函数通过PageContext.RegisterStartupScript调用时不能正确显示Icon的BUG(feedback:zhaowenke)。\n\t-修正basic\u002Fhello.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例在单独浏览器打开后,不能弹出对话框的BUG。\n\t-隐藏示例首页最外层RegionPanel的边框ShowBorder=\"false\"。\n\t+集成Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本v3.1.1。\n\t\t-增加一个新的Theme - Access。\n\t\t-修正了Firefox下Zoom In\u002FOut时页面消失的BUG。\n\t\t-删除Panel的EnableLightBackgroundColor属性,同时EnableBackgroundColor只支持Blue和Gray两种Theme。\n\n\n\n+2010-01-31 v2.2.0\n\t-使得\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件ImageButton具有和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的Button控件类似的\u003Cem\u003E行\u003C\u002Fem\u003E为(Ajax提交)(feedback:261629698)。\n\t+TabStrip增加GetAddTabReference和GetRemoveTabReference两个函数,用来向TabStrip控件\u003Cem\u003E动态\u003C\u002Fem\u003E增加删除Tab。\n\t\t-增加示例tabstrip\u002Ftabstrip_addtab.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-重构了示例网站的架构,目前只有一层IFrame结构。\n\t-为TabStrip增加EnableTabCloseMenu属性,是否启用右键菜单,可用来关闭当前Tab和所有其他Tab。\n\t-为NumberBox增加DecimalPrecision属性,用来控制小数点后的位数(需要设置NoDecimal=\"false\")(feedback:zqmars)。\n\t-Window控件更新。\n\t\t-关闭按钮默认直接关闭,不\u003Cem\u003E会\u003C\u002Fem\u003E弹出确认对话框。\n\t\t-GetConfirmFormModifiedHideReference的函数中的ConfirmFormModified简化为Confirm,所以此函数更名为GetConfirmHideReference。\n\t\t-增加两个属性EnableConfirmOnClose(默认false),CloseAction(Hide, HideRefresh, HidePostBack)。\n\t\t-修正EnableMaximize属性不能使Window最大化的BUG,修正了双击标题栏不能最大化的BUG。\n\t-删除Button控件的SystemIcon属性,比如以前这样定义SystemIcon=\"Close\",现在需要这样定义Icon=\"SystemClose\"。\n\t-WindowPosition默认居中,而不是黄金分割位置。\n\t+Button, Window等控件弹出位置属性的变化。\n\t\t-Window的Target属性由字符串类型变为枚举类型,注意更新以前的代码:Target=\"_self\" -\u003E Target=\"Self\", Target=\"_parent\" -\u003E Target=\"Parent\"。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField的ConfirmTarget属性由字符串变为枚举类型,可以取三个枚举值Self, Parent, Top。\n\t\t-Confirm.GetShowReference的最后一个参数target变为枚举类型。\n\t\t-Alert.GetShowReference中的showInParent参数也变为Target枚举类型。\n\t\t-MenuButton, LinkButton, Button, LinkButtonField增加ValidateTarget用来控制表单验证失败时提示对话框的显示位置。\n\n\n\n+2010-01-06 v2.1.9\n\t-集成Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本v3.1.0。\n\t-修正灰色皮肤的CSS问题。\n\t-修正Grid的列名中不能包含中文字符的BUG(feedback:davidwen)。\n\t-为Web.config和PageManager增加属性AjaxTimeout(单位秒,默认30秒)。\n\t-修正了在Grid的PageIndexChange事件中不能获取SelectedRowIndexArray属性的BUG(feedback:Violet)。\n\t-Button控件将不再\u003Cem\u003E自动\u003C\u002Fem\u003E拥有display:inline属性,如果希望两个按钮在一\u003Cem\u003E行\u003C\u002Fem\u003E显示,请为第一个按钮设置CssStyle=\"float:left;\"属性。\n\t-修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。\n\t-为TriggerBox和TwinTriggerBox增加EnableEdit属性。\n\t-使用Hidden来显示隐藏Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,而不是使用Visible属性(Visible目前设置为只读属性)。\n\t-使用Hidden控制Window控件的显示隐藏,Popup已经标记为Obsolete属性。\n\t-Window的实例方法GetCloseReference等以及ActiveWindow的静态方法GetCloseReference等,其中的Close全部改为Hide。\n\t-增加TabStrip中Tab控件可关闭属性EnableClose(默认为false)以及两个方法GetShowReference和GetHideReference(feedback:anson)。\n\t-修正绑定到Tree的XMLDocument中Icon属性映射错误(feedback:nopnop9)。\n\t-修正HtmlEditor不能编辑的BUG(feedback:TheBox)。\n\t-修正IE下有时\u003Cem\u003E会\u003C\u002Fem\u003E出现空白页面的情况(feedback:olivia919)。\n\t\n\t\n\n+2009-12-06 v2.1.8\n\t-修正了使用IFrame的Window关闭后不能再次打开的BUG(feedback:alexa99)。\n\t-修正了IE下Grid中的一个\u003Cem\u003EJS\u003C\u002Fem\u003E问题(feedback:lqm4108)。\n\t-修正Alert消息中引号未编码导致的\u003Cem\u003EJS\u003C\u002Fem\u003E错误(feedback:sun1299shine)。\n\t+集成ext\u003Cem\u003Ejs\u003C\u002Fem\u003E3.0.3。\n\t\t-修正弹出对话框的宽度计算错误(\u003Cem\u003E会\u003C\u002Fem\u003E保持最小的状态)。\n\t\t-增加新的皮肤Gray。\n\t-为示例工程\u003Cem\u003E添加\u003C\u002Fem\u003E改变语言和皮肤的下拉列表。\n\t-为PageContext增加静态函数Refresh,在切换语言和皮肤时使用。\t\n\n\n\n+2009-12-01 v2.1.7\n\t-增加示例(iframe\u002Fparent_postback_run3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex),如何通过简单的Javascript代码回发父页面(feedback:eroach)。\n\t-修正一些书写错误(feedback:bmck)。\n\t-从Region控件中删除SplitColor属性,增加CollapseMode, EnableSplitTip, SplitTip, CollapsibleSplitTip属性(feedback:bmck)。\n\t-BorderPanel更名为RegionPanel。\n\t-DropDownList拥有MarkInvalid方法(feedback:sun1299shine)。\n\t-增加中国的省市县三级联动示例(data\u002Fshengshixian.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:Blues T)。\n\t-修正了使用IFrameUrl的Tab在切换过程中\u003Cem\u003E会\u003C\u002Fem\u003E重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。\n\t-修正了启用AutoPostBack的Grid,其RowClick\u003Cem\u003E会\u003C\u002Fem\u003E覆盖LinkButtonField, HyperLinkField, CheckBoxField的点击事件(feedback:yymaoji)。\n\t\n\t\n\t\n+2009-11-26 v2.1.6\n\t+修正\u003Cem\u003E动态\u003C\u002Fem\u003E创建Grid列的BUG(feedback:gxpan)。\n\t\t-增加示例(data\u002Fgrid_dynamic_columns.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-修正Form不能自适应浏览器大小的改变(feedback:kaywood)(WorkItem#6309)。\n\t-增加重载方法Alert.Show(message, title, icon)(feedback:TheBox)(WorkItem#6353)。\n\t-为容器控件(比如Panel,Region,Tab等)增加AJAX属性IFrameUrl(feedback:BluesT)。\n\t-重新设计模拟树的下拉列表的实现,避免选中某项后的闪烁。\n\t\t\t\n\n\n+2009-11-21 v2.1.5\n\t+Tree优化。\n\t\t-修正Expanded项和Checked项的状态在回发改变后不能保持的BUG。\n\t\t-GetNodeById更名为FindNode,保持和FindControl一致命名。\n\t\t-删除CheckedNodeIDArray属性,增加GetCheckedNodes和GetCheckedNodeIDs函数。\n\t\t-删除ExpandedNodeIDArray属性,增加GetExpandedNodes和GetExpandedNodeIDs函数。\n\t\t-增加示例(data\u002Ftree_select_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex),如何选中当前节点的所有子节点(feedback:wjl_wjl520)。\n\t\t+TreeNode的属性NodeId被重命名为NodeID,这是Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet中的一个命名约定。\n\t\t\t-同时更名的还有GridColumn的ColumnId-\u003EColumnID,GetColumnId-\u003EGetColumnID。\n\t\t\t-Grid1.Columns.FindColumnById函数被Grid1.FindColumn所替代。\n\t\t-为TreeCheckEventArgs,TreeExpandEventArgs,TreeCommandEventArgs增加Node属性。\n\t-为所有控件增加Focus(覆盖Control默认的Focus函数)和GetFocusReference函数。\n\t-增加示例(other\u002Fcustom_postback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:thebox)。\n\t\t-如何自定义Javascript脚本和C#处理函数来响应键盘事件。\n\t-为Tree增加AutoLeafIdentification属性。\n\t\t-增加示例(tree_auto_leaf_identification.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:wdrabbit)。\n\t\n\t\n\n+2009-11-17 v2.1.4\n\t-修正Window的关闭按钮提示信息一直是中文的BUG(feedback:thebox)。\n\t-部分Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件的设计时支持(\u003Cem\u003E会\u003C\u002Fem\u003E在后续版本中逐步完善)。\n\t-v0.2beta2版本中关于PersistChildren(true)的描述有误,这个是设计时属性,和运\u003Cem\u003E行\u003C\u002Fem\u003E时是否保持状态没有关系。\n\t-修正CheckBox控件的CheckedChanged事件\u003Cem\u003E会\u003C\u002Fem\u003E被触发两次的BUG(Data PostBack-\u003EAutoPostBack, Event PostBack-\u003EEnablePostBack)。\n\t-为TextBox,TextArea,DatePicker,NumberBox,TriggerBox等控件增加AutoPostBack属性(feedback:dk3214)。\n\t+为表单字段增加RequiredMessage,MaxLengthMessage,MinLengthMessage属性,用于指定验证失败时提示信息。\n\t\t-为空则使用默认的提示信息,默认的提示信息支持多语言,建议一般情况下使用默认信息。\n\t+为表单字段增加MarkInvalid和GetMarkInvalidReference函数(feedback:sun1299shine)。\n\t\t-增加示例:form\u002Fform_validate.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\n\t\n\t\n\n+2009-10-19 v2.1.3\n\t+增加支持在AJAX时改变的控件属性列表(\u002Fajax.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet支持原生的AJAX,也就是说控件的属性改变在AJAX过程中\u003Cem\u003E会\u003C\u002Fem\u003E反映到页面中,但并不是所有的控件属性都支持AJAX改变。\n\t-加载s.gif图片在本机进\u003Cem\u003E行\u003C\u002Fem\u003E,不\u003Cem\u003E会\u003C\u002Fem\u003E请求ext\u003Cem\u003Ejs\u003C\u002Fem\u003E.com远程资源(feedback:efrigate43,abaocoole)。\n\t-在AJAX回发后确保\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮控件仍然具有AJAX的特性。\n\t-更新\u002Fbasic\u002Flogin.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例,使用验证图片(feedback:kedee)。\n\t-为Grid增加AutoPostBack属性和RowClick事件,示例在\u002Fdata\u002Fgrid_autopostback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(feedback:chenguizhu2006)。\n\t-为所有的表单字段增加AJAX属性ReadOnly(feedback:skydb)。\n\t-Grid中TemplateField生成到页面中控件具有唯一ID,例如Grid1_ct5_Label2,Grid1_ct6_Label2(feedback:geruger)。\n\t\n\t\n\n+2009-09-27 v2.1.2\n\t-为Tree控件增加GetExpandAllNodesReference和GetCollapseAllNodesReference两个函数。\n\t-修正RELEASE版本下多语言加载的BUG(feedback:yigehaoren)。\n\t-增加pt_BR语言,由Ujvari提供。\n\t+为所有Panel(包括Grid,Tree,Form等)增加枚举类型Icon,其中包含1700多个小图标。\n\t\t-如果Panel具有IconUrl属性,则IconUrl优先于Icon。\n\t\t-所有Icon的列表在icon.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-为Button,MenuItem(MenuButton,MenuHyperLink),AccordionLink,TreeNode,Image(如果ImageUrl为空,则取Icon的值)增加Icon属性。\n\t\n\t\n\n+2009-09-15 v2.1.1\n\t-修正不能\u003Cem\u003E动态\u003C\u002Fem\u003E修改AccordionPane属性Items的BUG。\n\t+为Button, MenuButton, LinkButton, LinkButtonField增加ConfirmTarget。\n\t\t-如果需要在父页面弹出确认对话框,需要设置ConfirmTarget=\"_parent\"(类似Window控件的Target=\"_parent\")。\n\t+为Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert.Show增加点击确定的JavaScript回调函数。\n\t\t-一个典型应用,在Window控件中打开新页面,如果传递的参数不正确,则首先提示参数不对然后关闭此弹出窗口。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert.Show(\"参数错误!\", String.Empty, Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.ActiveWindow.GetCloseReference());\n\t+TreeNode的前面的多选框可以\u003Cem\u003E自动\u003C\u002Fem\u003E回发了。\n\t\t-为TreeNode增加AutoPostBack属性,增加事件\u003Cem\u003E数据\u003C\u002Fem\u003E类TreeCheckEventArgs,为Tree增加事件NodeCheck。\n\t\t-示例在:http:\u002F\u002Fext\u003Cem\u003Easp\u003C\u002Fem\u003E.net\u002Fdata\u002Ftree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\n\t-Grid增加GetNoSelectionAlertInParentReference函数,用来表示没有选中任何一项时在父页面弹出对话框的\u003Cem\u003EJS\u003C\u002Fem\u003E代码。\n\t-修正IE7下不能以下划线作为CSS中类名的前缀的BUG(feedback:Steve.Wei)。\n\t-\u003Cem\u003E添加\u003C\u002Fem\u003E定时器控件Timer,用来定时发起AJAX请求。\n\t\n\t\n\n+2009-09-06 v2.1.0\n\t-Button的Pressed属性值能够正确的反映客户端的变化。\n\t-优化Tree控件的AJAX实现。\n\t+为页面的Form\u003Cem\u003E添加\u003C\u002Fem\u003Eautocomplete=\"off\"属性。\n\t\t-参考http:\u002F\u002Fwww.cnblogs.com\u002Fsanshi\u002Farchive\u002F2009\u002F09\u002F04\u002F1560146.html#1635830\n\t+\u003Cem\u003E添加\u003C\u002Fem\u003E对ext\u003Cem\u003Ejs\u003C\u002Fem\u003E3.0中所有语言的支持。\n\t\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet扩展的多语言包在\u003Cem\u003Ejs\u003C\u002Fem\u003E\\languages\\ext\u003Cem\u003Easp\u003C\u002Fem\u003Enet目录下,目前只有en,zh_CN,zh_TW三种实现\n\t\t-你可以向其中\u003Cem\u003E添加\u003C\u002Fem\u003E自己的语言版本,并执\u003Cem\u003E行\u003C\u002Fem\u003E\u003Cem\u003Ejs\u003C\u002Fem\u003E\\languages下的pack.bat打包,最后编译工程。\n\t\n\t\n\t\n+2009-09-01 v2.0.9\n\t-为Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Alert\u003Cem\u003E添加\u003C\u002Fem\u003E两个静态方法ShowInParent和GetShowInParentReference,用于在父页面弹出窗口。\n\t+在\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面中必须显示的声明控件的集合属性(比如Tabs(TabStrip), Items(PanelBase), Nodes(TreeNode))。\n\t\t-这将\u003Cem\u003E会\u003C\u002Fem\u003E影响所有的\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,所以要特别关注。\n\t-重命名AccordionPanel为AccordionPane (这也是在\u003Cem\u003EAsp\u003C\u002Fem\u003E.net AJAX中使用的名称).\n\t+所有的面板默认有两个集合属性(Toolbars和Items).\n\t\t-尽管TabStrip, From, Tree, Accordion继承了Items属性,但是你并不能对其设置(此时Items是只读的).\n\t\t-这将\u003Cem\u003E会\u003C\u002Fem\u003E影响所有的\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,一定要将工具条(Toolbars)和Items区分开来。\n\t-祝你生日快乐 - 小师妹妹。\n\n\n\n+2009-08-29 v2.0.8\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet支持多语言(en,zh_CN,zh_TW),可以在Web.config中修改。\n\t-将所有的示例转化为英语版本。\n\t-修正Tree控件的一个BUG(定义Mappings属性时)。\n\t+PageManager.Instance应该存在于HttpContext.Current,而不是一个全局变量。\n\t -这个BUG导致\u003Cem\u003EAsp\u003C\u002Fem\u003E.net compatibility中的示例无法完成,现在已经修正。\n\t+去除PageManager中方法AddAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls,增加属性Ajax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls。\n\t -这个属性和Button得ValidateForms属性类似,可以查看\u003Cem\u003EAsp\u003C\u002Fem\u003E.net compatibility中的示例。\n\t\n\t\n\n+2009-08-25 v2.0.7\n -为按钮增加DisableControlBeforePostBack属性 - 回发之前是否禁用按钮,防止重复提交 - 默认为true。\n -Grid的Values属性访问限制由internal改为public,这就意味这可以自由改变Grid中每个单元格的值了。\n -增加示例-如何将Grid控件导出为Excel(data\\grid_excel_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:503684912)。\n -如果TreeNode的属性Enabled=\"false\",则此项变灰并且不\u003Cem\u003E会\u003C\u002Fem\u003E被选中(feedback:your568)。\n -修正TreeNode的属性NavigateUrl不接受服务器端URL(以~\u002F开头)的BUG。\n -增加Accordion和Tree配合使用的示例(other\\accordion_tree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n -修正Panel图标不能显示的BUG(CSS中class名不能有$字符)。\n +去除PageLayout控件,此控件可以使用BorderLayout和指定PageManager的AutoSizePanelID属性来代替。\n\t\t-这样所有需要占据全屏的Panel(不管你是Accordion,Panel,ContentPanel,Form,GroupPanel,SimpleForm,Tree还是Grid,TabStrip)都可以通过这种方式全屏。\n\t\t-简单方便,示例可以参考 default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex 或者 other\\accordion_tree_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n \n \n\n+2009-08-14 v2.0.6\n\t-\u003Cem\u003E动态\u003C\u002Fem\u003E生成菜单实例(other\\menu_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和other\\menu_dynamic2_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)(feedback:shguo)。\n\t-优化AJAX的内部实现,每个页面保存的ViewState现在减少1\u002F3左右(重要更新)。\n\t-优化Tree节点的NodeId\u003Cem\u003E自动\u003C\u002Fem\u003E生成,减少ViewState占用。\n\t\n\n\n+2009-08-09 v2.0 beta5\n\t+Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的提交按钮兼容问题(feedback:千帆)。\n\t\t-在2009-03-03 v1.3.0曾经提到这个兼容问题,并有这样的规则,如果\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮AJAX提交,必须设置UseSubmitBehavior=\"false\"\n\t\t--也就是说生成的input的type不能是\"submit\",而这个限制在有些情况下是不可原谅的。\n\t\t--我们\u003Cem\u003E做\u003C\u002Fem\u003E了优化,现在要使一个\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的按钮能够AJAX提交,你不需要\u003Cem\u003E做\u003C\u002Fem\u003E任何设置(PageManager的属性EnableAjax为true即可,这是默认属性)。\n\t+PageManager的实例方法AddAjaxUpdateControl改名为AddAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls,现在可以在Page_Load中设置需要在AJAX中需要更新的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件了。\n\t\t-在Page_Load中设置了哪些需要在AJAX中更新的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件\u003Cem\u003E会\u003C\u002Fem\u003E在回发时保持状态,可以通过RemoveAjax\u003Cem\u003EAsp\u003C\u002Fem\u003EnetControls来去除不需要更新的控件。\n\t\t-示例在\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\fckeditor_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\\u003Cem\u003Easp\u003C\u002Fem\u003Enet_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t\t-FCKEditor和上传控件兼容。示例在\u003Cem\u003Easp\u003C\u002Fem\u003Enet\\fileupload_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t-修正ToolbarText的文本在AJAX下更新的BUG。\n\t-Button的Pressed属性在AJAX可更新(feedback:mgzhenhong)。\n\t-更新所有示例。在IE7.0,IE8.0,Firefox3.5,Chrome2.0下测试通过。\n\t\n\n\n+2009-08-02 v2.0 beta4\n\t+和\u003Cem\u003EAsp\u003C\u002Fem\u003E.Net的Forms Authentication兼容[feedback:mgzhenhong]。\n\t\t-采用和\u003Cem\u003EAsp\u003C\u002Fem\u003E.Net Ajax类似的处理方式,需要在配置文件Web.config增加一个httpModules。\n\t\t-现在支持Response.Redirect,你可以选择Response.Redirect或者Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.PageContext.Redirect重定向页面,两者效果一样。\n\t\t-支持FormsAuthentication.RedirectFromLoginPage(accountID, false);这样的方法。\n\t-Button增加Type属性(button,reset,submit)[feedback:mgzhenhong]。\n\t-修正Alert.Show方法不能指定文本前图片的BUG[feedback:xmq&mgzhenhong]。\n\t-修正IE下某些弹出窗口的IFrame第一次不能加载的BUG。\n\t-增加Menu和Accordion的示例。\n\t-修正Window控件的IconUrl有时不显示(Target=\"_parent\")的BUG[feedback:xmq&mgzhenhong]。\n\t\n\n\n+2009-07-22 v2.0 beta3\n\t-兼容FCKEditor。\n\t-在IE8.0,Firefox3.5下测试通过。以后Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet将不\u003Cem\u003E会\u003C\u002Fem\u003E对IE6.0提供支持。\n\t\n\n\n+2009-07-13 v2.0 beta2\n\t-集成ext\u003Cem\u003Ejs\u003C\u002Fem\u003E最新版本v3.0。\n\t+兼容IE6.0-7.0-8.0。\n\t\t-这应该是Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E3.0的一个BUG,在IE6.0-7.0下面设置Ext.QuickTips.init();\u003Cem\u003E会\u003C\u002Fem\u003E导致button的click事件无法响应(IE8下无此问题)。\n\t\t-目前先禁用IE6.0-7.0的QuickTips。\n\t-优化底层JavaScript。\n\t\n\t\n\t\n+2009-07-05 v2.0 beta1\n\t-更新ext\u003Cem\u003Ejs\u003C\u002Fem\u003E库到最新版本v3.0 RC2; 目前只有一个缺省皮肤(Theme)。\n\t-使用YUI Compressor压缩JavaScript和CSS文件。\n\t-Release版本每个页面只包含一个JavaScript文件(语言文件除外)和一个CSS文件。\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet自身的CSS\u003Cem\u003E会\u003C\u002Fem\u003E紧挨着页面标签引入,这样在中自定义的样式可以覆盖Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet缺省样式。\n\t+Alert对话框\u003Cem\u003E会\u003C\u002Fem\u003E遮挡所有的Window窗口。\n\t\t-使用一个变通的方法解决,因为无法改变Ext.Message的默认z-index(9000)所以将box.window_default_group的zseed调整为6000。\t\n\t-为所有按钮的左右增加5px的空白边距:.x-btn button { margin: 0 5px !important; }。\n\t-因为下拉列表不可编辑,所以不能为空,如果不设置SelectedIndex或SelectedValue,则默认选中第一项。\n\t-重新绑定模拟树的下拉列表后,选中项的前面有图片的HTML标签的BUG。\n\t-更新自定义JavaScript组件Ext.ux.SimplePagingToolbar。\n\t-更新示例工程。\n\t\n\t\n\n+2009-03-25 v1.3.1\n\t-Tree在AJAX回发展开节点时\u003Cem\u003EJS\u003C\u002Fem\u003E错误[feedback:xlli]。[fixed]\n\t-Window中的EnableIFrame==false,则点击关闭按钮时报\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-页面包含FileUpload控件,需要点击按钮回发并上传文件,则不能采用原生AJAX方式。(参见示例\u003Cem\u003Easp\u003C\u002Fem\u003Enet\u002Ffileupload.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t-HtmlEditor显示隐藏工具栏按钮不起作用,HtmlEditor目前不支持Enabled和Readonly两个属性。[fixed]\n\t\n\t\n\n+2009-03-03 v1.3.0\n\t-如果弹出的窗口(Ext-Window)含有\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件FileUpload,则此弹出窗口在关闭时出现\u003Cem\u003EJS\u003C\u002Fem\u003E错误(http:\u002F\u002Fext\u003Cem\u003Ejs\u003C\u002Fem\u003E.com\u002Fforum\u002Fshowthread.php?t=8129)[feedback:xlli]。[fixed]\n\t-如果页面中存在\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件(TextBox),则第二次提交表单就\u003Cem\u003E会\u003C\u002Fem\u003E报错(视图状态不对,其实时没有更新EventValidation隐藏字段导致的问题)。[fixed]\n\t-页面上放置Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet-Button和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET-Button,则点击Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet-Button时激发的是\u003Cem\u003EASP\u003C\u002Fem\u003E.NET-Button的事件,这个BUG和Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E2.2.1中Ext.Ajax.serializeForm的实现有关。[fixed]\n\t-Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet内部包含HtmlAgilityPack和Nii.\u003Cem\u003EJS\u003C\u002Fem\u003EON两个开源的第三方类库。[added]\n\t+如果以前你听过不要在Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet工程中使用\u003Cem\u003EASP\u003C\u002Fem\u003E.NET标准控件的忠告,那么从v1.3.0版本开始,你可以忘掉这个说法,现在Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件和\u003Cem\u003EASP\u003C\u002Fem\u003E.NET标准控件和平共处了。[fixed]\n\t\t-如果一个\u003Cem\u003EASP\u003C\u002Fem\u003E.NET按钮控件要使用Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的原生AJAX,只需要设置属性 UseSubmitBehavior=\"false\" 即可。\n\t\t-如果要在一次Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的原生AJAX回发时更新\u003Cem\u003EASP\u003C\u002Fem\u003E.NET控件的值,只需要调用PageManager的公共方法AddAjaxUpdateControl即可(示例:\u003Cem\u003Easp\u003C\u002Fem\u003Enet\u002F\u003Cem\u003Easp\u003C\u002Fem\u003Enet.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\n\n\n+2009-02-27 v1.2 beta9\n\t-网络连接出错时的“Ajax Error”改成更加友好的提示信息“本次连接失败!可能是网络连接出错,请刷新页面重试。”。[fixed]\n\t-\u003Cem\u003E自动\u003C\u002Fem\u003E测试功能\u003Cem\u003E会\u003C\u002Fem\u003E在以后版本中逐步完善。这个版本完成测试框架,采用Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E中\u003Cem\u003EJS\u003C\u002Fem\u003E函数进\u003Cem\u003E行\u003C\u002Fem\u003E大部分的测试,对于一些难以测试的地方借助jQuery完成。[fixed]\n\t+系统底层代码优化(主要是Javascript的封装和BUG修复)。[fixed]\n\t\t-底层使用Javascript创建一个Window控件的代码由原来的2000字符减少为500个字符。\t\n\t\t-PageContext静态类中的GetPageStateChangedFunction改名为GetConfirmFormModifiedReference,底层代码优化。表示“获取当前页面中表单修改的确认提示框的脚本”。\n\t\t---[updated]删除PageContext中的GetConfirmFormModifiedReference,使用CurrentActiveWindow中的GetConfirmFormModifiedCloseReference\u002FGetConfirmFormModifiedCloseRefreshReference\u002FGetConfirmFormModifiedClosePostBackReference三个方法代替。\n\t\t-不\u003Cem\u003E会\u003C\u002Fem\u003E修改弹出页面的URL(Ext-Window中的IFrame),以前为了实现功能为每个弹出页面\u003Cem\u003E添加\u003C\u002Fem\u003Ebox_parent_client_id查询字符串\n\t\t-去除PageManager的RegisterPageStateChangedScript属性,现在已经将这个功能实现为静态的\u003Cem\u003EJS\u003C\u002Fem\u003E方法。可以通过PageContext.GetFormModifiedConfirmReference获取此方法的客户端脚本。\n\t\t---注意:以前的项目需要在所有的\u003Cem\u003EASP\u003C\u002Fem\u003EX页面中查找RegisterPageStateChangedScript属性,并删除,否则\u003Cem\u003E会\u003C\u002Fem\u003E运\u003Cem\u003E行\u003C\u002Fem\u003E错误!\n\t\t-A页面有Ext-Window控件弹出B页面,B页面有Ext-Window控件弹出C页面,B页面的Ext-Window控件设置Target='_parent',则弹出的Ext-Window(C页面)\u003Cem\u003E会\u003C\u002Fem\u003E覆盖整个A页面,这是正确的。\n\t\t---当时如果用户直接访问B页面,就\u003Cem\u003E会\u003C\u002Fem\u003E报\u003Cem\u003EJS\u003C\u002Fem\u003E错误,因为此时找不到B页面的父页面A了。现在的版本修正为如果找不到父页面,则就在当前页面弹出窗口,这样用户直接访问B页面也不\u003Cem\u003E会\u003C\u002Fem\u003E出错了。\n\t\t-Window控件的GetIFramePageStateChangedFunction函数改名为GetConfirmFormModifiedCloseReference,表示“获取先确认IFrame的页面中表单改变,然后关闭弹出窗口的客户端脚本”。\n\t\t---为Window控件增加如下两个方法GetConfirmFormModifiedCloseRefreshReference和GetConfirmFormModifiedClosePostBackReference,表示“先确认表单改变,然后关闭弹出Ext-Window,再然后刷新父页面或回发父页面”。\n\t\t---Window控件的OnClientCloseButtonClick属性如果不设置,则默认采用GetConfirmFormModifiedCloseReference,也即是先判断表单是否更新,然后在关闭窗口。\n\t\t---现在可以很方便的为Window控件的关闭按钮\u003Cem\u003E添加\u003C\u002Fem\u003E关闭后刷新父页面或者关闭后回发父页面的\u003Cem\u003E行\u003C\u002Fem\u003E为。\n\t\t-如果弹出窗口(Window控件)中IFrame的页面不能正常加载(网络暂时出错或页面抛出异常),则此时点击右上角的关闭按钮\u003Cem\u003E会\u003C\u002Fem\u003E报\u003Cem\u003EJS\u003C\u002Fem\u003E错误,因为此时页面尚未加载完毕。\n\t\t---此版本修正了这个BUG,即时页面不能加载完全,也能通过右上角的关闭按钮关闭弹出含IFrame的窗体。\n\t\t-Window控件的IFrameName属性是\u003Cem\u003E自动\u003C\u002Fem\u003E生成的,只读属性。(因为有可能所有的Ext-Window最终都渲染到最外层的页面,为了保证这些IFrame的name不同,IFrameName使用的是GUID,内部处理)。\n\t\t-CurrentActiveWindow改名为ActiveWindow。\n\t\t-[特别注意]GetWriteBackValueReference(string controlClientIds, string value, params string[] values)函数现在的定义是GetWriteBackValueReference(params string[] values)\n\t\t---所有调用GetWriteBackValueReference的地方,需要删除第一个参数(一般是ActiveWindow.GetLoadStateReference())。\n\t\t\n\t\n\n+2009-02-23 v1.2 beta8\n\t-ContentPanel中内容不能\u003Cem\u003E自动\u003C\u002Fem\u003E扩展高度的BUG[feedback:huihuang]。[fixed]\n\t-DropDownList在Ajax回发时不能计算模拟树的\u003Cem\u003E数据\u003C\u002Fem\u003E[feedback:huihuang]。[fixed]\n\t-DropDownList在页面第一次加载时没有不可选择项,则回发时也不\u003Cem\u003E会\u003C\u002Fem\u003E有不可选择项的BUG。[fixed]\n\t-升级底层Ext\u003Cem\u003EJS\u003C\u002Fem\u003E类库为v2.2.1(此版本主要是Chrome的支持和部分内存泄漏问题的修正)。[fixed]\n\t-页面加载过程中的时间信息保存在Javascript变量window.box.timeInfo中。[added]\n\t+增加部分\u003Cem\u003E自动\u003C\u002Fem\u003E测试支持(使用WatiN和NUnit),下个版本将\u003Cem\u003E会\u003C\u002Fem\u003E提供完整的\u003Cem\u003E自动\u003C\u002Fem\u003E测试支持。[fixed]\n\t\n\t\n\n+2008-10-28 v1.2 beta7\n\t-DropDownList没有选中任何一项,回发时报错[feedback:huihuang]。[fixed]\n\t-Window显示位置不对,以及不能拖动的BUG[feedback:huihuang]。[fixed]\n\t+PageContext优化。[fixed]\n\t\t-去除RegisterExclusiveScript静态函数(这是没有原生ajax之前的产物),使用RegisterStartupScript替代。\n\t\t-去除RegisterStartupScript的重载函数,只保留最简单的PageContext.RegisterStartupScript(string script)函数。\n\t\t-Resirect增加重载函数Redirect(string url, string target),其中target可能的取值为_self,_parent,_top,分别表示在当前窗口,父窗口,顶级窗口重定向[feedback:jqpeng]。\n\t-Image控件增加ImageWidth\u002FImageHeight\u002FImageCssStyle\u002FImageCssClass\u002FImageAlt属性[feedback:jqpeng]。[fixed]\n\t-发布包中增加一个Web.config.txt,这是一个空的Web.config文件,包含BOX基本的配置信息。[fixed]\n\t-ContentPanel的ShowHeader和ShowBorder属性默认也是true(注意更新以前的应用)。[fixed]\n\t-Row和Column布局时,修正IE下设置RowHeight=\"100%\"时显示不正确的BUG。[fixed]\n\t-AccordionLink当鼠标移上和移开时,有背景色的变化效果[feedback:huihuang]。[fixed]\n\t+TabStrip的Tab控件的EnablePostBack属性\u003Cem\u003E会\u003C\u002Fem\u003E在回发时保持(也即是说如果EnablePostBack=true,回发时没改变EnablePostBack的值,则每次切换到此Tab都\u003Cem\u003E会\u003C\u002Fem\u003E回发)。[fixed]\n\t\t-有这样一个效果,如果Tab1默认显示,Tab1的EnablePostBack=true,则页面加载完毕后\u003Cem\u003E会\u003C\u002Fem\u003E回发Tab1一次。\n\t\n\t\n\n+2008-10-20 v1.2 beta6\n\t+使用控件的站点必须建立虚拟目录,否则\u003Cem\u003E会\u003C\u002Fem\u003E报\u003Cem\u003EJS\u003C\u002Fem\u003E错误(即是脚本资源没有加载),却原来是HTTPCompress组件的问题。[fixed]\n\t\t-需要替换新的blowery.Web.HttpCompress.dll,解决方案见http:\u002F\u002Fpohee.com\u002Fit\u002Fhttp-compression-in-\u003Cem\u003Easp\u003C\u002Fem\u003Enet-20\u002F。\n\t+DropDownList优化。[fixed]\n\t\t-去除EnableFirstItem\u002FFirstItemText\u002FFirstItemValue,这个并不能带来很大的好处,反而容易让开发人员困惑。\n\t\t 现在可以方便的在后台DropDownList1.Items.Insert(0, new Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.ListItem(\"全部\", \"-1\"));来达到同样的效果。\n\t\t+如果某项(ListItem)的Value为空字符串,则通过SelectedIndex和SelectedValue不能选中[feedback:jqpeng]。\n\t\t\t-和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net中的保持一致,ListItem的Value值可以为空字符串。 也就是可以这样写DropDownList1.SelectedValue = \"\";\n\t\t-ListItemCollection增加重载函数Add(string text, string value),这样方便后台\u003Cem\u003E添加\u003C\u002Fem\u003E列表项。\n\t-处于布局内的容器控件(Layout!=LayoutType.Container),AutoHeight\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003E自动\u003C\u002Fem\u003E设置为false(避免开发人员发生此类错误)。[fixed]\n\t-注意,控件的高度指的是整个控件的高度,包含BodyPadding(这和CSS中的height不同,CSS中的height是指内容的高度,除去padding\u002Fborder-width\u002Fmargin)。[fixed]\n\t+为所有控件属性增加在VS中的智能提示。[fixed]\n\t\t-需要将Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.XML和Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.dll放在一起,这样引用dll时xml\u003Cem\u003E会\u003C\u002Fem\u003E被拷贝到bin目录下,提供VS的智能提示。\n\t+控件的属性如果是枚举类型,如果此属性可以不取值,则默认为None。[fixed]\n\t\t-TriggerIconType.Default -\u003E TriggerIconType.None\n\t\t-SystemIconType.Empty -\u003E SystemIconType.None\n\t\t-RegexPattern.USER_DEFINED -\u003E RegexPattern.None\n\t-表单验证属性名称变化(ValueToCompare-\u003ECompareValue,ControlToCompare-\u003ECompareControl)。[fixed]\n\t+注意:一个属性可以拥有多个值的情况。[fixed]\n\t\t-属性和CSS相关则用空格分隔(比如ColumnWidths,BodyPadding)。\n\t\t-其他的都是逗号分隔(比如ValidateForms,DataKeyNames,DataNavigateUrlFields)。\n\t+AccordionLink实现为控件。[fixed]\n\t\t-可以方便的在子页面(iframe)中通过\u003Cem\u003Ejs\u003C\u002Fem\u003E切换父页面中选中的菜单项(Accordion-\u003EAccordionLink)(示例在other\u002Faccordion_links_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,other\u002Faccordion_links_run_iframe_htm)[feedback:jima]。\n\t+确认:可以方便的\u003Cem\u003E动态\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E控件,并且可以给控件\u003Cem\u003E添加\u003C\u002Fem\u003E服务器端事件(示例在form\u002Fform_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-10-15 v1.2 beta5\n\t-验证表单字段的ValueToCompare属性,为字符串时\u003Cem\u003E会\u003C\u002Fem\u003E出错的BUG。[fixed]\n\t+优化下拉列表。[fixed]\n\t\t-验证下拉列表时,应该取ListItem的Value属性进\u003Cem\u003E行\u003C\u002Fem\u003E验证,而不是Text属性。\n\t\t-DropDownList的Items增加Insert方法(可方便的下拉列表选项\u003Cem\u003E添加\u003C\u002Fem\u003E“全部”)。\n\t\t-DropDownList不支持EmptyText属性。\n\t\t-ListItem启用EnableSelect和SimulateTreeLevel属性,这样就可以直接在前台(\u003Cem\u003EASP\u003C\u002Fem\u003EX)中设置哪些项不可选择,以及创建模拟下拉树。\n\t\t-DropDownList增加EnableSimulateTree属性(默认为false),如果设置了DataSimulateTreeLevelField,则\u003Cem\u003E自动\u003C\u002Fem\u003E将EnableSimulateTree设置为true。\n\t\n\t\n\n+2008-09-27 v1.2 beta4\n\t+EnableLargeHeader属性对所有容器的效果一样,Accordion的属性EnableLargeHeader只\u003Cem\u003E会\u003C\u002Fem\u003E改变Accordion的标题大小,而不\u003Cem\u003E会\u003C\u002Fem\u003E对AccordionPanel起作用(示例见other\u002Faccordion_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-Accordion去除EnableHightlight属性,AccordionPanel增加EnableHightlight属性。\n\t\t-影响以前使用Box的应用,需要将Accordion的属性去掉,然后为每个AccordionPanel增加EnableLargeHeader和EnableHightlight属性。\n\t-AccordionPanel鼠标移上去的样式调整(现在没有下面的一条白线了)。[fixed]\n\t+AccordionPanel增加Links属性,可以绑定列表\u003Cem\u003E数据\u003C\u002Fem\u003E到AccordionPanel,呈现的是链接的列表(示例在other\u002Faccordion_links_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-原来放置在AccordionPanel中的容器,比如ContentPanel需要在外层加上标签。\n\t\t-适当增大AccordionPanel中链接的高度20px-\u003E22px,同时对链接的样式也\u003Cem\u003E做\u003C\u002Fem\u003E了微调。\n\t\t-通过BodyPadding控制链接列表的边距。\n\t\t-这样能大大减少\u003Cem\u003EASP\u003C\u002Fem\u003EX中HTML代码和Javascript代码的书写,可以在后台\u003Cem\u003E动态\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E链接,效果很赞,此需求由马季提出。\n\t\n\t\n\t\n+2008-09-25 v1.2 beta3\n\t+代码优化与设计时支持(尚需要不断完善,目前可以在\u003Cem\u003EASP\u003C\u002Fem\u003EX页切换到“设计时”,方便属性的更改和事件处理函数的\u003Cem\u003E添加\u003C\u002Fem\u003E)。[fixed]\n\t\t-Panel\u002FGroupPanel\u002FContentPanel\u002FTree\u002FHiddenField\u002FPageLoading\n\t\t-TabStrip\u002FToolbar\n\t-TabStrip去除Plain属性,增加EnableTitleBackgroundColor(默认为true)。[fixed]\n\t-向Form中\u003Cem\u003E动态\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E控件的BUG,现在form\u002Fform_dynamic_run.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例已经能正确运\u003Cem\u003E行\u003C\u002Fem\u003E。[fixed]\n\t+大部分容器的子控件集合更正为Items(以前有些是Rows)。[fixed]\n\t\t-影响的控件包括Toolbar\u002FAccordion\u002FAccordionPanel\u002FGroupPanel\u002FPanel\u002FSimpleForm\u002FWindow等。\n\t\t-保留Form的Rows(FormRowCollection)属性和Grid的Rows属性(GridRowCollection)。\n\t\t-保留TabStrip的Tabs(TabCollection)属性。\n\t\t-保留PageLayout\u002FBorderLayout的Regions(RegionCollection)属性。\n\t-预祝今晚神七发射成功。\n\t\n\t\n\t\n+2008-09-22 v1.2 beta2\n\t+Grid选中项(SelectedRowIndexArray)在ajax回发过程中存在BUG [feedback:xmzhu]。[fixed]\n\t\t-表现为对Grid进\u003Cem\u003E行\u003C\u002Fem\u003E多次删除\u003Cem\u003E添加\u003C\u002Fem\u003E操作后,SelectedRowIndexArray选中项中\u003Cem\u003E会\u003C\u002Fem\u003E存在当前不存在的\u003Cem\u003E行\u003C\u002Fem\u003E序号,导致服务器端遍历选中项时数组越界。所有使用box控件的应用程序都受到此BUG的影响,需尽快更新到新版本。\n\t+代码优化与设计时支持(示例中表单控件都已支持设计)。[fixed]\n\t\t-PageManager\u002FSimpleForm\u002FButton\u002FHyperLink\u002FLabel\u002FImage\u002FLinkButton\u002FTextBox\n\t\t-TriggerBox\u002FTwinTriggerBox\u002FWindow\u002FTextArea\u002FHtmlEditor\u002FDatePicker\u002FNumberBox\n\t\t-CheckBox\u002FRadioButton\u002FRadioButtonList\u002FDropDownList\n\t\t-Grid\n\n\n\n+2008-09-19 v1.2 beta1\n\t-Image\u002FLinkButton\u002FHyperLink增加一些Ajax可更新属性。[fixed]\n\t+隐藏的方式由HideMode属性控制Visibility\u002FOffsets\u002FDisplay。[fixed]\n\t\t-修正Form\u002FSimpleForm中隐藏一个表单字段(Hidden=false)\u003Cem\u003E会\u003C\u002Fem\u003E占据页面空间的BUG。\n\t-ToolbarText\u002FToolbarFill\u002FToolbarSeparator在\u003Cem\u003EASP\u003C\u002Fem\u003EX中设置Hidden=true不起作用的BUG [feedback:jbzhang]。[fixed]\n\t-Button去除MarginRight属性(可以通过CssStyle=\"margin-right:5px;\"达到相同的效果)[fixed]\n\t\n\t\n\t\n+2008-09-09 v1.1\n\t+Toolbar去除IsPageMenu属性,在网报中可以用自定义样式实现,而不应该写在控件中。[fixed]\n\t\t-网报:CssClass=\"toolbar-pagemenu\" CssStyle=\"border:0px;\",同时定义样式:.toolbar-pagemenu{ background: rgb(208, 222, 240) url(..\u002Fimages\u002Fpagemenu_toolbar_background.gif) repeat-x left top;}。\n\t-Region去除默认的Layout=Fit,如果希望Region使用Fit\u002FAnchor\u002FColumn\u002FRow等布局的话,需要手工指定。[fixed]\n\t-ToolbarSeparator\u002FToolbarFill在Ajax更新Hidden属性的BUG。[fixed]\n\t+布局整理。[fixed]\n\t\t-新增Column\u002FAbsolute\u002FRow三种布局,加上以前的Container\u002FFit\u002FAnchor\u002FAccordion\u002FBorder\u002FForm六种布局,总共有9中布局可供使用。\n\t\t-其中一些控件默认使用一种布局:SimpleForm(Form)\u002FForm(Form)\u002FPanel-GroupPanel(Container)\u002FAccordion(Accordion)\u002FPageLayout(Border)\u002FBorderLayout(Border)\u002FTabStrip(Card),所有布局控件默认的布局是Container。\n\t\t-经常用到的布局控件:SimpleForm\u002FForm\u002FAccordion\u002FTabStrip\u002FBorderLayout,经常用到的布局:Fit\u002FRow\u002FAnchor\n\t\n\t\n\t\n+2008-09-08 v1.1 beta7\n\t-MenuButton\u002FMenuHyperLink增加HideOnClick属性,如果一个菜单项的作用仅仅为了弹出下级菜单,点击没反应,则可以这样设置HideOnClick=\"false\" CssStyle=\"cursor:default;\" [feedback:huayu]。[fixed]\n\t-MenuButton\u002FMenuHyperLink\u002FMenuSeparator\u002FMenuText增加Hidden属性(此属性是Ajax可更新属性,如果需要在Ajax时显示隐藏菜单,请使用此属性而不是Visible属性)。[fixed]\n\t+大部分的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件增加Hidden属性(少数几个控件没有此属性:Menu),这样在Ajax时可以显示隐藏控件。[fixed]\n\t\t-注意Visible和Hidden的区别:Visible=false的属性不\u003Cem\u003E会\u003C\u002Fem\u003E渲染到客户端,Hidden=true的控件渲染到客户端但是隐藏。\n\t\t-US的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet改造强烈依赖于此属性,这个版本发布后可以继续。\n\t\t-网报中唯一没有用到Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax的地方就是显示隐藏表单字段,现在也可以使用Ajax了。\n\n\n\n+2008-09-04 v1.1 beta6\n\t-PageContext.Redirect支持普通页面转向和Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax下页面转向。[fixed]\n\t+模拟树的下拉列表的BUG(\u003Cem\u003E会\u003C\u002Fem\u003E使一些可选项变成不可选项)[feedback:xmzhu]。[fixed]\n\t\t-因为if(\"0,2,9,11,\".indexOf('1,')\u003E=0){ok},这显然是不对的,此BUG涉及很多控件(Grid,DropDownList,TabStrip)。\n\t\t-解决方法:testValue += '';if(domValue.split(',').indexOf(testValue) \u003E= 0){ok}。\n\t-DropDownList在Ajax时应该先更新\u003Cem\u003E数据\u003C\u002Fem\u003E再设置选定项 [feedback:xmzhu]。[fixed]\n\t-Button\u002FMenuButton增加Ajax可更新属性OnClientClick [feedback:xmzhu]。[fixed]\n\t-Tree的Ajax支持(尚需优化)。[fixed]\n\t\n\t\n\n+2008-09-02 v1.1 beta5\n\t-DropDownList如果第一次没有绑定值,应该绑定到[[]](二维数组),而不是[](一维数组)。[fixed]\n\t-模拟树的DropDownList,在Ajax重新绑定DataSource后,保持项是否可选状态是最新的(页面第一次加载时,即使没有\u003Cem\u003E数据\u003C\u002Fem\u003E也需要设置DataTextField\u002FDataValueField\u002FDataSimulateTreeLevelField\u002FDataEnableSelectField等属性的值,否则Ajax回发时\u003Cem\u003E会\u003C\u002Fem\u003E出错)。[fixed]\n\t-UserControlConnector导致的Ajax错误,去除UpdatePanelConnector控件(以后不\u003Cem\u003E会\u003C\u002Fem\u003E用\u003Cem\u003EAsp\u003C\u002Fem\u003EnetAjax,这个控件已经完成使命)。[fixed]\n\t-不要使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件HiddenField,而是使用Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet的HiddenField,因为\u003Cem\u003EAsp\u003C\u002Fem\u003E.net的控件在Ajax不\u003Cem\u003E会\u003C\u002Fem\u003E被更新,所以\u003Cem\u003E会\u003C\u002Fem\u003E导致视图状态不一致的错误。[fixed]\n\t-网报Ajax整合基本完成(除了待审批-\u003E下一步[审核\u002F归档\u002F出纳]操作,由于需要显示隐藏表单字段,目前Ajax不支持,使用的还是普通的PostBack)。[fixed]\n\t-IE下,RadioButtonList中项如果存在汉字,则\u003Cem\u003E会\u003C\u002Fem\u003E换\u003Cem\u003E行\u003C\u002Fem\u003E的BUG。[fixed]\n\t-增加两个Theme[Slate\u002FBlack](样式尚需完善)。[fixed]\n\t\n\t\n\t\n+2008-09-01 v1.1 beta4\n\t-非当前Tab中如果有ContentPanel,则在页面上方\u003Cem\u003E会\u003C\u002Fem\u003E有空白(可以通过设置EnableDeferredRender=false解决,但\u003Cem\u003E会\u003C\u002Fem\u003E减慢页面的加载速度),现在已经解决这个问题。[fixed]\n\t-RadioButtonList去除EnableBackgroundColor\u002FEnableLightBackgroundColor属性,背景色是透明的,也就是和父控件(SimpleForm\u002FForm)的背景色一致。[fixed]\n\t-TwinTriggerBox的第一个Trigger图标不\u003Cem\u003E会\u003C\u002Fem\u003E先显示再隐藏,而是直接隐藏掉(如果用户设置ShowTrigger1=false)。[fixed]\n\t-Web.config中增加配置项FormLabelWidth=\"80\"(默认为80),同时PageManager增加FormLabelWidth属性用来控制页面上所有SimpleForm\u002FForm的表单字段标题的宽度。[fixed]\n\t+完善Ajax。[fixed]\n\t\t-RadioButtonList增加Ajax可更新属性SelectedIndex(SelectedValue\u002FSelectedItem)。\n\t\t-DropDownList增加Ajax可更新属性Enable\u002FSelectedIndex(SelectedValue\u002FSelectedItem)\u002FDataSource。\n\t\t-Grid增加Ajax可更新属性Columns(也就是说Grid列在回发时隐藏显示了一些,也能正确的Ajax)。\n\t\t-ToolbarText增加Ajax可更新属性Text。\n\t\t\n\t\t\n\t\t\n+2008-08-31 v1.1 beta3\n\t-TabStrip增加EnableDeferredRender属性(是否启用延迟加载Tab,默认启用)。[fixed]\n\t-重定向页面,使用系统的方法 PageContext.Redirect(string url),使用Response.Redirect方法\u003Cem\u003E会\u003C\u002Fem\u003E出错。[fixed]\n\t+安全的Ajax设计。[fixed]\n\t\t-这个版本Ajax和上个版本(v1.1beta1)在设计思路上有很大区别,同时在速度上\u003Cem\u003E会\u003C\u002Fem\u003E有进一步的提升。\n\t\t-基本思想:安全的Ajax交互,明确Ajax回发时支持控件哪些属性的改变,这将适合90%的应用场景(并且具有极快的反应速度),对于需要UI大改动的可采用常规回发,系统提供控件级别的EnableAjax属性。\n\t\t-整理支持Ajax的控件属性改变列表(所有被支持的属性改变都是安全的、快速的,所有不被支持的属性改变不\u003Cem\u003E会\u003C\u002Fem\u003E对UI起作用,同时是安全的,不\u003Cem\u003E会\u003C\u002Fem\u003E有\u003Cem\u003Ejs\u003C\u002Fem\u003E错误)。\n\t-网报Ajax整合(目前只支持所有的列表页面)(v0.8.1)。[fixed]\n\t\n\t\n\t\n+2008-08-29 v1.1 beta1\n\t+Window控件是否弹出的状态在回发时维持。[fixed]\n\t\t-控件设计的一个原则,凡是可以在客户端改变的属性都应该在回发时保持属性的状态。\n\t+完全抛弃\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax,Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件内置Ajax支持。[fixed]\n\t\t-这是一个值得骄傲的设计,可以明显提高页面回发的速度(相比普通的回发和\u003Cem\u003EAsp\u003C\u002Fem\u003E.netAjax的回发),对于IFrame框架的交互也起到很好的加速效果。\n\t\t-不需要\u003Cem\u003E做\u003C\u002Fem\u003E任何配置,所有的回发都是Ajax(在Web.config和PageManager中有设置启用Ajax回发的属性-EnableAjax-默认为true)。\n\t\t+在这种设计下,其实可以完全抛弃Javascript。\n\t\t\t-比如简单的点击一个按钮弹出窗口,可以在Button的OnClick事件中设置Window1.Popup=true,也可以注册Button的OnClientClick=Window1.GetShowReference()。\n\t\t\t-第一种方法需要回发,但是我们内置的Ajax支持能很快的返回需要的结果并解析,在网络速度很快的情况下和第二种方法差别不是很大。\n\t\t\t-推荐的\u003Cem\u003E做\u003C\u002Fem\u003E法是尽量用客户端实现,客户端实现复杂的直接用服务器端实现。\n\t\t+目前Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax的限制。\n\t\t\t-只对Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件起作用,对\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件不起作用。\n\t\t\t-对容器控件(有子控件的控件)不起作用,只对最底层的控件起作用。\n\t\t\t-对改变控件的Visible属性\u003Cem\u003E会\u003C\u002Fem\u003E有错误。\n\t\t\t-Window控件的属性改变只有少数几个起作用(Popup,IFrameUrl)。\n\t-PageManager增加属性EnablePageLoading和EnableAjaxLoading(启用页面第一次加载标示和Ajax加载标示,默认都为true),所以如果使用系统默认的加载标示就不必每个页面都\u003Cem\u003E添加\u003C\u002Fem\u003EPageLoading控件。[fixed]\n\t-Grid中的回发事件(主要是LinkButtonField和CheckBoxField(RenderAsStaticField=false))要延迟0ms执\u003Cem\u003E行\u003C\u002Fem\u003E,这样当前\u003Cem\u003E行\u003C\u002Fem\u003E被选中的状态在回发后\u003Cem\u003E会\u003C\u002Fem\u003E得到保持。[fixed]\n\t-Grid选中\u003Cem\u003E行\u003C\u002Fem\u003E的状态在第一次回发时不能保持的BUG。[fixed]\n\t\n\t\n\t\n+2008-08-26 v1.0\n\t+已知问题:IE的ActiveX插件IE Developer Toolbar\u003Cem\u003E会\u003C\u002Fem\u003E对IFrame的加载造成0.5m左右的延迟。\n\t\t-主要是父页面加载一个比较大的css文件(~100k),则每次打开iframe页面,onload事件的调用都\u003Cem\u003E会\u003C\u002Fem\u003E有500ms左右的延迟,在测试IE性能时要禁用此插件。\n\t+优化弹出窗口中IFrame的显示速度。[fixed]\n\t\t-在当前页面弹出窗口需要~20ms,在父页面弹出窗口需要100~300ms。通过缓存弹出的窗口实例,从而第二次弹出窗口不再需要创建时间。\n\t-PageLayout的Region增加SplitColor属性,默认的背景色是透明的。(在网报中需要设置SplitColor=\"#CADDF7\",以便分隔符的颜色和Toolbar的颜色一致)[fixed]\n\t+PageManager增加属性Theme、Language、FormMessageTarget、FormOffsetRight等属性,这些属性可以在Web.config中设置(推荐方法),也可以为每个页面设置。[fixed]\n\t\t-一个典型的应用是为每个用户设置不同的皮肤(根据用户浏览器中Cookie设置的值)(示例在default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-TreeNode增加属性SingleClickExpand,表示点击可切换节点的折叠展开状态。[fixed]\n\t+TabStrip中非当前Tab\u003Cem\u003E会\u003C\u002Fem\u003E延迟渲染。[fixed]\n\t\t-这\u003Cem\u003E会\u003C\u002Fem\u003E明显加快页面的渲染速度,网报中一个典型的费用审批页面可以减少200ms的渲染时间。\n\t\t-由于非当前Tab不\u003Cem\u003E会\u003C\u002Fem\u003E在页面加载时渲染,所以那些Tab中的节点在页面加载后也是不可见的,需要将相关的脚本移动到控件的render事件中。\n\t-不能比较两个DataPicker大小的BUG。[fixed]\n\t-TabStrip延迟加载引起的BUG(非当前Tab中的ContentPanel\u003Cem\u003E会\u003C\u002Fem\u003E占据页面空间,已修正)。[fixed]\n\t-全新的Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet.Examples(基础知识\u002F表单控件\u002F\u003Cem\u003E数据\u003C\u002Fem\u003E绑定\u002F容器布局\u002FIFrame框架)。[fixed]\n\t\n\t\n\t\n+2008-08-19 v0.4 beta6\n\t+PageManager增加两个属性(EnableInlineStyleJavascript\u002FApplyParentStyleJavascript),可以在IFrame页面中使用父页面的脚本和样式(示例在iframe\u002Fdefault.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-测试发现,IFrame页面的加载速度并没有明显加快,可以先不使用此属性。\n\t-RadioButtonList放在在BorderLayout中显示不了的BUG [feedback:zgjiang2]。[fixed]\n\t+ext\u003Cem\u003Ejs\u003C\u002Fem\u003E的BUG,当页面中含有iframe时,Ext.onReady\u003Cem\u003E会\u003C\u002Fem\u003E被调用两次(IE6\u002FIE7)(http:\u002F\u002Fwww.ext\u003Cem\u003Ejs\u003C\u002Fem\u003E.net\u002Fforum\u002Fshowthread.php?t=43246)(示例在test.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-现在的解决方法是在初始化时:if(this.initialized){return;}this.initialized=true;\n\t+需要先回发页面再弹出IFrame窗口。[fixed]\n\t\t-在回发时设置窗口的Popup和IFrameUrl属性,因为这些属性是可以保持状态的,所以在关闭窗口时要注意设置Popup=false。\n\t\t-另一种\u003Cem\u003E做\u003C\u002Fem\u003E法(推荐):PageContext.RegisterStartupScript(Window99.GetShowReference(\".\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\"));。\n\t\n\t\t\n\t\n+2008-08-15 v0.4 beta5\n\t-点击关闭窗口的按钮,在IE6下\u003Cem\u003E会\u003C\u002Fem\u003E有\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-增加BorderLayout控件,示例在iframe\u002Fborderlayout.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。[fixed]\n\t+Radiobuttonlist显示有重影(示例在radio.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-全新的样式。\n\t\t-去除Horizontal属性,增加ColumnNumber(可以设置渲染成几列)。\n\t\t-GetValueReference取得的值不正确的BUG。\n\t-\u003Cem\u003E动态\u003C\u002Fem\u003E向Form中\u003Cem\u003E添加\u003C\u002Fem\u003EFormRow,并\u003Cem\u003E动态\u003C\u002Fem\u003E的向FormRow中\u003Cem\u003E添加\u003C\u002Fem\u003E表单字段,以及如何取得表单字段的值。(示例在form_dynamic.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t+IFrame弹出窗口关闭后回发父页面,则\u003Cem\u003E会\u003C\u002Fem\u003E多加载IFrame一次,再次打开窗口\u003Cem\u003E会\u003C\u002Fem\u003E重复加载IFrame2-3次[feedback:xmzhu]。[fixed]\n\t\t-这是一个重要的BUG,\u003Cem\u003E会\u003C\u002Fem\u003E严重影响页面的加载速度。原因是通过脚本改变的IFrameUrl\u003Cem\u003E会\u003C\u002Fem\u003E在回发时保持状态,从而回发父页面后Window中的IFrame被\u003Cem\u003E添加\u003C\u002Fem\u003E到页面,而这是不需要的。\n\t\t-现在\"是否弹出窗口、窗口标题、IFrameUrl\"在客户端的改变,不\u003Cem\u003E会\u003C\u002Fem\u003E影响服务器端的属性,也即是不保持状态。此问题解决。(示例在button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\n\t\n\t\n+2008-08-13 v0.4 beta4\n\t-点击关闭窗口的按钮,在IE下\u003Cem\u003E会\u003C\u002Fem\u003E有\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-Window的右上角关闭图标增加提示,优化事件响应。[fixed]\t\n\t-Window的代码重构。[fixed]\t\n\t+修正一个的内存泄漏。[fixed]\n\t\t-IE7下测试,打开iframe\u002Fdefault.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面,iexplorer占内存68.368M。\n\t\t-内存存在泄漏时,点击iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面8次后iexplorer占118.792M内存。\n\t\t-修正后,点击iframe\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面8次后iexplorer占76.492M内存。\n\t\t-IE窗口最小化时,IE\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003E自动\u003C\u002Fem\u003E进\u003Cem\u003E行\u003C\u002Fem\u003E垃圾回收。\n\t\n\t\n\t\n+2008-08-12 v0.4 beta3\n\t-底层的javascript框架Ext\u003Cem\u003Ejs\u003C\u002Fem\u003E升级为v2.2,Grid的渲染速度有很大提升。[fixed]\n\t-Grid的EnableDelayRender默认为true(如果没有设置Grid的高度或通过布局间接设置高度,则\u003Cem\u003E行\u003C\u002Fem\u003E不可见,可以通过AutoHeight=\"true\"解决)。[fixed]\n\t+页面正在加载的提示尽早的显示出来。[fixed]\n\t\t-首先在执\u003Cem\u003E行\u003C\u002Fem\u003E\u003Cem\u003Ejs\u003C\u002Fem\u003E来完成页面渲染之前延迟5ms,以便浏览器把当前页面内容显示出来。\n\t\t-加载\u003Cem\u003Ejs\u003C\u002Fem\u003E脚本的script标签放置在页面的最后,放置加载\u003Cem\u003Ejs\u003C\u002Fem\u003E而阻塞PageLoading的显示。\n\t\n\t\n\t\n+2008-08-08 v0.4 beta2\n\t-TabStrip延时加载出错。[fixed]\n\t-Window的IFrameUrl处理的BUG,比如Pages_Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet目录下的页面应该为.\u002FFE_ApplyEditor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex或~\u002FPages_Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet\u002FFE_ApplyEditor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。[fixed]\n\t-Window的WindowPosition=\"Center\"并且Target=\"_parent\",则\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003EJS\u003C\u002Fem\u003E错误。[fixed]\n\t-实现网报首页下拉菜单和左侧菜单的导航功能。[fixed]\n\t-Window的创建在页面显示后进\u003Cem\u003E行\u003C\u002Fem\u003E,不计算在\u003Cem\u003Ejs\u003C\u002Fem\u003E渲染时间内。[fixed]\n\t-优化费用申请页面(尽量减少不必要的层次嵌套)。[fixed]\n\t-button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex默认\u003Cem\u003E会\u003C\u002Fem\u003E加载form.\u003Cem\u003Easp\u003C\u002Fem\u003Ex页面(Window控件的BUG)。[fixed]\n\t-Window中的保存并关闭按钮和\u003Cem\u003EAsp\u003C\u002Fem\u003E.netAjax冲突。[fixed]\n\t-优化关闭Window的\u003Cem\u003Ejs\u003C\u002Fem\u003E脚本,减少写到页面的\u003Cem\u003Ejs\u003C\u002Fem\u003E大小。[fixed]\n\t-加快“保存并关闭”按钮关闭窗口的速度,使用PageContext.RegisterExclusiveScript(CurrentActiveWindow.GetClosePostBackReference());,示例在(simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-08-05 v0.4 beta1\n\t-DropDownList去除Traditional属性,和传统的\u003Cem\u003EAsp\u003C\u002Fem\u003E.net控件一样不可编辑。[fixed]\n\t-DropDownList增加SelectedText属性(去除了模拟树时通过SelectedItem.Text的多余html字符)。[fixed]\n\t-为了加快渲染速度,去掉一些特效(比如Panel的折叠效果,Grid的拖动列效果等)[feedback:dcding]。[fixed]\n\t-将生成的\u003Cem\u003Ejs\u003C\u002Fem\u003E对象的名称简单化,这样可以减少生成的\u003Cem\u003Ejs\u003C\u002Fem\u003E内容,加快页面加载速度(一个典型页面的\u003Cem\u003Ejs\u003C\u002Fem\u003E由原来的33.0k降低为21.4k)。[fixed]\n\t+弹出窗口中,点击按钮回发然后点击关闭按钮,出现\u003Cem\u003Ejs\u003C\u002Fem\u003E错误 [feedback:xmzhu]。[fixed]\n\t\t-因为在页面的Page_Load中,if (!IsPostBack){PageContext.RegisterPageStateChangedStartupScript();}通过这样方法向页面注册了一段脚本,但是这段脚本在回发时没有注册到页面,因为\u003Cem\u003Ejs\u003C\u002Fem\u003E调用此脚本时报错。\n\t\t-一种解决方法是将向页面注册脚本的函数移动到if语句的外面,即每次都向页面注册此脚本。\n\t\t-另一种办法就是在PageManager控件中增加RegisterPageStateChangedScript(向页面注册监视页面中表单内容改变的脚本)的属性(\u003Cem\u003E会\u003C\u002Fem\u003E在每次页面回发(包含ajax回发)时注册脚本)(示例在button_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t+PageManager控件增加ExecuteOnReadyWhenPostBack属性(示例在onreadyscript.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-这个手工\u003Cem\u003E添加\u003C\u002Fem\u003EonReady函数能够在每次页面回发时都注册脚本(包括Ajax局部回发),这就避免了手工去\u003Cem\u003E做\u003C\u002Fem\u003E的麻烦(已经在网报中遇到这种情况)。\n\t-每个页面必须\u003Cem\u003E添加\u003C\u002Fem\u003E一个PageManager控件,否则\u003Cem\u003E会\u003C\u002Fem\u003E出错,同时去除DesignTimeStyle控件(作为PageManager的属性出现)。[fixed]\n\t-TextField等表单字段增加Readonly属性。[fixed]\n\t+全新设计的IFrame的架构(尽可能和基于MasterPage的架构保持兼容,和\u003Cem\u003EAsp\u003C\u002Fem\u003E.net Ajax保持兼容)。[fixed]\n\t\t-最大的好处是可以减少页面下载完毕后Javascript渲染时间(可以节约一般的渲染时间)。(所有示例在iframe文件夹下)\n\t\t+示例1,通过点击按钮弹出IFrame窗口,可直接关闭父页面,也可在关闭后刷新或回发父页面。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fpage2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\n\t\t\t-虽然IFrame和Master两种架构差异迥然,或许你以为需要修改一堆代码来完成这种转换,起初我也是这么认为的,但是现在你所要\u003Cem\u003E做\u003C\u002Fem\u003E的仅仅是为Window控件增加一个属性(Target=\"_parent\"),就完成了两种框架的转换,是不是很酷。\n\t\t\t-显然,控件本身封装了大量的代码,简单来看现在有三个页面(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(A)\u002Fpage2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(B)\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex(C)),其中A包含B页面,当你在B中打开包含有页面C的窗口时,窗口不是在B中打开,而是在A中打开,这样才能保证窗口覆盖整个页面,当你从C中返回需要回发页面B时,却发现取得的是A页面,因为我们窗口是在A页面中创建的。我\u003Cem\u003E会\u003C\u002Fem\u003E通过一篇文章来揭示这一过程,敬请期待。\n\t\t-示例2,Grid中弹出窗口。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fpage3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\t\n\t\t+示例3,TriggerBox弹出窗口。(default.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Ftriggerbox.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)\t\n\t\t\t-在整个页面弹出窗口或者在当前页面弹出窗口,仅仅设置Window的Target属性即可。\n\t\t-示例4,弹出窗口中的弹出窗口。\n\t-对整个Examples更新测试。[fixed]\n\t\n\t\n\t\n+2008-07-31 v0.3 beta12\n\t-IE下TabStrip在Ajax回发后不\u003Cem\u003E会\u003C\u002Fem\u003E去掉x-hide-display样式,导致Tab显示为空的BUG。[fixed]\n\t-对TabStrip\u002FPanel\u002FWindow中的IFrame重新设计,如果设置IFrameUrl=\"#\"或者\"about:blank\",则不渲染iframe到页面节点,同时第二次打开Window中的IFrame不\u003Cem\u003E会\u003C\u002Fem\u003E有残影出现。[fixed]\n\t-如果TabStrip的Tab不是激活Tab并且设置了IFrameUrl,则\u003Cem\u003E会\u003C\u002Fem\u003E延迟加载(示例在tabstrip_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-Tree控件,点击一个节点\u003Cem\u003E自动\u003C\u002Fem\u003E回发,则当前点击的那个节点的选中状态不\u003Cem\u003E会\u003C\u002Fem\u003E保持的BUG [feedback:zgjiang2]。[fixed]\n\t+规范关闭窗口时提示用户保存已经修改的内容提示的调用方式(包含iframe中关闭按钮和window右上角关闭图标的调用方式)(示例在grid_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-内部实现上,点击“保存并关闭按钮”,可以将关闭窗口的脚本更早的执\u003Cem\u003E行\u003C\u002Fem\u003E(在simpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,PageContext.RegisterStartupScript增加重载函数),而不是原来的先创建整个页面UI,再关闭窗口。\n\t-参照Yslow的评分规则,将\u003Cem\u003EJS\u003C\u002Fem\u003E文件引用由head移动到body中。[fixed]\n\t-Firefox下,如果页面太长\u003Cem\u003E会\u003C\u002Fem\u003E出滚动条,原来在ViewPort样式中有body{overflow:hidden;}。[fixed]\n\t+IFrame内的页面宽度和高度\u003Cem\u003E会\u003C\u002Fem\u003E\u003Cem\u003E自动\u003C\u002Fem\u003E设置(是不是还在为1px\u002F2px的白边而烦恼,现在不用了:-)(示例在iframe_autosize.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-增加PageManager控件(需要指定AutoSizePanelID,即需要设置宽度和高度为整个页面的宽度和高度的Panel),HideScrollbar属性用于隐藏滚动条(IE\u002FFirefox)。\n\t\n\t\n\t\n+2008-07-24 v0.3 beta11\n\t-web.config配置信息中MessageTarget改名为FormMessageTarget,增加FormOffsetRight配置项,用来定义全局表单字段距离右边界的宽度,同时每个表单字段都增加OffsetRight属性 [feedback:jima]。[fixed]\n\t-Window在回发时设置的Title不起作用的BUG。[fixed]\n\t-增加Image控件 [feedback:jima]。[fixed]\n\t-Tree控件,如果一个节点不是叶子节点并且没有子节点,则应把它的Expanded设置为false,否则\u003Cem\u003E会\u003C\u002Fem\u003E引起页面死循环回发 [feedback:zgjiang2]。[fixed]\n\t-Image增加ToolTipTitle\u002FToolTipAutoHide两个属性,当提示信息特别长时,可以让用户阅读完毕之后手工关闭提示信息(示例在hyperlink.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-去掉DropDownList控件的Text属性(强制性),可以通过设置SelectedValue来设置选中哪一项 [feedback:xmzhu]。[fixed]\n\t-过滤提示消息中的换\u003Cem\u003E行\u003C\u002Fem\u003E符(转换为),否则提示信息可能导致页面渲染错误 [feedback:dcding]。[fixed]\n\t\n\t\n\t\n+2008-07-23 v0.3 beta10\n\t+完善Tree控件。[fixed]\n\t\t-如何将\u003Cem\u003E数据\u003C\u002Fem\u003E库中的\u003Cem\u003E数据\u003C\u002Fem\u003E绑定到Tree(示例在tree2_bind_database.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-ajax加载树节点,放在UpdatePanel中才有ajax的效果(示例在tree2_ajax.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-更改TreeNode的ID为NodeId,否则两个树中不能有相同ID的TreeNode,这是不合理的。\n\t-Grid的GridColumn的ID改名成ColumnId,否则同一个页面放置两个Grid,它们的GridColumn的ID不能同名,这是不合理的。注意需要更新以前的代码![fixed]\n\t-Grid所有类型的列增加DataTooltipField\u002FDataTooltipFormatString两个字段,以显示ToolTip(示例在grid.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-07-22 v0.3 beta9\n\t+IE6下,左侧导航链接的选中样式,以及鼠标移上去和移开的样式不对。[fixed]\n\t\t-发现原来ie6不能正确解析li的高度,必须手工设置才\u003Cem\u003E行\u003C\u002Fem\u003E(style=\"height:20px;\")。\n\t+IE6\u002FIE7下,模拟树的下拉列表如果文字长度太长,则显示的文字\u003Cem\u003E会\u003C\u002Fem\u003E换\u003Cem\u003E行\u003C\u002Fem\u003E,导致错位。[fixed]\n\t\t-虽然最后未能解决##差旅交通费在IE和Firefox下显示的不同效果。\n\t\t-但是通过用来代替,从而实现FF和IE下样式的统一。\n\t\t-刚看到old9的解决方案:把“差旅交通费”改成“差旅交通费”,在IE下和FF下的都不换\u003Cem\u003E行\u003C\u002Fem\u003E,:-)\n\t-LinkButton增加OnClick事件 [feedback:huihuang]。[fixed]\n\t-Window通过设置IFrameUrl和Popup不起作用的BUG。[feedback:xmzhu]。[fixed]\n\t+增加树控件(Tree)(示例在tree2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-可以在回发时维持树的状态(选中\u003Cem\u003E行\u003C\u002Fem\u003E,折叠\u002F展开,CheckBox)。\n\t\t-可以通过Inline的方式\u003Cem\u003E添加\u003C\u002Fem\u003E树节点,也可以绑定到XmlDocument\u002FXmlDataSource\u002FSiteMap。\n\t\t-点击树节点可以链接到页面,也可以引发PostBack事件,可以\u003Cem\u003E添加\u003C\u002Fem\u003E自定义脚本。\n\t\n\t\n\t\n+2008-07-16 v0.3 beta8\n\t+ContentPanel中放置Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,则渲染时\u003Cem\u003E会\u003C\u002Fem\u003E出现各种问题,比如下拉列表显示样式出错,Grid没了滚动条等等。[fixed]\n\t\t-隐蔽性非常强,原来在ContentPanel中渲染Ext\u003Cem\u003EAsp\u003C\u002Fem\u003ENet控件,如果容器的display='none',则\u003Cem\u003E会\u003C\u002Fem\u003E出现各种问题(主要是大小不对)。\n\t\t 必须设置容器为visibility='hidden',然后在渲染完成后显示容器。\n\t\t-现在Grid只要显示的设置高度和宽度,或者隐式的设定宽度高度(通过Anchor或Fit布局实现),只要超过Grid容器就\u003Cem\u003E会\u003C\u002Fem\u003E显示滚动条。\n\t+IE6下,在应用\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax后,Form中字段的宽度渲染不正确。[fixed]\n\t\t-调试相当困难,如果你有过在IE下通过alert发现问题的经历,你就能明白。\n\t\t-最后发现IE6下应用\u003Cem\u003EAsp\u003C\u002Fem\u003E.NetAjax后不仅Form中列的宽度设置不正确,而且主内容区域的宽度设置也不正确,不过最终我们还是顽强的修复了IE6下的这个BUG:\n\t\t 在MasterPage的onReady函数中,首先修正内容区域的宽度(region3.setWidth(pageLayout1.getSize().width - region2.getSize().width - 5);region3.doLayout();),然后修正页面中所有表单的宽度(box_fixFormWidthInIE6();):\n\t\t 示例在 Site.Master 页面。\n\t+集成的\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax有一个很大的BUG,只要你在页面上进\u003Cem\u003E行\u003C\u002Fem\u003E过ajax操作,当改变窗口大小时你\u003Cem\u003E会\u003C\u002Fem\u003E惊讶的发现内容区域的内容全部为空了![fixed]\n\t\t-解决方法相当怪异,经过一个下午的不断尝试,终于用一个怪异的方法解决(box.{0}.setSize(box.{0}.getSize());box.{0}.doLayout();),\n\t\t 这样的代码让我想起刷新窗口时那个方法(window.location.href=window.location.href;),不管怎么说,我对能很好的解决这个重大的BUG很是欣喜。\n\t\n\t\n\t\n+2008-07-14 v0.3 beta6\n\t-增加FlashObject控件。[fixed]\n\t-PageLoading增加EnableFadeOut属性(默认false),可以启用淡出效果。[fixed]\n\t-Accordion选中样式微调。[fixed]\n\t-预加载Form表单出错时提示信息的背景图片。[fixed]\n\t+Grid增加EnableDelayRender属性(默认false),可以加快页面的渲染速度(一个典型的20个记录的页面,可提前0.7s-1s显示出来)。[fixed]\n\t\t-因为延迟加载\u003Cem\u003E数据\u003C\u002Fem\u003E不\u003Cem\u003E会\u003C\u002Fem\u003E改变Grid的大小,所以对于非布局内或不设定高度宽度的Grid,需要设置\"EnableDelayRender=false\"。\n\t-改变Grid中静态的CheckBoxField图片。[fixed]\n\t-TabStrip增加TabIndexChanged事件,同时Tab增加EnablePostBack,可以在点击一个Tab时引起回发事件。这在延迟加载Tab的内容非常有用。(示例在tabstrip.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\n\t\n\t\n+2008-07-12 v0.3 beta5\n\t-页面菜单Toolbar的分割符和背景不相融合。[fixed]\n\t-表单字段之间可以比较大小,比如NumberBox可以和Label比较大小,同时增加CompareType,来指定比较的类型(示例在form_compare.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-如果是同种类型的表单字段,不需要指定CompareType,比如两个NumberBox比较值的大小不需要指定CompareType,而一个NumberBox和TextBox比较大小需要指定CompareType。\n\t+如果在编辑页面使用\u003Cem\u003EAsp\u003C\u002Fem\u003ENetAjax,则不能在回发时关闭当前窗口[feedback:huihuang](示例在ajax_editor_main.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fajax_editor.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-这是由于ajax后执\u003Cem\u003E行\u003C\u002Fem\u003E的javascript中不能有return false语句。\n\t+在文本框失去焦点时,执\u003Cem\u003E行\u003C\u002Fem\u003E一些Javascript脚本(示例在textbox_blur.\u003Cem\u003Easp\u003C\u002Fem\u003Ex) [feedback:xmzhu]。[fixed]\n\t\t-在页面\u003Cem\u003E添加\u003C\u002Fem\u003EonReady函数(\u003Cem\u003E会\u003C\u002Fem\u003E被系统调用),然后用javascript监视文本框值的改变。\n\t-弹出Window默认显示的错误页面,解决方法在当前目录\u003Cem\u003E添加\u003C\u002Fem\u003E一个空的html页面,然后把Window控件的IFrameUrl指向这个页面而不是\"#\"。[fixed]\n\t+弹出的窗口中的弹出窗口的如果内容发生变化,则点击右上角的关闭按钮时\u003Cem\u003E会\u003C\u002Fem\u003E有提示用户先保存的对话框,但是这个对话框的被第二个弹出窗口覆盖了 [feedback:xmzhu]。[fixed]\n\t\t-原来的调用方法太麻烦(见示例中alert\\alert_1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和alert\\alert_2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex,总计 6 \u003Cem\u003E行\u003C\u002Fem\u003E代码),现在只需要 3 \u003Cem\u003E行\u003C\u002Fem\u003E代码就OK了。\n\t-点击提交按钮后变成灰色不可再次点击(示例在button_click_gray.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t+增加Menu、MenuText、MenuSeparator、MenuButton、MenuHyperLink控件,用于按钮的下拉菜单(示例在button_menu.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-增加SplitButton控件。[fixed]\n\t\n\t\n\t\n+2008-07-09 v0.3 beta4\n\t-DataPicker默认的日期格式为(yyyy-MM-dd)。[fixed]\n\t+Form表单字段(TextBox,DropDownList...)之间可以比较大小 [feedback:huihuang]。[fixed]\n\t\t-增加ControlToCompare\u002FValueToCompare\u002FCompareOperator\u002FCompareMessage四个属性,示例在form_compare.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t+TabStrip中放置IFrame\u003Cem\u003E会\u003C\u002Fem\u003E出现渲染错误 (示例在tabstrip_iframe.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t\t-特殊处理,拥有IFrame的Tab如果不是激活Tab,则不设置Url,只有在激活时才设置Url。\n\t-RadioButtonList增加AutoPostBack属性(示例在radio.\u003Cem\u003Easp\u003C\u002Fem\u003Ex) [feedback:xmzhu]。[fixed]\n\t-FormRow可以设置各列的宽度百分比 (示例在form_columnwidths.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[feedback:jima]。[fixed]\n\t+表单字段Enable=false时显示颜色太浅 [feedback:jima]。[fixed]\n\t\t-覆盖缺省样式的.x-item-disabled,设置不透明。\n\t\n\t\n\t\n+2008-07-08 v0.3 beta3\n\t-Grid没有\u003Cem\u003E数据\u003C\u002Fem\u003E,向后翻页按钮可以点击的BUG [feedback:huihuang]。[fixed]\n\t+增加HiddenField控件。[fixed]\n\t\t-其实用TextBox也能模拟HiddenField的\u003Cem\u003E行\u003C\u002Fem\u003E为,只需要设置CssStyle=\"display:none;\"即可。\n\t+TriggerBox 如果 EnableTextBox = true,则不能将Text回发(这是html的限制)。[fixed]\n\t\t-最后的解决方案居然是设置 readonly=true,同时更改属性为 Readonly(示例在textbox2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-模拟树的下拉列表在失去焦点后显示的文字不对的BUG。[fixed]\n\t+控制下拉列表某些项不可以选择(示例在dropdownlist2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-增加 DataEnableSelectField 属性,不可选择的项变灰,并且鼠标经过时没有样式。\n\t-LinkButton和Grid的LinkButtonField增加Enable属性(示例在hyperlink.\u003Cem\u003Easp\u003C\u002Fem\u003Ex和grid.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\n\t\n\t\n+2008-07-07 v0.3 beta2\n\t+增加UpdatePanelConnector控件,支持在布局构建的页面使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net Ajax。[fixed]\n\t\t-使用UpdatePanelConnector有一个要求:ContentTemplate下只能有一个子节点,比如box:Panel。\n\t\t-示例在ajax3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fcontent_page4.\u003Cem\u003Easp\u003C\u002Fem\u003Ex。\n\t\t-示例content_page3.\u003Cem\u003Easp\u003C\u002Fem\u003Ex中,点击“Ajax查询”按钮和关闭弹出的窗口(点击右上角的叉)都引发异步更新。\n\t \n\t \n\t\n+2008-07-03 v0.3 beta1\n\t+容器控件的AutoHeight\u002FAutoWidth默认为false。[fixed]\n\t\t-使用GroupPanel的地方需要手工\u003Cem\u003E添加\u003C\u002Fem\u003EAutoHeight=\"true\"属性。\n\t+增加UserControlConnector,可以在其中放置用户控件(示例在page_usercontrol.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-也可以在ContentPanel中放置用户控件,注意两者的区别。\n\t+增加ContentPlaceHolderConnector,替换原来Region的ContentPlaceHolderId属性(示例在Site.master)。[fixed]\n\t+支持\u003Cem\u003EAsp\u003C\u002Fem\u003E.net ajax异步加载。[fixed]\n\t\t-有很大局限性,只能在ContentPanel中使用,示例在ajax1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fcontent_ajax2.\u003Cem\u003Easp\u003C\u002Fem\u003Ex中。\n\t\t-对于使用布局构建的页面(比如content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)还不能使用\u003Cem\u003EAsp\u003C\u002Fem\u003E.net ajax,因为页面是整体渲染的,先放弃。\n\t\n\t\n\t\n+2008-07-02 v0.2 beta12\n\t+关闭前提示当前页面已经被修改(示例在content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-支持Iframe内按钮和window右上角关闭按钮。\n\t\t-删除CloseAction属性,可以在后台通过OnClientCloseButtonClick属性指定(为了和iframe中\u003Cem\u003E做\u003C\u002Fem\u003E法一致)。\n\t+iframe中的alert\u002Fconfirm要覆盖整个父页面,而不仅仅是iframe页面。[fixed]\n\t\t-在Firefox下还有问题。[fix pending]\n\t+排序时在标题栏显示排序箭头,可以排序的列标题光标为手形(示例在grid_sorting.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t-可以通过设置Grid1.CurrentSortColumnIndex = 0;来强制某列显示排序箭头。\n\t\t-可以通过 Grid1.Columns[Grid1.CurrentSortColumnIndex].SortExpression 的方式取得当前Grid的排序表达式。\n\t+HyperLinkField\u002FWindowField的链接地址支持服务器端格式(即是~\u002Falert.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-TabStrip的Tab中如果放置ContentPanel,则内容渲染位置不正确。[fixed]\n\t-可以在ContentPanel中放置用户控件(示例在page_usercontrol.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t\t\n\t\n\t\n+2008-06-30 v0.2 beta11\n\t-增加TwinTriggerBox控件(示例在twintriggerbox.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-Grid的\u003Cem\u003E数据\u003C\u002Fem\u003E库分页需要增加属性IsDatabasePaging=true,以便普通分页和\u003Cem\u003E数据\u003C\u002Fem\u003E库分页,否则在\u003Cem\u003E添加\u003C\u002Fem\u003E删除记录时总记录数不\u003Cem\u003E会\u003C\u002Fem\u003E变化 [feedback:zgjiang2]。[fixed]\n\t-关闭Window时PostBack事件OnClose可以指定参数,来区分是哪些操作引发的PostBack事件 [feedback:zgjiang2](示例在window_postback.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。[fixed]\n\t-如果表单验证不通过,则需要弹出对话框提示(第一个没通过验证的字段)(目前还不能切换到相应的tab)。[fixed]\n\t+页面中任意可输入表单字段发生变化,可提示先保存。(示例在content_page1.\u003Cem\u003Easp\u003C\u002Fem\u003Ex\u002Fsimpleform.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)[fixed]\n\t\t-目前还不支持Window右上角关闭按钮的提示保存功能。\n\t-Master\u002FContent的内容页中Grid的Sort事件不起作用的BUG [feedback:zgjiang2]。[fixed]\n\t-Grid中的LinkButtonField设置ConfirmText\u003Cem\u003E会\u003C\u002Fem\u003E出错 [feedback:huihuang]。[fixed]\n\t-增加静态类Confirm。[fixed]\n\t\n\t\n\t\n+2008-06-27 v0.2 beta10\n\t+Grid完善。[fixed]\n\t\t-CheckBoxField在回发时不能保持状态的BUG (已经更新了grid_checkboxfield.\u003Cem\u003Easp\u003C\u002Fem\u003Ex示例)。\n\t\t-Grid中模拟树显示,GridColumn增加DataSimulateTreeLevelField属性(一个Grid只能有一个Column指定此属性),指定此列模拟树显示时的层次字段(0,1,2,...)(示例在grid_simulate_tree.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\t-切换分页时清空选中的值 [feedback:jqpeng]。\n\t\t-增加PreRowDataBound事件,可以在\u003Cem\u003E数据\u003C\u002Fem\u003E绑定之前设置某列的属性 [feedback:xmzhu] (示例在grid_prerowdatabound.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t-DropDownList模拟树的方式显示,增加DataSimulateTreeLevelField属性,使用方法和Grid的类似(示例在dropdownlist_simulate_tree.\u003Cem\u003Easp\u003C\u002Fem\u003Ex)。\n\t\n\t\n\t\n+2008-06-25 v0.2 beta9\n\t+Window窗体中的","createTime":"2010-09-29 14:37:08","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"2\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fwode2600\u002F2726130\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-2-2726130-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fzrf139138\u002F6207707","title":"JavaScript网页特效范例宝典源码","desc":"目录: \n\n第1章 窗口\u002F框架与导航条设计 1\n1.1 弹出窗口控制 2\n实例001 打开新窗口显示广告信息 2\n实例002 定时打开窗口 4\n实例003 通过按钮创建窗口 5\n实例004 \u003Cem\u003E自动\u003C\u002Fem\u003E关闭的广告窗口 6\n实例005 控制弹出窗口居中显示 7\n实例006 弹出的窗口之Cookie控制 9\n实例007 为弹出的窗口加入关闭按钮 11\n实例008 关闭弹出窗口时刷新父窗口 12\n实例009 关闭IE主窗口时,不弹出询问对话框 13\n1.2 弹出网页对话框 14\n实例010 弹出网页模式对话框 14\n实例011 弹出全屏显示的网页模式对话框 16\n实例012 网页拾色器 18\n实例013 日期选择器 21\n1.3 窗口的动画效果 26\n实例014 页面\u003Cem\u003E自动\u003C\u002Fem\u003E滚动 26\n实例015 打开窗口特殊效果 27\n实例016 \u003Cem\u003E动态\u003C\u002Fem\u003E显示窗口 29\n实例017 慢慢放大的窗口 30\n实例018 下降式浏览器 32\n实例019 旋转的窗口 33\n实例020 移动的窗口 34\n实例021 震动的窗口 35\n实例022 弹出广告窗口 36\n1.4 窗口控制 37\n实例023 窗口始终在最上面 38\n实例024 窗口的最小化、最大化 39\n实例025 频道方式窗口 41\n实例026 全屏显示 42\n实例027 设置窗口大小和位置 43\n实例028 刷新当前页 44\n实例029 \u003Cem\u003E自动\u003C\u002Fem\u003E最大化 45\n实例030 自定义导航控制面板 46\n实例031 根据用户分辨率\u003Cem\u003E自动\u003C\u002Fem\u003E调整窗口 48\n1.5 窗口的其他效果 49\n实例032 打开窗口时显示对话框 50\n实例033 使窗口背景透明 50\n实例034 立体窗口 52\n实例035 \u003Cem\u003E动态\u003C\u002Fem\u003E标题栏 53\n实例036 固定大小的窗口 54\n1.6 框架的应用 55\n实例037 框架集的嵌套 56\n实例038 在网页中应用浮动框架 58\n实例039 创建空白框架 60\n实例040 居中显示框架页 62\n1.7 无边框窗口 63\n实例041 全屏显示无边框有滚动条的窗口 63\n实例042 应用CSS+DIV实现指定尺寸无边框无滚动条窗口 65\n实例043 应用JavaScript实现指定尺寸无边框无滚动条窗口 67\n1.8 水平导航条应用 69\n实例044 图片按钮导航条 69\n实例045 导航条的动画效果 71\n实例046 不用图片实现质感导航条 72\n1.9 下拉菜单式导航条 73\n实例047 二级导航菜单 74\n实例048 半透明背景的下拉菜单 76\n实例049 展开式导航条 80\n实例050 用层制作下拉菜单1 81\n实例051 用层制作下拉菜单2 84\n1.10 侧导航条设计 86\n实例052 \u003Cem\u003E自动\u003C\u002Fem\u003E隐藏式菜单 87\n实例053 收缩式导航菜单 89\n实例054 树状导航菜单 91\n第2章 表单及表单元素 95\n2.1 文本框\u002F编辑框\u002F隐藏域组件 96\n实例055 获取文本框\u002F编辑框\u002F隐藏域的值 96\n实例056 \u003Cem\u003E自动\u003C\u002Fem\u003E计算金额 97\n实例057 设置文本框的只读属性 98\n实例058 限制多\u003Cem\u003E行\u003C\u002Fem\u003E文本域输入的字符个数 100\n实例059 \u003Cem\u003E自动\u003C\u002Fem\u003E选择文本框\u002F编辑框中的文字 102\n实例060 按下回车键时\u003Cem\u003E自动\u003C\u002Fem\u003E切换焦点 103\n2.2 下拉列表\u002F菜单 104\n实例061 获取下拉列表\u002F菜单的值 104\n实例062 遍历多选择下拉列表 105\n实例063 在下拉列表中进\u003Cem\u003E行\u003C\u002Fem\u003E多选移除 106\n实例064 将数组中的\u003Cem\u003E数据\u003C\u002Fem\u003E\u003Cem\u003E添加\u003C\u002Fem\u003E到下拉菜单中 107\n实例065 应用下拉菜单选择所要联机的网站 108\n实例066 多级级联菜单 110\n实例067 可以输入文字的下拉菜单 111\n实例068 根据下拉菜单的值显示不同控件 112\n实例069 分级下拉列表 113\n2.3 单选按钮组 114\n实例070 不提交表单获取单选按钮的值 114\n实例071 选中单选按钮后显示其他表单元素 116\n实例072 通过单选按钮控制其他表单元素是否可用 117\n2.4 复选框 117\n实例073 不提交表单获取复选框的值 118\n实例074 控制复选框的全选或反选 118\n实例075 只有一个复选框时控制复选框的全选或反选 119\n2.5 密码域 120\n实例076 让您的密码域更安全 120\n实例077 不提交表单\u003Cem\u003E自动\u003C\u002Fem\u003E检测密码域是否相同 121\n2.6 表单应用 122\n实例078 通过JavaScript控制表单的提交与重置 122\n实例079 带记忆功能的表单 123\n实例080 防止表单重复提交 124\n实例081 \u003Cem\u003E自动\u003C\u002Fem\u003E提交表单 125\n实例082 通过for循环获取表单元素的中文名称 126\n实例083 可以提交到不同处理页的表单 127\n第3章 实用JavaScript函数 129\n3.1 \u003Cem\u003E数据\u003C\u002Fem\u003E验证 130\n实例084 通过正则表达式验证日期 130\n实例085 验证输入的日期格式是否正确 132\n实例086 检查表单元素是否为空 134\n实例087 验证E-mail是否正确 135\n实例088 通过正则表达式验证电话号码 137\n实例089 验证输入的字符串是否为汉字 139\n实例090 验证身份证号码 140\n实例091 验证用户名和密码 142\n实例092 验证车牌号码 144\n实例093 验证网站地址 145\n实例094 验证数量和金额 147\n实例095 验证字符串是否以指定字符开头 149\n实例096 限制输入字符串的长度 150\n3.2 字符串处理 152\n实例097 小写金额转换为大写金额 152\n实例098 去除字符串中的空格 155\n实例099 转换输入文本中的回车和空格 156\n实例100 将数字字符串格式化为指定长度 158\n实例101 把一个长数字分位显示 159\n实例102 将RGB格式的颜色值转换为十六进制格式 161\n实例103 将IP地址转换为对应的数值 163\n实例104 从指定URL中提取文件名 164\n3.3 随机函数 166\n实例105 随机产生指定位数的验证码 166\n实例106 生成随机字符串 167\n3.4 日期与时间 169\n实例107 显示长日期格式的系统日期 169\n实例108 实时显示系统时间 171\n第4章 日期和时间 173\n4.1 日期时间显示 174\n实例109 在标题栏中显示日期时间 174\n实例110 使用toLocaleString()方法获取本地时间 176\n实例111 全中文显示日期 176\n实例112 在状态栏中显示日期时间 178\n实例113 使用数组显示星期 179\n实例114 在表格中显示时间 180\n实例115 退出页面时显示停留时间 181\n实例116 显示用户在页面的停留时间 182\n实例117 显示最后修改时间 183\n4.2 日期时间算法 184\n实例118 计算某一天是星期几 184\n实例119 判断指定年份是否为闰年 186\n实例120 计算从出生到现在度过的时间 187\n实例121 返回两个日期之间的间隔小时 188\n实例122 倒计时 190\n实例123 访问时间限制 191\n实例124 计步器 192\n4.3 日期时间特效 194\n实例125 分时问候 194\n实例126 节日提示 195\n实例127 倒影时钟 196\n实例128 带阴影的时钟 199\n实例129 \u003Cem\u003E动态\u003C\u002Fem\u003E石英钟 200\n实例130 生日提醒器 203\n实例131 数字时钟 205\n实例132 各地时间表 206\n实例133 位于页面顶层的时钟 209\n第5章 文字特效 213\n5.1 文字的颜色变换 214\n实例134 简单文字变色 214\n实例135 文字变色 215\n实例136 变换的文字 216\n实例137 描边文字 217\n实例138 霓虹灯文字 218\n实例139 追逐点亮的文字 219\n实例140 萤光文字 220\n实例141 发光文字的闪烁效果 221\n实例142 文字的舞台灯光效果 223\n实例143 制作彩色渐变文字动画 224\n5.2 改变文字大小 226\n实例144 文字伸缩 226\n实例145 动荡的文字 227\n实例146 文字伸展 228\n实例147 文字逐个放大 230\n实例148 \u003Cem\u003E自动\u003C\u002Fem\u003E改变大小 231\n实例149 选择字体的大小 232\n5.3 文字显示效果 234\n实例150 文字渐隐渐现 234\n实例151 文字虚幻变化 235\n实例152 文字虚幻抖动 237\n5.4 指定文字位置 238\n实例153 将文字置于工作区左上角 238\n实例154 右上角文字 239\n实例155 鼠标移动文字 241\n5.5 文字\u003Cem\u003E动态\u003C\u002Fem\u003E移动 242\n实例156 文字\u003Cem\u003E自动\u003C\u002Fem\u003E滚屏 242\n实例157 文字上下滚动 243\n5.6 文字立体效果 244\n实例158 文字的旋转 244\n实例159 立体旋转文字 246\n实例160 文字3D效果 248\n5.7 文字动画效果 249\n实例161 反弹文字 249\n实例162 飞舞的文字 252\n实例163 飞翔的文字 254\n实例164 平面旋转的文字 257\n实例165 输出文字 258\n实例166 文字打字效果 259\n实例167 文字抖动 261\n实例168 指向文字时飞出星形标记 262\n实例169 文字的抛出效果 264\n5.8 文字特殊效果 265\n实例170 波浪文字 265\n实例171 梦幻文字效果 266\n实例172 屏风文字 268\n实例173 文字阴影 270\n5.9 其他 270\n实例174 随机显示文字 270\n实例175 文字加密及解密 271\n第6章 超级链接特效 275\n6.1 超级链接样式 276\n实例176 改变超级链接字体样式 276\n实例177 当鼠标移动到超级链接时改变超级链接颜色 277\n实例178 改变超级链接背景色 278\n6.2 超级链接控制 279\n实例179 建立E-mail超级链接 280\n实例180 获取页面中的全部超级链接 281\n实例181 将网站设为首页 282\n实例182 单击鼠标右键\u003Cem\u003E自动\u003C\u002Fem\u003E链接到指定网站 283\n实例183 单击超级链接将本页加入收藏夹 285\n实例184 访问指定的链接地址 286\n实例185 返回默认主页 287\n实例186 导航链接 289\n6.3 超级链接特效 291\n实例187 快速闪动页面中的超级链接 291\n实例188 滚动的超级链接提示信息 292\n实例189 公告栏中显示超级链接 294\n实例190 显示超级链接站点相关信息 295\n实例191 显示超级链接的提示信息 296\n实例192 半透明背景的超级链接提示 297\n第7章 操作表格 299\n7.1 表格的颜色效果 300\n实例193 闪烁的表格边框 300\n实例194 单元格边框变色 301\n实例195 选中的\u003Cem\u003E行\u003C\u002Fem\u003E变色 302\n7.2 对单元格的焦点进\u003Cem\u003E行\u003C\u002Fem\u003E控制 303\n实例196 选定表格中的单元格 303\n实例197 左右移动单元格的信息 304\n实例198 通过键盘使单元格焦点任意移动 306\n7.3 对表格的\u003Cem\u003E行\u003C\u002Fem\u003E、列进\u003Cem\u003E行\u003C\u002Fem\u003E修改 311\n实例199 \u003Cem\u003E动态\u003C\u002Fem\u003E制作表格 311\n实例200 \u003Cem\u003E动态\u003C\u002Fem\u003E生成\u003Cem\u003E行\u003C\u002Fem\u003E或列 313\n实例201 删除表中的\u003Cem\u003E行\u003C\u002Fem\u003E 314\n7.4 单元格的相关操作 316\n实例202 隐藏及显示单元格 316\n实例203 编辑单元格中的文本信息 318\n实例204 合并单元格 320\n实例205 在表格中\u003Cem\u003E添加\u003C\u002Fem\u003E\u003Cem\u003E行\u003C\u002Fem\u003E及单元格 322\n实例206 删除表中的单元格 324\n7.5 表格的特殊效果 325\n实例207 透明表格 326\n实例208 限制表格的宽度 327\n实例209 表格的标题 328\n实例210 表格的外阴影 329\n实例211 立体表格 329\n实例212 虚线边框表格 330\n实例213 表格作为分割线 332\n实例214 表格向下展开 332\n第8章 图形图像与多媒体 335\n8.1 图片大小 336\n实例215 打开自定义大小的图片 336\n实例216 图片放大缩小 337\n实例217 通过鼠标滚轮放大缩小图片 338\n8.2 图片与鼠标相关操作 339\n实例218 跟随鼠标移动的图片 340\n实例219 可以左右拖动的图片 340\n实例220 随意拖动图片 342\n实例221 当鼠标经过图片时显示图片 344\n实例222 改变图片获取焦点时的状态 345\n实例223 抖动的图片 346\n实例224 鼠标移动放大图片 347\n8.3 图片与时间相关操作 349\n实例225 定时隐藏图片 349\n实例226 根据时间变换页面背景 350\n实例227 使图片不停闪烁 352\n实例228 上下跳动的图片 352\n实例229 图片左右晃动 354\n实例230 飘舞的变形图片 356\n8.4 图片的动画效果 358\n实例231 图片翻转效果 359\n实例232 水波倒影特效 360\n实例233 图片渐隐渐现 361\n实例234 图片的探照灯效果 362\n实例235 雷达扫描图片特效 363\n实例236 在页面中旋转的图片 365\n实例237 改变形状的图片 366\n实例238 图片在页面浮动 367\n实例239 随机变化的网页背景 369\n8.5 选择头像 370\n实例240 在列表中选择图片 370\n实例241 在弹出的新窗口中选择图片 372\n8.6 在页面中播放图片 374\n实例242 幻灯片式播放图片 374\n实例243 无间断的图片循环滚动效果 376\n8.7 图片的其他效果 377\n实例244 导航地图 377\n8.8 播放音乐 378\n实例245 为网页设置背景音乐 378\n实例246 随机播放背景音乐 380\n实例247 MIDI音乐选择 381\n8.9 插入Flash动画 383\n实例248 插入Flash动画 383\n实例249 插入背景透明的Flash动画 384\n8.10 播放视频文件 385\n实例250 播放AVI文件 385\n实例251 自制视频播放器 387\n第9章 页面特效 391\n9.1 页面背景效果 392\n实例252 背景固定居中 392\n实例253 背景图片纵向重复显示 393\n实例254 通过按钮变换背景颜色 395\n实例255 背景\u003Cem\u003E自动\u003C\u002Fem\u003E变色 396\n实例256 百叶窗 396\n实例257 渐隐渐显的背景颜色 398\n实例258 页面缩小 399\n实例259 页面上下打开效果 400\n实例260 页面左右打开效果 402\n实例261 页面溶解效果 404\n9.2 特殊页面 406\n实例262 页首页尾切换 406\n实例263 调用下载页面 408\n实例264 程序加载页面 409\n实例265 颜色拾取器 411\n9.3 广告页面 415\n实例266 图片总置于顶端 415\n实例267 随机显示广告 416\n实例268 广告随滚动条漂移 418\n9.4 页面动画效果 419\n实例269 下雪 419\n实例270 飘落的枫叶 421\n实例271 下雨 423\n实例272 背景的烟花效果 425\n实例273 变色的圆圈 427\n实例274 滚动的光环 429\n实例275 星空极速飞入效果 430\n实例276 闪烁的星星 432\n9.5 其他 434\n实例277 带密码的网页 434\n实例278 页面左右滚动 435\n实例279 \u003Cem\u003E动态\u003C\u002Fem\u003E移动的层 437\n实例280 在页面中显示十字光标 438\n第10章 状态栏特效 441\n10.1 状态栏文字动画 442\n实例281 使状态栏中的文字不停闪烁 442\n实例282 文字从右向左依次弹出 443\n实例283 文字从中间向两边展开 445\n实例284 文字跑马灯特效 447\n实例285 文字依次显示后快速收缩 449\n实例286 文字的展开与收缩 451\n实例287 状态栏中的文字依次弹出 452\n10.2 其他 453\n实例288 在状态栏显示固定自定义信息 453\n实例289 在状态栏显示鼠标坐标 454\n实例290 在状态栏显示特定的超级链接信息 456\n第11章 报表与打印 459\n11.1 Web打印 460\n实例291 调用IE自身的打印功能实现打印 460\n实例292 打印指定框架中的内容 461\n实例293 利用WebBrowser打印 462\n实例294 设置页眉页脚 463\n11.2 利用Word打印报表 465\n实例295 将页面中的表格导出到Word并打印 465\n实例296 打开指定的Word文档并打印 467\n实例297 在\u003Cem\u003EJS\u003C\u002Fem\u003EP中利用Word\u003Cem\u003E自动\u003C\u002Fem\u003E打印指定格式的\u003Cem\u003E会\u003C\u002Fem\u003E议记录 468\n实例298 在\u003Cem\u003EASP\u003C\u002Fem\u003E中利用Word\u003Cem\u003E自动\u003C\u002Fem\u003E打印指定格式的\u003Cem\u003E会\u003C\u002Fem\u003E议记录 470\n实例299 在PHP中调用Word\u003Cem\u003E自动\u003C\u002Fem\u003E打印指定格式的\u003Cem\u003E会\u003C\u002Fem\u003E议记录 472\n11.3 利用Excel打印报表 474\n实例300 将Web页面中的\u003Cem\u003E数据\u003C\u002Fem\u003E导出到Excel 474\n实例301 将Web页面中的\u003Cem\u003E数据\u003C\u002Fem\u003E导出到Excel并\u003Cem\u003E自动\u003C\u002Fem\u003E打印 476\n11.4 利用CSS样式打印 478\n实例302 利用CSS样式打印页面中的指定内容 478\n实例303 利用CSS样式分页打印 479\n11.5 套打邮寄产品单 482\n实例304 打印汇款单 482\n实例305 打印快递单 484\n实例306 打印信封 485\n第12章 网站安全 489\n12.1 禁止用户复制网页内容 490\n实例307 禁止用户复制网页内容(方法一) 490\n实例308 禁止用户复制网页内容(方法二) 491\n实例309 禁止网页另存为 492\n12.2 禁止用户刷新屏幕 493\n实例310 屏蔽IE主菜单 493\n实例311 屏蔽键盘相关事件 494\n实例312 屏蔽鼠标右键 496\n12.3 登录页面 497\n实例313 具有浏览器检测功能的登录页面 497\n实例314 防止SQL注入的登录页面 498\n实例315 带验证码的登录页面 500\n12.4 其他 501\n实例316 使用Script Encoder加密工具加密 501\n第13章 HTML\u002FCSS样式 503\n13.1 页面效果 504\n实例317 统一站内网页风格 504\n实例318 设置超级链接文字的样式 508\n实例319 网页换肤 509\n实例320 滚动文字 512\n实例321 制作渐变背景 513\n13.2 表格样式 514\n实例322 只有外边框的表格 515\n实例323 彩色外边框的表格 516\n实例324 控制表格指定外边框不显示 518\n实例325 背景颜色渐变的表格 520\n实例326 表格隔\u003Cem\u003E行\u003C\u002Fem\u003E变色 521\n13.3 鼠标及滚动条样式 522\n实例327 显示自定义鼠标形状 522\n实例328 动画光标 524\n实例329 制作彩色滚动条 525\n13.4 文字及列表样式 527\n实例330 应用删除线样式标记商品特价 527\n实例331 在文字上方标注说明标记 528\n实例332 指定图标的列表项 529\n13.5 文字滤镜特效 530\n实例333 文字的发光效果 531\n实例334 文字的阴影效果 532\n实例335 文字的渐变阴影效果 533\n实例336 文字的图案填充效果 534\n实例337 文字的探照灯效果 535\n实例338 文字的闪烁效果 537\n实例339 文字的空心效果 538\n实例340 文字的浮雕效果 539\n实例341 文字的阳文效果 540\n实例342 文字的雪雕效果 541\n实例343 火焰字 542\n实例344 文字扭曲动画 544\n13.6 图片滤镜特效 545\n实例345 图片的半透明效果 545\n实例346 图片的模糊效果 546\n实例347 图片的水波纹特效 547\n实例348 图片的灰度效果 548\n实例349 图片的\u003Cem\u003E动态\u003C\u002Fem\u003E说明文字 549\n第14章 JavaScript与XML 553\n14.1 读取XML文件 554\n实例350 使用XML DOM对象读取XML文件 554\n实例351 使用XMLHttpRequest对象读取XML文件 557\n14.2 显示XML文档 559\n实例352 使用CSS显示XML文档 559\n实例353 使用XSL显示XML文档 562\n实例354 使用IE XML\u003Cem\u003E数据\u003C\u002Fem\u003E岛输出XML文档 564\n14.3 操作XML 565\n实例355 用JavaScript控制XML文档的分页显示 565\n实例356 通过操作XML\u003Cem\u003E数据\u003C\u002Fem\u003E岛实现\u003Cem\u003E添加\u003C\u002Fem\u003E、删除留言信息 567\n第15章 JavaScript与\u003Cem\u003EASP\u003C\u002Fem\u003E结合 573\n15.1 弹出窗口\u002F对话框控制 574\n实例357 关闭弹出窗口时刷新父窗口 574\n实例358 打开新窗口显示详细信息 575\n实例359 弹出网页模式对话框 577\n实例360 日期选择器 580\n实例361 弹出提示对话框并重定向网页 584\n实例362 打开指定大小的新窗口并居中显示 586\n15.2 弹出确认对话框 588\n实例363 删除\u003Cem\u003E数据\u003C\u002Fem\u003E前弹出确认对话框 588\n实例364 安全退出前弹出确认对话框 590\n15.3 其他 591\n实例365 远程获取其他网页情报 591\n实例366 树状导航菜单 594\n实例367 使用XML实现不刷新页面查询\u003Cem\u003E数据\u003C\u002Fem\u003E 596\n第16章 JavaScript与\u003Cem\u003EJS\u003C\u002Fem\u003EP结合 601\n16.1 窗口与对话框 602\n实例368 弹出提示对话框并重定向网页 602\n实例369 打开新窗口显示详细信息 604\n实例370 打开指定大小的新窗口并居中显示 605\n实例371 弹出网页模式对话框 607\n实例372 关闭弹出窗口时刷新父窗口 609\n16.2 无刷新技术 611\n实例373 无刷新的用户名检测 611\n实例374 无刷新的级联下拉列表 614\n实例375 使用XML实现不刷新页面查询\u003Cem\u003E数据\u003C\u002Fem\u003E 616\n16.3 调用与控制 619\n实例376 将查询结果导出到Word 619\n实例377 调用Excel 621\n实例378 调用PowerPoint 622\n16.4 其他 623\n实例379 树状导航菜单 623\n第17章 JavaScript与\u003Cem\u003EASP\u003C\u002Fem\u003E.NET结合 627\n17.1 窗口与对话框 628\n实例380 使用JavaScript脚本弹出对话框 628\n实例381 打开新窗口显示详细信息 629\n实例382 关闭弹出窗口刷新父窗口 631\n实例383 弹出网页模式对话框 633\n实例384 弹出全屏显示网页 635\n17.2 其他 637\n实例385 \u003Cem\u003E自动\u003C\u002Fem\u003E隐藏式菜单 637\n第18章 JavaScript与PHP结合 641\n18.1 窗口与对话框 642\n实例386 弹出提示对话框并重定向网页 642\n实例387 关闭弹出窗口时\u003Cem\u003E自动\u003C\u002Fem\u003E刷新父窗口 643\n实例388 在弹出的网页模式对话框中选择个性头像 645\n实例389 时间选择器 647\n实例390 弹出提示对话框并重定向网页 649\n实例391 删除\u003Cem\u003E数据\u003C\u002Fem\u003E前弹出确认对话框 650\n18.2 其他 651\n实例392 树状导航菜单 651\n第19章 综合应用 657\n19.1 计算器 658\n实例393 简单计算器 658\n实例394 复杂计算器 662\n19.2 日历 667\n实例395 精美日历 668\n实例396 带农历的日历 674\n19.3 购物车 681\n实例397 \u003Cem\u003E添加\u003C\u002Fem\u003E至购物车 682\n实例398 查看购物车 684\n实例399 修改商品购买数量 686\n实例400 从购物车中移去指定商品 687\n实例401 清空购物车 689\nJavaScript程序开发范例宝典附录 691","createTime":"2013-09-04 10:40:38","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fzrf139138\u002F6207707\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"3\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fzrf139138\u002F6207707\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-3-6207707-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fu013013722\u002F8220345","title":"正则表达式","desc":"正则表达式中的特殊字符\n字符\t含意\n\\\t\u003Cem\u003E做\u003C\u002Fem\u003E为转意,即通常在\"\\\"后面的字符不按原来意义解释,如\u002Fb\u002F匹配字符\"b\",当b前面加了反斜杆后\u002F\\b\u002F,转意为匹配一个单词的边界。 \n-或- \n对正则表达式功能字符的还原,如\"*\"匹配它前面元字符0次或多次,\u002Fa*\u002F将匹配a,aa,aaa,加了\"\\\"后,\u002Fa\\*\u002F将只匹配\"a*\"。\n^\t匹配一个输入或一\u003Cem\u003E行\u003C\u002Fem\u003E的开头,\u002F^a\u002F匹配\"an A\",而不匹配\"An a\"\n$\t匹配一个输入或一\u003Cem\u003E行\u003C\u002Fem\u003E的结尾,\u002Fa$\u002F匹配\"An a\",而不匹配\"an A\"\n*\t匹配前面元字符0次或多次,\u002Fba*\u002F将匹配b,ba,baa,baaa\n+\t匹配前面元字符1次或多次,\u002Fba*\u002F将匹配ba,baa,baaa\n?\t匹配前面元字符0次或1次,\u002Fba*\u002F将匹配b,ba\n(x)\t匹配x保存x在名为$1...$9的变量中\nx|y\t匹配x或y\n{n}\t精确匹配n次\n{n,}\t匹配n次以上\n{n,m}\t匹配n-m次\n[xyz]\t字符集(character set),匹配这个集合中的任一一个字符(或元字符)\n[^xyz]\t不匹配这个集合中的任何一个字符\n[\\b]\t匹配一个退格符\n\\b\t匹配一个单词的边界\n\\B\t匹配一个单词的非边界\n\\cX\t这儿,X是一个控制符,\u002F\\cM\u002F匹配Ctrl-M\n\\d\t匹配一个字数字符,\u002F\\d\u002F = \u002F[0-9]\u002F\n\\D\t匹配一个非字数字符,\u002F\\D\u002F = \u002F[^0-9]\u002F\n\\n\t匹配一个换\u003Cem\u003E行\u003C\u002Fem\u003E符\n\\r\t匹配一个回车符\n\\s\t匹配一个空白字符,包括\\n,\\r,\\f,\\t,\\v等\n\\S\t匹配一个非空白字符,等于\u002F[^\\n\\f\\r\\t\\v]\u002F\n\\t\t匹配一个制表符\n\\v\t匹配一个重直制表符\n\\w\t匹配一个可以组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[\\w]匹配\"$5.98\"中的5,等于[a-zA-Z0-9]\n\\W\t匹配一个不可以组成单词的字符,如[\\W]匹配\"$5.98\"中的$,等于[^a-zA-Z0-9]。\n\n用re = new RegExp(\"pattern\",[\"flags\"]) 的方式比较好 \npattern : 正则表达式 \nflags: g (全文查找出现的所有 pattern) \ni (忽略大小写) \nm (多\u003Cem\u003E行\u003C\u002Fem\u003E查找)\tvaScript\u003Cem\u003E动态\u003C\u002Fem\u003E正则表达式问题\n请问正则表达式可以\u003Cem\u003E动态\u003C\u002Fem\u003E生成吗? \n例如JavaScript中: \nvar str = \"strTemp\"; \n要生成: \nvar re = \u002FstrTemp\u002F; \n如果是字符连接: \nvar re = \"\u002F\" + str + \"\u002F\"即可 \n但是要生成表达式,可以实现吗?怎样实现?\t \n \t \t \n \t \t \n[JAVA] javascript 正则表达式 \n秋雨叶 发表于 2004-12-9 14:54:13\n正则表达式是一个描述字符模式的对象。 \nJavaScript的RegExp对象和String对象定义了使用正则表达式来执\u003Cem\u003E行\u003C\u002Fem\u003E强大的模式匹配和文本检索与替换函数的方法. \n\n在JavaScript中,正则表达式是由一个RegExp对象表示的.当然,可以使用一个RegExp()构造函数来创建RegExp对象, \n也可以用JavaScript 1.2中的新\u003Cem\u003E添加\u003C\u002Fem\u003E的一个特殊语法来创建RegExp对象.就像字符串直接量被定义为包含在引号内的字符一样, \n正则表达式直接量也被定义为包含在一对斜杠(\u002F)之间的字符.所以,JavaScript可能\u003Cem\u003E会\u003C\u002Fem\u003E包含如下的代码: \n\nvar pattern = \u002Fs$\u002F; \n\n这\u003Cem\u003E行\u003C\u002Fem\u003E代码创建一个新的RegExp对象,并将它赋给变量parttern.这个特殊的RegExp对象和所有以字母\"s\"结尾的字符串都匹配.用RegExp()也可以定义 \n一个等价的正则表达式,代码如下: \n\nvar pattern = new RegExp(\"s$\"); \n\n无论是用正则表达式直接量还是用构造函数RegExp(),创建一个RegExp对象都是比较容易的.较为困难的任务是用正则表达式语法来描述字符的模式. \nJavaScript采用的是Perl语言正则表达式语法的一个相当完整的子集. \n\n正则表达式的模式规范是由一系列字符构成的.大多数字符(包括所有字母数字字符)描述的都是按照字面意思进\u003Cem\u003E行\u003C\u002Fem\u003E匹配的字符.这样说来,正则表达式\u002Fjava\u002F就和 \n所有包含子串 \"java\" 的字符串相匹配.虽然正则表达式中的其它字符不是按照字面意思进\u003Cem\u003E行\u003C\u002Fem\u003E匹配的,但它们都具有特殊的意义.正则表达式 \u002Fs$\u002F 包含两个字符. \n第一个特殊字符 \"s\" 是按照字面意思与自身相匹配.第二个字符 \"$\" 是一个特殊字符,它所匹配的是字符串的结尾.所以正则表达式 \u002Fs$\u002F 匹配的就是以字母 \"s\" 结尾 \n的字符串. \n\n\n1.直接量字符 \n\n我们已经发现了,在正则表达式中所有的字母字符和数字都是按照字面意思与自身相匹配的.JavaScript的正则表达式还通过以反斜杠(\\)开头的转义序列支持某些非 \n\n字母字符.例如,序列 \"\\n\" 在字符串中匹配的是一个直接量换\u003Cem\u003E行\u003C\u002Fem\u003E符.在正则表达式中,许多标点符号都有特殊的含义.下面是这些字符和它们的含义: \n\n正则表达式的直接量字符 \n\n字符 匹配 \n________________________________ \n字母数字字符 自身 \n\\ f 换页符 \n\\ n 换\u003Cem\u003E行\u003C\u002Fem\u003E符 \n\\ r 回车 \n\\ t 制表符 \n\\ v 垂直制表符 \n\\ \u002F 一个 \u002F 直接量 \n\\ \\ 一个 \\ 直接量 \n\\ . 一个 . 直接量 \n\\ * 一个 * 直接量 \n\\ + 一个 + 直接量 \n\\ ? 一个 ? 直接量 \n\\ | 一个 | 直接量 \n\\ ( 一个 ( 直接量 \n\\ ) 一个 ) 直接量 \n\\ [ 一个 [ 直接量 \n\\ ] 一个 ] 直接量 \n\\ { 一个 { 直接量 \n\\ } 一个 } 直接量 \n\\ XXX 由十进制数 XXX 指 定的ASCII码字符 \n\\ Xnn 由十六进制数 nn 指定的ASCII码字符 \n\\ cX 控制字符^X. 例如, \\cI等价于 \\t, \\cJ等价于 \\n \n\n___________________________________________________ \n\n如果想在正则表达式中使用特殊的标点符号,必须在它们之前加上一个 \"\\\" . \n\n\n2.字符类 \n\n将单独的直接符放进中括号内就可以组合成字符类.一个字符类和它所包含的任何一个字符都匹配,所以正则表达式 \u002F [abc] \u002F 和字母 \"a\" , \"b\" , \"c\" 中的任何一个 \n都匹配.另外还可以定义否定字符类,这些类匹配的是除那些包含在中括号之内的字符外的所有字符.定义否定字符尖时,要将一个 ^ 符号作为从左中括号算起的第 \n一个字符.正则表达式的集合是 \u002F [a-zA-z0-9] \u002F . \n\n由于某些字符类非常常用,所以JavaScript的正则表达式语法包含一些特殊字符和转义序列来表示这些常用的类.例如, \\s 匹配的是空格符,制表符和其它空白符, \\s \n匹配的则是空白符之外的任何字符. \n\n正则表灰式的字符类 \n\n字符 匹配 \n____________________________________________________ \n[...] 位于括号之内的任意字符 \n[^...] 不在括号之中的任意字符 \n. 除了换\u003Cem\u003E行\u003C\u002Fem\u003E符之外的任意字符,等价于[^\\n] \n\\w 任何单字字符, 等价于[a-zA-Z0-9] \n\\W 任何非单字字符,等价于[^a-zA-Z0-9] \n\\s 任何空白符,等价于[\\ t \\ n \\ r \\ f \\ v] \n\\S 任何非空白符,等价于[^\\ t \\ n \\ r \\ f \\ v] \n\\d 任何数字,等价于[0-9] \n\\D 除了数字之外的任何字符,等价于[^0-9] \n[\\b] 一个退格直接量(特例) \n________________________________________________________________ \n\n3.复制 \n\n用以上的正则表式的语法,可以把两位数描述成 \u002F \\ d \\ d \u002F,把四位数描述成 \u002F \\d \\ d \\ d \\ d \u002F.但我们还没有一种方法可以用来描述具有任意多数位的数字或者是一个 \n\n字符串.这个串由三个字符以及跟随在字母之后的一位数字构成.这些复杂的模式使用的正则表达式语法指定了该表达式中每个元素要重复出现的次数. \n\n指定复制的字符总是出现在它们所作用的模式后面.由于某种复制类型相当常用.所以有一些特殊的字符专门用于表示它们.例如: +号匹配的就是复制前一模式一次 \n\n或多次的模式.下面的表列出了复制语法.先看一个例子: \n\n\u002F\\d{2, 4}\u002F \u002F\u002F匹配2到4间的数字. \n\n\u002F\\w{3} \\d?\u002F \u002F\u002F匹配三个单字字符和一个任意的数字. \n\n\u002F\\s+java\\s+\u002F \u002F\u002F匹配字符串\"java\" ,并且该串前后可以有一个或多个空格. \n\n\u002F[^\"] * \u002F \u002F\u002F匹配零个或多个非引号字符. \n\n\n正则表达式的复制字符 \n\n字符 含义 \n__________________________________________________________________ \n{n, m} 匹配前一项至少n次,但是不能超过m次 \n{n, } 匹配前一项n次,或者多次 \n{n} 匹配前一项恰好n次 \n? 匹配前一项0次或1次,也就是说前一项是可选的. 等价于 {0, 1} \n+ 匹配前一项1次或多次,等价于{1,} \n* 匹配前一项0次或多次.等价于{0,} \n___________________________________________________________________ \n\n\n4.选择,分组和引用 \n\n正则表达式的语法还包括指定选择项,对子表达式分组和引用前一子表达式的特殊字符.字符| 用于分隔供选择的字符.例如: \u002Fab|cd|ef\u002F 匹配的是字符串 \"ab\",或者是 \n\n字符串 \"cd\",又或者 \"ef\". \u002F\\d{3}|[a-z]{4}\u002F 匹配的是要么是一个三位数,要么是四个小写字母.在正则表达式中括号具有几种作用.它的主要作用是把单独的项目分组 \n\n成子表达式,以便可以像处理一个独立的单元那种用 *、+或? 来处理那些项目.例如: \u002Fjava(script) ?\u002F 匹配的是字符串 \"java\",其后既可以有 \"script\",也可以没有. \u002F \n\n(ab|cd) + |ef) \u002F 匹配的既可以是字符串 \"ef\",也可以是字符串\"ab\" 或者 \"cd\" 的一次或多次重复. \n\n在正则表达式中,括号的第二个用途是在完整的模式中定义子模式。当一个正则表达式成功地和目标字符串相匹配时,可以从目标串中抽出和括号中的子模式相匹配 \n\n的部分.例如,假定我们正在检索的模式是一个或多个字母后面跟随一位或多位数字,那么我们可以使用模式 \u002F [a-z] + \\ d+\u002F.但是由于假定我们真正关心的是每个匹配 \n\n尾部的数字,那么如果我们将模式的数字部分放在括号中 (\u002F [a-z] + (\\d+)\u002F) ,我们就可以从所检索到的任何匹配中抽取数字了,之后我们\u003Cem\u003E会\u003C\u002Fem\u003E对此进\u003Cem\u003E行\u003C\u002Fem\u003E解析的. \n\n代括号的子表达式的另一个用途是,允许我们在同一正则表达式的后面引用前面的子表达式.这是通过在字符串 \\ 后加一位或多位数字来实现的.数字指的是代括号的 \n\n子表达式在正则表达式中的位置.例如: \\1 引用的是第一个代括号的子表达式. \\3 引用的是第三个代括号的子表达式.注意,由于子表达式可以嵌套在其它子表达式中, \n\n所以它的位置是被计数的左括号的位置. \n例如:在下面的正则表达式被指定为 \\2: \n\u002F([Jj]ava([Ss]cript)) \\sis \\s (fun\\w*) \u002F \n\n\n对正则表达式中前一子表达式的引用所指定的并不是那个子表达式的模式,而是与那个模式相匹配的文本.这样,引用就不只是帮助你输入正则表达式的重复部分的快 \n\n捷方式了,它还实施了一条规约,那就是一个字符串各个分离的部分包含的是完全相同的字符.例如:下面的正则表达式匹配的就是位于单引号或双引号之内的所有字 \n\n符.但是,它要求开始和结束的引号匹配(例如两个都是双引号或者都是单引号): \n\u002F[' \"] [^ ' \"]*[' \"]\u002F \n\n\n如果要求开始和结束的引号匹配,我们可以使用如下的引用: \n\u002F( [' \"] ) [^ ' \"] * \\1\u002F \n\n\n\\1匹配的是第一个代括号的子表达式所匹配的模式.在这个例子中,它实施了一种规约,那就是开始的引号必须和结束的引号相匹配.注意,如果反斜杠后跟随的数字比 \n\n代括号的子表达式数多,那么它就\u003Cem\u003E会\u003C\u002Fem\u003E被解析为一个十进制的转义序列,而不是一个引用.你可以坚持使用完整的三个字符来表示转义序列,这们就可以避免混淆了.例如, \n\n使用 \\044,而不是\\44.下面是正则表达式的选择、分组和引用字符: \n\n字符 含义 \n____________________________________________________________________ \n| 选择.匹配的要么是该符号左边的子表达式,要么它右边的子表达式 \n(...) 分组.将几个项目分为一个单元.这个单元可由 *、+、?和|等符号使用,而且还可以记住和这个组匹配的字符以供此后引 \n\n用使用 \n\\n 和第n个分组所匹配的字符相匹配.分组是括号中的子表达式(可能是嵌套的).分组号是从左到右计数的左括号数 \n____________________________________________________________________ \n\n\n\n5.指定匹配的位置 \n\n我们已经看到了,一个正则表达式中的许多元素才能够匹配字符串的一个字符.例如: \\s 匹配的只是一个空白符.还有一些正则表达式的元素匹配的是字符之间宽度为 \n\n0的空间,而不是实际的字符例如: \\b 匹配的是一个词语的边界,也就是处于一个\u002Fw字字符和一个\\w非字字符之间的边界.像\\b 这样的字符并不指定任何一个匹配了的 \n\n字符串中的字符,它们指定的是匹配所发生的合法位置.有时我们称这些元素为正则表达式的锚.因为它们将模式定位在检索字符串中的一个特定位置.最常用的锚元 \n\n素是 ^, 它使模式依赖于字符串的开头,而锚元素$则使模式定位在字符串的末尾. \n\n例如:要匹配词 \"javascript\" ,我们可以使用正则表达式 \u002F^ javascript $\u002F. 如果我们想检索 \"java\" 这个词自身 (不像在 \"javascript\" 中那样作为前缀),那么我们可以使 \n\n用模式 \u002F\\s java \\s \u002F, 它要求在词语java之前和之后都有空格.但是这样作有两个问题.第一: 如果 \"java\" 出现在一个字符的开头或者是结尾.该模式就不\u003Cem\u003E会\u003C\u002Fem\u003E与之匹配,除 \n\n非在开头和结尾处有一个空格. 第二: 当这个模式找到一个与之匹配的字符时,它返回的匹配的字符串前端和后端都有空格,这并不是我们想要的.因此,我们使用词语 \n\n的边界 \\b 来代替真正的空格符 \\s 进\u003Cem\u003E行\u003C\u002Fem\u003E匹配. 结果表达式是 \u002F\\b java \\b\u002F. \n下面是正则表达式的锚字符: \n\n\n字符 含义 \n____________________________________________________________________ \n^ 匹配的是字符的开头,在多\u003Cem\u003E行\u003C\u002Fem\u003E检索中,匹配的是一\u003Cem\u003E行\u003C\u002Fem\u003E的开头 \n$ 匹配的是字符的结尾,在多\u003Cem\u003E行\u003C\u002Fem\u003E检索中,匹配的是一\u003Cem\u003E行\u003C\u002Fem\u003E的结尾 \n\\b 匹配的是一个词语的边界.简而言之就是位于字符\\w 和 \\w之间的位置(注意:[\\b]匹配的是退格符) \n\\B 匹配的是非词语的边界的字符 \n_____________________________________________________________________\n\n\n\n6.属性 \n\n有关正则表达式的语法还有最后一个元素,那就是正则表达式的属性,它说明的是高级模式匹配的规则.和其它正则表达式语法不同,属性是在 \u002F 符号之外说明的.即它 \n\n们不出现在两个斜杠之间,而是位于第二个斜杠之后.javascript 1.2支持两个属性.属性 i 说明模式匹配应该是大小写不敏感的.属性 g 说明模式匹配应该是全局的.也 \n\n就是说,应该找出被检索的字符串中所有的匹配.这两种属性联合起来就可以执\u003Cem\u003E行\u003C\u002Fem\u003E一个全局的,大小写不敏感的匹配. \n\n例如: 要执\u003Cem\u003E行\u003C\u002Fem\u003E一个大小不敏感的检索以找到词语 \"java\" (或者是 \"java\" 、\"JAVA\"等) 的第一个具体值,我们可以使用大小不敏感的正则表达式 \u002F\\b java\\b\u002Fi .如果要在 \n\n一个字符串中找到 \"java\" 所有的具体值,我们还可以\u003Cem\u003E添加\u003C\u002Fem\u003E属性 g, 即 \u002F\\b java \\b\u002Fgi . \n\n以下是正则表达式的属性: \n\n\n字符 含义 \n_________________________________________ \ni 执\u003Cem\u003E行\u003C\u002Fem\u003E大小写不敏感的匹配 \ng 执\u003Cem\u003E行\u003C\u002Fem\u003E一个全局的匹配,简而言之,就是找到所有的匹配,而不是在找到第一个之后就停止了 \n_________________________________________ \n\n除属性 g 和 i 之外,正则表达式就没有其它像属性一样的特性了.如果将构造函数 RegExp 的静态属性 multiline 设置为 true ,那么模式匹配将以多\u003Cem\u003E行\u003C\u002Fem\u003E的模式进\u003Cem\u003E行\u003C\u002Fem\u003E.在这 \n\n种模式下,锚字符 ^ 和 $ 匹配的不只是检索字符串的开头和结尾,还匹配检索字符串内部的一\u003Cem\u003E行\u003C\u002Fem\u003E的开头和结尾.例如: 模式 \u002FJava$\u002F 匹配的是 \"Java\",但是并不匹配 \n\n\"Java\\nis fun\" .如果我们设置了 multiline 属性,那么后者也将被匹配: \n\nRegExp.multiline = true;\n在JAVASCRIPT里面判断一个字符串是否是电子邮件的格式: \nif(formname.email.value!=formname.email.value.match(\u002F^\\w +[@]\\w +[.][\\w.] +$\u002F)) \n{ \nalert(\"您的电子邮件格式错误!\"); \nformname.email.focus(); \nreturn false; \n}\n\n阅读全文(42) | 回复(0) | 引用(0) | [用365key收藏此日志]\n \n\n[RED]function dateVerify(date){ \nvar reg = \u002F^(\\d{4})(-)(\\d{2})\\2(\\d{2})$\u002F; \nvar r = date.match(reg); \nif(r==null) return false; \nvar d= new Date(r[1], r[3]-1,r[4]); \nvar newStr=d.getFullYear()+r[2]+(d.getMonth()+1)+r[2]+d.getDate(); \ndate=r[1]+r[2]+((r[3]-1)+1)+r[2]+((r[4]-1)+1); \nreturn newStr==date; \n}[\u002FRED] \n \njavascript的17种正则表达式\n作者: 不祥  时间: 2004-6-9\n\"^\\\\d+$\"  \u002F\u002F非负整数(正整数 + 0) \n\"^[0-9]*[1-9][0-9]*$\"  \u002F\u002F正整数 \n\"^((-\\\\d+)|(0+))$\"  \u002F\u002F非正整数(负整数 + 0) \n\"^-[0-9]*[1-9][0-9]*$\"  \u002F\u002F负整数 \n\"^-?\\\\d+$\"    \u002F\u002F整数 \n\"^\\\\d+(\\\\.\\\\d+)?$\"  \u002F\u002F非负浮点数(正浮点数 + 0) \n\"^(([0-9]+\\\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\\\.[0-9]+)|([0-9]*[1-9][0-9]*))$\"  \u002F\u002F正浮点数 \n\"^((-\\\\d+(\\\\.\\\\d+)?)|(0+(\\\\.0+)?))$\"  \u002F\u002F非正浮点数(负浮点数 + 0) \n\"^(-(([0-9]+\\\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$\"  \u002F\u002F负浮点数 \n\"^(-?\\\\d+)(\\\\.\\\\d+)?$\"  \u002F\u002F浮点数 \n\"^[A-Za-z]+$\"  \u002F\u002F由26个英文字母组成的字符串 \n\"^[A-Z]+$\"  \u002F\u002F由26个英文字母的大写组成的字符串 \n\"^[a-z]+$\"  \u002F\u002F由26个英文字母的小写组成的字符串 \n\"^[A-Za-z0-9]+$\"  \u002F\u002F由数字和26个英文字母组成的字符串 \n\"^\\\\w+$\"  \u002F\u002F由数字、26个英文字母或者下划线组成的字符串 \n\"^[\\\\w-]+(\\\\.[\\\\w-]+)*@[\\\\w-]+(\\\\.[\\\\w-]+)+$\"    \u002F\u002Femail地址 \n\"^[a-zA-z]+:\u002F\u002F(\\\\w+(-\\\\w+)*)(\\\\.(\\\\w+(-\\\\w+)*))*(\\\\?\\\\S*)?$\"  \u002F\u002Furl \n\nJavaScript中的正则表达式(2)\n \n \n作者 :中国论坛网收集 来源 :http:\u002F\u002Fwww.51one.net 加入时间 :2004-8-25  \n正则表达式对象的属性及方法 \n   预定义的正则表达式拥有有以下静态属性:input, multiline, lastMatch, lastParen, leftContext, rightContext和$1到$9。其中input和multiline可以预设置。其他属性的值在执\u003Cem\u003E行\u003C\u002Fem\u003E过exec或test方法后被根据不同条件赋以不同的值。许多属性同时拥有长和短(perl风格)的两个名字,并且,这两个名字指向同一个值。(JavaScript模拟perl的正则表达式) \n正则表达式对象的属性\n属性\t含义\n$1...$9\t如果它(们)存在,是匹配到的子串\n$_\t参见input\n$*\t参见multiline\n$&\t参见lastMatch\n$+\t参见lastParen\n$`\t参见leftContext\n$''         \t参见rightContext\nconstructor   \t创建一个对象的一个特殊的函数原型\nglobal      \t是否在整个串中匹配(bool型)\nignoreCase    \t匹配时是否忽略大小写(bool型)\ninput       \t被匹配的串\nlastIndex    \t最后一次匹配的索引\nlastParen    \t最后一个括号括起来的子串\nleftContext   \t最近一次匹配以左的子串\nmultiline    \t是否进\u003Cem\u003E行\u003C\u002Fem\u003E多\u003Cem\u003E行\u003C\u002Fem\u003E匹配(bool型)\nprototype    \t允许附加属性给对象\nrightContext   \t最近一次匹配以右的子串\nsource      \t正则表达式模式\nlastIndex    \t最后一次匹配的索引\n\n\n正则表达式对象的方法 \n方法\t含义\ncompile     \t正则表达式比较\nexec       \t执\u003Cem\u003E行\u003C\u002Fem\u003E查找\ntest       \t进\u003Cem\u003E行\u003C\u002Fem\u003E匹配\ntoSource     \t返回特定对象的定义(literal representing),其值可用来创建一个新的对象。重载Object.toSource方法得到的。\ntoString     \t返回特定对象的串。重载Object.toString方法得到的。\nvalueOf     \t返回特定对象的原始值。重载Object.valueOf方法得到\n\n例子 \n \nvar myReg = \u002F(w+)s(w+)\u002F; \nvar str = \"John Smith\"; \nvar newstr = str.replace(myReg, \"$2, $1\"); \ndocument.write(newstr); \n \n将输出\"Smith, John\"\n javascript正则表达式检验\n\u002F********************************************************************************* \n* EO_\u003Cem\u003EJS\u003C\u002Fem\u003ELib.\u003Cem\u003Ejs\u003C\u002Fem\u003E \n* javascript正则表达式检验 \n**********************************************************************************\u002F \n\n\u002F\u002F校验是否全由数字组成 \nfunction isDigit(s) \n{ \nvar patrn=\u002F^[0-9]{1,20}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串 \nfunction isRegisterUserName(s) \n{ \nvar patrn=\u002F^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验用户姓名:只能输入1-30个以字母开头的字串 \nfunction isTrueName(s) \n{ \nvar patrn=\u002F^[a-zA-Z]{1,30}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验密码:只能输入6-20个字母、数字、下划线 \nfunction isPasswd(s) \n{ \nvar patrn=\u002F^(\\w){6,20}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-” \nfunction isTel(s) \n{ \n\u002F\u002Fvar patrn=\u002F^[+]{0,1}(\\d){1,3}[ ]?([-]?(\\d){1,12})+$\u002F; \nvar patrn=\u002F^[+]{0,1}(\\d){1,3}[ ]?([-]?((\\d)|[ ]){1,12})+$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验手机号码:必须以数字开头,除数字外,可含有“-” \nfunction isMobil(s) \n{ \nvar patrn=\u002F^[+]{0,1}(\\d){1,3}[ ]?([-]?((\\d)|[ ]){1,12})+$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验邮政编码 \nfunction isPostalCode(s) \n{ \n\u002F\u002Fvar patrn=\u002F^[a-zA-Z0-9]{3,12}$\u002F; \nvar patrn=\u002F^[a-zA-Z0-9 ]{3,12}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\n\u002F\u002F校验搜索关键字 \nfunction isSearch(s) \n{ \nvar patrn=\u002F^[^`~!@#$%^&*()+=|\\\\\\][\\]\\{\\}:;'\\,.\u002F?]{1}[^`~!@$%^&()+=|\\\\\\][\\]\\{\\}:;'\\,.?]{0,19}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n} \n\nfunction isIP(s) \u002F\u002Fby zergling \n{ \nvar patrn=\u002F^[0-9.]{1,20}$\u002F; \nif (!patrn.exec(s)) return false \nreturn true \n}\n \n \n正则表达式regular expression详述(一) \nhttp:\u002F\u002Fwww.kymita.com\u002F888.\u003Cem\u003Easp\u003C\u002Fem\u003E 2002-12-15 蓝箭工作室\n\n正则表达式是regular expression,看来英文比中文要好理解多了,就是检查表达式符 \n不符合规定!!正则表达式有一个功能十分强大而又十分复杂的对象RegExp,在JavaScript1.2 版本以 \n上提供。 \n下面我们看看有关正则表达式的介绍: \n正则表达式对象用来规范一个规范的表达式(也就是表达式符不符合特定的要求,比如是不是Email \n地址格式等),它具有用来检查给出的字符串是否符合规则的属性和方法。 \n除此之外,你用RegExp构造器建立的个别正则表达式对象的属性,就已经预先定义好了正则表达式 \n对象的静态属性,你可以随时使用它们。 \n核心对象: \n在JavaScript 1.2, NES 3.0以上版本提供。 \n在JavaScript 1.3以后版本增加了toSource方法。 \n建立方法: \n文字格式或RegExp构造器函数。 \n文字建立格式使用以下格式: \n\u002Fpattern\u002Fflags即\u002F模式\u002F标记\n构造器函数方法使用方法如下: \nnew RegExp(\"pattern\"[, \"flags\"])即new RegExp(\"模式\"[,\"标记\"])\n参数: \npattern(模式) \n表示正则表达式的文本\nflags(标记) \n如果指定此项,flags可以是下面值之一: \ng: global match(全定匹配) \ni: ignore case(忽略大小写) \ngi: both global match and ignore case(匹配所有可能的值,也忽略大小写)\n注意:文本格式中的参数不要使用引号标记,而构造器函数的参数则要使用引号标记。所以下面的 \n表达式建立同样的正则表达式: \n\u002Fab+c\u002Fi \n   new RegExp(\"ab+c\", \"i\")\n描述: \n当使用构造函数的时候,必须使用正常的字符串避开规则(在字符串中加入前导字符\\ )是必须的。 \n例如,下面的两条语句是等价的: \nre = new RegExp(\"\\\\w+\") \nre = \u002F\\w+\u002F\n下面的提供了在正则表达式中能够使用的完整对特殊字符的一个完整的列表和描述。\n表1.3:正则表达式中的特殊字符:\n字符\\ \n意义:对于字符,通常表示按字面意义,指出接着的字符为特殊字符,\\不作解释。 \n例如:\u002Fb\u002F匹配字符'b',通过在b 前面加一个反斜杠\\,也就是\u002F\\b\u002F,则该字符变成特殊字符,表示 \n匹配一个单词的分界线。 \n或者: \n对于几个字符,通常说明是特殊的,指出紧接着的字符不是特殊的,而应该按字面解释。 \n例如:*是一个特殊字符,匹配任意个字符(包括0个字符);例如:\u002Fa*\u002F意味匹配0个或多个a。 \n为了匹配字面上的*,在a前面加一个反斜杠;例如:\u002Fa\\*\u002F匹配'a*'。\n字符^ \n意义:表示匹配的字符必须在最前边。 \n例如:\u002F^A\u002F不匹配\"an A,\"中的'A',但匹配\"An A.\"中最前面的'A'。\n字符$ \n意义:与^类似,匹配最末的字符。 \n例如:\u002Ft$\u002F不匹配\"eater\"中的't',但匹配\"eat\"中的't'。\n字符* \n意义:匹配*前面的字符0次或n次。 \n例如:\u002Fbo*\u002F匹配\"A ghost booooed\"中的'boooo'或\"A bird warbled\"中的'b',但不匹配\"A goat g \nrunted\"中的任何字符。\n字符+ \n意义:匹配+号前面的字符1次或n次。等价于{1,}。 \n例如:\u002Fa+\u002F匹配\"candy\"中的'a'和\"caaaaaaandy.\"中的所有'a'。\n字符? \n意义:匹配?前面的字符0次或1次。 \n例如:\u002Fe?le?\u002F匹配\"angel\"中的'el'和\"angle.\"中的'le'。\n字符. \n意义:(小数点)匹配除换\u003Cem\u003E行\u003C\u002Fem\u003E符外的所有单个的字符。 \n例如:\u002F.n\u002F匹配\"nay, an apple is on the tree\"中的'an'和'on',但不匹配'nay'。\n\n字符(x) \n意义:匹配'x'并记录匹配的值。 \n例如:\u002F(foo)\u002F匹配和记录\"foo bar.\"中的'foo'。匹配子串能被结果数组中的素[1], ..., [n] 返\n回,或被RegExp对象的属性$1, ..., $9返回。\n字符x|y \n意义:匹配'x'或者'y'。 \n例如:\u002Fgreen|red\u002F匹配\"green apple\"中的'green'和\"red apple.\"中的'red'。\n字符{n} \n意义:这里的n是一个正整数。匹配前面的n个字符。 \n例如:\u002Fa{2}\u002F不匹配\"candy,\"中的'a',但匹配\"caandy,\" 中的所有'a'和\"caaandy.\"中前面的两个 \n'a'。\n字符{n,} \n意义:这里的n是一个正整数。匹配至少n个前面的字符。 \n例如:\u002Fa{2,}不匹配\"candy\"中的'a',但匹配\"caandy\"中的所有'a'和\"caaaaaaandy.\"中的所有'a'\n字符{n,m} \n意义:这里的n和m都是正整数。匹配至少n个最多m个前面的字符。 \n例如:\u002Fa{1,3}\u002F不匹配\"cndy\"中的任何字符,但匹配 \"candy,\"中的'a',\"caandy,\" 中的前面两个 \n'a'和\"caaaaaaandy\"中前面的三个'a',注意:即使\"caaaaaaandy\" 中有很多个'a',但只匹配前面的三 \n个'a'即\"aaa\"。\n字符[xyz] \n意义:一字符列表,匹配列出中的任一字符。你可以通过连字符-指出一个字符范围。 \n例如:[abcd]跟[a-c]一样。它们匹配\"brisket\"中的'b'和\"ache\"中的'c'。\n字符[^xyz] \n意义:一字符补集,也就是说,它匹配除了列出的字符外的所有东西。 你可以使用连字符-指出一 \n字符范围。 \n例如:[^abc]和[^a-c]等价,它们最早匹配\"brisket\"中的'r'和\"chop.\"中的'h'。\n字符[\\b] \n意义:匹配一个空格(不要与\\b混淆)\n字符\\b \n意义:匹配一个单词的分界线,比如一个空格(不要与[\\b]混淆) \n例如:\u002F\\bn\\w\u002F匹配\"noonday\"中的'no',\u002F\\wy\\b\u002F匹配\"possibly yesterday.\"中的'ly'。\n字符\\B \n意义:匹配一个单词的非分界线 \n例如:\u002F\\w\\Bn\u002F匹配\"noonday\"中的'on',\u002Fy\\B\\w\u002F匹配\"possibly yesterday.\"中的'ye'。\n字符\\cX \n意义:这里的X是一个控制字符。匹配一个字符串的控制字符。 \n例如:\u002F\\cM\u002F匹配一个字符串中的control-M。\n字符\\d \n意义:匹配一个数字,等价于[0-9]。 \n例如:\u002F\\d\u002F或\u002F[0-9]\u002F匹配\"B2 is the suite number.\"中的'2'。\n字符\\D \n意义:匹配任何的非数字,等价于[^0-9]。 \n例如:\u002F\\D\u002F或\u002F[^0-9]\u002F匹配\"B2 is the suite number.\"中的'B'。\n字符\\f \n意义:匹配一个表单符\n字符\\n \n意义:匹配一个换\u003Cem\u003E行\u003C\u002Fem\u003E符\n字符\\r \n意义:匹配一个回车符\n字符\\s \n意义:匹配一个单个white空格符,包括空格,tab,form feed,换\u003Cem\u003E行\u003C\u002Fem\u003E符,等价于[ \\f\\n\\r\\t\\v]。 \n例如:\u002F\\s\\w*\u002F匹配\"foo bar.\"中的' bar'。\n字符\\S \n意义:匹配除white空格符以外的一个单个的字符,等价于[^ \\f\\n\\r\\t\\v]。 \n例如:\u002F\\S\u002F\\w*匹配\"foo bar.\"中的'foo'。\n字符\\t \n意义:匹配一个制表符\n字符\\v \n意义:匹配一个顶头制表符\n字符\\w \n意义:匹配所有的数字和字母以及下划线,等价于[A-Za-z0-9_]。 \n例如:\u002F\\w\u002F匹配\"apple,\"中的'a',\"$5.28,\"中的'5'和\"3D.\"中的'3'。\n字符\\W \n意义:匹配除数字、字母外及下划线外的其它字符,等价于[^A-Za-z0-9_]。 \n例如:\u002F\\W\u002F或者\u002F[^$A-Za-z0-9_]\u002F匹配\"50%.\"中的'%'。\n字符\\n \n意义:这里的n是一个正整数。匹配一个正则表达式的最后一个子串的n的值(计数左圆括号)。\n例如:\u002Fapple(,)\\sorange\\1\u002F匹配\"apple, orange, cherry, peach.\"中的'apple, orange',下面 \n有一个更加完整的例子。 \n注意:如果左圆括号中的数字比\\n指定的数字还小,则\\n取下一\u003Cem\u003E行\u003C\u002Fem\u003E的八进制escape作为描述。\n字符\\ooctal和\\xhex \n意义:这里的\\ooctal是一个八进制的escape值,而\\xhex是一个十六进制的escape值,允许在一个 \n正则表达式中嵌入ASCII码。\n\n当表达式被检查的时候,文字符号提供了编辑正则表达式的方法。利用文字符号可以使到正则表达 \n式保持为常数。例如,如果你在一个循环中使用文字符号来构造一个正则表达式,正则表达式不需进\u003Cem\u003E行\u003C\u002Fem\u003E \n反复编译。 \n正则表达式对象构造器,例如,new RegExp(\"ab+c\"),提供正则表达式的运\u003Cem\u003E行\u003C\u002Fem\u003E时编译。当你知道正 \n则表达式的模式\u003Cem\u003E会\u003C\u002Fem\u003E变化的时候,应该使用构造函数,或者你不知道正则表达式的模式,而它们是从另外 \n的源获得的时候,比如由用户输入时。一旦你定义好了正则表达式,该正则表达式可在任何地方使用, \n并且可以改变,你可以使用编译方法来编译一个新的正则表达式以便重新使用。 \n一个分离预先定义的RegExp对象可以在每个窗口中使用;也就是说,每个分离的JavaScript线程运 \n\u003Cem\u003E行\u003C\u002Fem\u003E以获得自己的RegExp对象。因为每个脚本在一个线程中是不可中断的,这就确保了不同的脚本不\u003Cem\u003E会\u003C\u002Fem\u003E覆 \n盖RegExp对象的值。 \n预定义的RegExp对象包含的静态属性:input, multiline, lastMatch,lastParen, leftContext, \nrightContext, 以及从$1到$9。input和multiline属性能被预设。其它静态属性的值是在执\u003Cem\u003E行\u003C\u002Fem\u003E个别正则 \n表达式对象的exec和test方法后,且在执\u003Cem\u003E行\u003C\u002Fem\u003E字符串的match和replace方法后设置的。\n属性 \n注意RegExp对象的几个属性既有长名字又有短名字(象Perl)。这些名字都是指向相同的值。Perl是 \n一种编程语言,而JavaScript模仿了它的正则表达式。\n属性$1, ..., $9 \n取得匹配的子串,如果有的话\n属性$_ \n参考input\n属性$* \n参考multiline\n属性$& \n参考lastMatch\n属性$+ \n参考lastParen\n属性$` \n参考leftContext\n属性$' \n参考rightContext\n属性constructor \n指定用来建立对象原型函\n属性global \n决定是否测试正则表达式是否不能匹配所有的字符串,或者只是与最先的冲突。\n属性ignoreCase \n决定试图匹配字符串的时候是否忽略大小写\n属性input \n当正则表达式被匹配的时候,为相反的字符串。\n属性lastIndex \n决定下一次匹配从那里开始\n属性lastMatch \n最后一个匹配的字符\n属性lastParen \n子串匹配的时候,最后一个parenthesized,如果有的话。\n属性leftContext \n最近一次匹配前的子串。\n属性multiline \n是否在串的多\u003Cem\u003E行\u003C\u002Fem\u003E中搜索。\n属性prototype \n允许附加属性到所有的对象\n属性rightContext \n最近一次匹配后的的子串。\n属性source \n模式文本\n\n\n方法 \ncompile方法 \n编译一个正则表达式对象\nexec方法 \n运\u003Cem\u003E行\u003C\u002Fem\u003E正则表达式匹配\ntest方法 \n测试正则达式匹配\ntoSource方法 \n返回一个对象的文字描述指定的对象;你可以使用这个值来建立一个新的对象。不考虑Object.toS \nource方法。\ntoString方法 \n返回一个字符串描述指定的对象,不考虑Object.toString对象。\nvalueOf方法 \n返回指定对角的原始值。不考虑Object.valueOf方法。\n 另外,这个对象继承了对象的watch和unwatch方法\n\n   例子: \n   例1、下述示例脚本使用replace方法来转换串中的单词。在替换的文本中,脚本使用全局 RegExp \n对象的$1和$2属性的值。注意,在作为第二个参数传递给replace方法的时候,RegExp对象的$属性的名 \n称。 \n \nre = \u002F(\\w+)\\s(\\w+)\u002F; \nstr = \"John Smith\"; \nnewstr=str.replace(re,\"$2, $1\"); \ndocument.write(newstr) \n \n显示结果:\"Smith, John\".\n  例2、下述示例脚本中,RegExp.input由Change事件处理句柄设置。在getInfo函数中,exec 方法 \n使用RegExp.input的值作为它的参数,注意RegExp预置了$属性。\n\n \nfunction getInfo(abc) \n{ \nre = \u002F(\\w+)\\s(\\d+)\u002F; \nre.exec(abc.value); \nwindow.alert(RegExp.$1 + \", your age is \" + RegExp.$2); \n} \n\n  请输入你的姓和年龄,输入完后按回车键。 \n   \n   \n\n$1, ..., $9属性 \n用圆括号括着的匹配子串,如果有的话。 \n是RegExp的属性 \n静态,只读\n在JavaScript 1.2, NES 3.0以上版本提供 \n描述:因为input是静态属性,不是个别正则表达式对象的属性。你可以使用RegExp.input 访问该 \n属性。\n能加上圆括号的子串的数量不受限制,但正则表达式对象只能保留最后9 条。如果你要访问所有的 \n圆括号内的匹配字串,你可以使用返回的数组。\n这些属性能用在RegExp.replace方法替换后的字符串(输出结果)。当使用这种方式的时候,不用预 \n先考虑RegExp对象。下面给出例子。当正则表达式中没有包含圆括号的时候,该脚本解释成$n的字面意 \n义。(这里的n是一个正整数)。\n\n例如: \n下例脚本使用replace 方法来交换串中单词的位置。在替换后的文本字串中,脚本使用正则表达式 \nRegExp对象的$1和$2属性的值。注意:当它们向replace方法传递参数的时候,这里没有考虑 $ 属性的 \nRegExp对象的名称。 \n \nre = \u002F(\\w+)\\s(\\w+)\u002F; \nstr = \"John Smith\"; \nnewstr=str.replace(re,\"$2, $1\"); \ndocument.write(newstr) \n \n显示的输出结果为:Smith, John。 \n \n正则表达式regular expression详述(二) \nhttp:\u002F\u002Fwww.kymita.com\u002F888.\u003Cem\u003Easp\u003C\u002Fem\u003E 2002-12-15 蓝箭工作室\n\n正则表达式详述(二)\n以下这些不是正则表达式的新增对象请参阅对应的JavaScript对象的属性 $_属性 参考input $*属性 \n参考multiline $&属性 参考lastMatch $+属性 参考lastParen $`属性 \n参考leftContext $'属性 参考rightContext compile方法 在脚本运\u003Cem\u003E行\u003C\u002Fem\u003E期间编译正则表达式对象 \n属于RegExp的方法 在JavaScript 1.2, NES 3.0以上版本提供 语法: \nregexp.compile(pattern[, flags]) 以数: regexp 正则表达式的名称,可以是变量名或文字串。 \npattern 正则表达式的定义文本。 flags 如果指定的话,可以是下面其中的一个: \"g\": 匹配所有可能的字串 \n\"i\": 忽略大小写 \"gi\": 匹配所有可能的字串及忽略大小写 描述: \n使用compile方法来编译一个正则表达式 created with the RegExp constructor function。这样 \n就强制正则表达式只编译一次,而不是每次遇到正则表达式的时候都编译一次。当你确认正则表达式能 \n保持不变的时候可使用compile 方法来编译它(在获得它的匹配模式后),这样就可以在脚本中重复多次使用它。 \n你亦可以使用compile 方法来改变在运\u003Cem\u003E行\u003C\u002Fem\u003E期间改变正则表达式。例如,假如正则表达式发生变化, \n你可以使用compile方法来重新编译该对象来提高使用效率。 \n使用该方法将改变正则表达式的source, global和ignoreCasesource属性的值。 constructor \n指出建立对象原型的function。注意这个属性的值由函数本身提供,而不是一个字串包含RegExp的name.Property提供。 \n在JavaScript 1.1, NES 2.0以上版本提供 ECMA版本ECMA-262 描述:参考Object.constructor. \nexec方法 在指定的字符串运\u003Cem\u003E行\u003C\u002Fem\u003E匹配搜索。返回一个结果数组。 是RegExp的方法 \n在JavaScript 1.2, NES 3.0以上版本提供 语法: regexp.exec([str])regexp([str]) \n参数: regexp,正则表达式的名称,可以是一个变量名或文字定义串。 \nstr,要匹配正则表达式的字符串,如果省略,将使用RegExp.input的值。 \n描述:就如在语法描述中的一样,正则表达工的exec方法能够被直接调用(使用regexp.exec(str))或者间接调用(使用regexp(str))。 \n假如你只是运\u003Cem\u003E行\u003C\u002Fem\u003E以找出是否匹配,可以使用String搜索方法。 \n假如匹配成功,exec方法返回一个数组并且更新正则表达式对象属性的值和预先定义的正则表达式对象、RegExp。如果匹配失败,exec方法返回null。 \n请看下例: \u002F\u002F匹配一个b接着一个或多个d,再接着一个b \n\u002F\u002F忽略大小写 myRe=\u002Fd(b+)(d)\u002Fig; myArray = myRe.exec(\"cdbBdbsbz\"); \n 下面是该脚本的返回值:对象 属性\u002FIndex 描述 例子 \nmyArray\nmyArray的内容 [\"dbBd\", \"bB\", \"d\"] \nindex \n基于0的匹配index 1 \ninput \n原始字符串 cdbBdbsbz \n[0] \n最后匹配的字符 dbBd \n[1], ...[n] \n用圆括号括住的匹配字符串,如果有的话。不限制括号的个数。 [1] = bB \n[2] = d \nmyRe \nlastIndex \n开始下次匹配操作的index值 5 \nignoreCase \n指出\"i\"是否使用以忽略大小写 true \nglobal \n指出是否使用\"g\"标记来进\u003Cem\u003E行\u003C\u002Fem\u003E匹配所有可能的字串 true \nsource \n定义模式的文本字符串 d(b+)(d) \nRegExp \nlastMatch$& \n最后匹配的字符 dbBd \nleftContext$\\Q \n最新匹配前面的子串 c \nrightContext$' \n最新匹配后面的子串 bsbz \n$1, ...$9 \n圆括号内的匹配子串,如果有的话。圆括号的个数不受限制,但RegExp只能保留最后9个 $1 = bB \n$2 = d \nlastParen $+ \n最后一个加上圆括号的匹配子串,如果有的话 d\n假如你的正则表达式使用了\"g\"标记,你可以多次使用exec 方法来连续匹配相同的串。当你这样\u003Cem\u003E做\u003C\u002Fem\u003E \n的时候,新的匹配将从由正则表达式的lastIndex 属性值确定的子串中开始。例如,假定你使用下面的脚本: \n myRe=\u002Fab*\u002Fg;str = \"abbcdefabh\" \nmyArray = myRe.exec(str); \ndocument.writeln(\"Found \"+myArray[0]+\". Next match starts at \"+myRe.lastIndex) \nmySecondArray = myRe.exec(str); \ndocument.writeln(\"Found \"+mySecondArray[0]+\". Next match starts at \"+myRe.lastIndex) \n 这个脚本显示如下结果: Found abb. Next match starts at 3 \nFound ab. Next match starts at 9 例子: \n在下面的例子中,用户输入一个名字,脚本根据输入执\u003Cem\u003E行\u003C\u002Fem\u003E匹配操作。接着检查数组看是否和其它用户的名字匹配。 \n本脚本假定已注册的用户的姓已经存进了数组A中,或许从一个\u003Cem\u003E数据\u003C\u002Fem\u003E库中取得。 \n A = [\"zhao\",\"qian\",\"sun\",\"li\",\"liang\"] \nfunction lookup() { firstName = \u002F\\w+\u002Fi(); if (!firstName) \nwindow.alert (RegExp.input + \"非法输入\"); else { count=0; \nfor (i=0;i 输入你的姓然后按回车键。 \n \n global属性 正则表达式中是否使用了\"g\"标记。 RegExp属性,只读 \n在JavaScript 1.2, NES 3.0以上版本提供 描述: global是一个个别正则表达式对象的属性 \n如果使用了\"g\"标记,global的值为true;否则为 false。\"g\"标记指定正则表达式测试所有可能的匹配。 \n你不能直接改变该属性的值,但可以调用compile方法来改变它。 ignoreCase 检查正则表达式是否使用了\"i\"标记 \nRegExp属性,只读 在JavaScript 1.2, NES 3.0以上版本提供 描述: \nignoreCase是个别正则表达式对象的一个属性。 \n如果使用了\"i\"标记,则返回true,否则返回false。\"i\"标记指示在进\u003Cem\u003E行\u003C\u002Fem\u003E匹配的时候忽略大小写。\n你不能直接改变该属性的值,但可以通过调用compile方法来改变它 input 指出正则表达式要测试那个字串。$_是这个属性的另一个名字。 \nRegExp的属性,静态 在JavaScript 1.2, NES 3.0以上版本提供 \n描述:因为input是静态的,不是某个个别的正则表达式对象的属性。你也可以使用 RegExp.input来表示。 \n如果没有给正则表达式的exec或test方法提供字符串,并且RegExp.input中有值,则使用它的值来调用该方法。 \n脚本或浏览器能够预置input属性。如果被预置了值且调用exec或 test方法的时候没有提供字符串 \n则调用exec或test的时候使用input的值。input可以被浏览器以下面的方式设置: \n当text表单域处理句柄被调用的时候,input被设置为该text输入的字串。 \n当textarea表单域处理句柄被调用的时候,input被设置为textarea域内输入的字串。注意multili \nne亦被设置成true从而能匹配多\u003Cem\u003E行\u003C\u002Fem\u003E文本。 当select表单域处理句柄被调用的时候,input被设置成selected text的值。 \n当链接对象的处理句柄被调用的时候,input被设置成和之间的字符串。 \n事件理现句柄处理完毕后,input属性的值被清除。 lastIndex 可读\u002F可写的一个整数属性,指出下一次匹配从哪里开始。 \nRegExp的属性 在JavaScript 1.2, NES 3.0以上版本提供 \n描述:lastIndex 是个别的正则表达式对象的属性。 这个属性只有当正则表达式的\"g\"标记被使用以进\u003Cem\u003E行\u003C\u002Fem\u003E全串匹配的时候才被设置。实\u003Cem\u003E行\u003C\u002Fem\u003E以下规则: \n如果lastIndex大小字符串的长度,regexp.test和regexp.exec失败,且lastIndex被设为0。 \n如果lastIndex等于字串的长度且正则表达式匹配空字符串,则正则表达式从lastIndex的位置开始匹配。 \n如果lastIndex等于字符串的长度且正则表达式不匹配空字符串,则正则表达式不匹配input,且lastIndex被置为0。 \n否则,lastIndex被设置成最近一次匹配的下一点。 例如,按下面的顺序执\u003Cem\u003E行\u003C\u002Fem\u003E脚本: re = \u002F(hi)?\u002Fg 匹配空字符串 \nre(\"hi\") 返回[\"hi\", \"hi\"],lastIndex置为2 \nre(\"hi\") 返回[\"\"],一个空数组,它的下标为0的元素就是匹配字符串。在这种情况下,返回空\n串是因为lastIndex等于2(且仍然是2),并且\"hi\"的长度也是2。 lastMatch 最后一次匹配字符串,$&是同样的意思。 \nRegExp的属性,静态,只读 在JavaScript 1.2, NES 3.0以上版本提供 \n描述:因为lastMatch是静态的,所以它不是个别指定正则表达式的属性。你也可以使用RegExp.lastMatch。 lastParen \n最后一次加上括号的匹配字符串,如果有的话。$+是同样的意思。 RegExp属性,静态,只读\n在JavaScript 1.2, NES 3.0以上版本提供 \n描述:因为lastParen是静态的,它不是某个个别正则式的属性,你可以使用RegExp.lastParen 表达同样的意思。 \nleftContext 最近一次匹配前面的子串,$`具有相同的意思。 RegExp的属性,静态,只读 \n在JavaScript 1.2, NES 3.0以上版本提供 \n描述:因为leftContext是静态的,不是某一个正则表达式的属性,所以可以使用RegExp.leftContext来表达想同的意思。 \nmultiline 反映是否匹配多\u003Cem\u003E行\u003C\u002Fem\u003E文本,$*是相同的意思。 RegExp的属性,静态 \n在JavaScript 1.2, NES 3.0以上版本提供 \n描述:因为multiline是静态的,而不是某个个别正则表达式的属性,所以能够用RegExp.multiline表达相同的意思。 \n如果允许匹配多\u003Cem\u003E行\u003C\u002Fem\u003E文本,则multiline为true,如果搜索必须在换\u003Cem\u003E行\u003C\u002Fem\u003E时停止,则为false。 \n脚本或浏览器能够设置multiline属性。当一个textarea的事件处理句柄被调用的时候,multiline \n被置为true。在事件处理句柄处理完毕后,multiline属性值被清除。也就是说,如果你设置了multili \nne为true,则执\u003Cem\u003E行\u003C\u002Fem\u003E任何的事件处理句柄后,multiline被置为false。 prototype \n描绘类的原型。你可以根据要求使用prototype来增加类的属性或方法。为了获得prototypes 的资 \n料,请参阅RegExp的Function.prototype.Property属性。 从JavaScript 1.1, NES 2.0版本开始提供 \nECMA版本ECMA-262 rightContext 最后一次匹配的右边的字符串,$'是同样的效果。 \nRegExp的属性,静态,只读 从 JavaScript 1.2, NES 3.0以上版本开始提供 \n描述:因为rightContext是静态的,不是某个个别正则表达工的属性,可以使用RegExp.rightContext来达到相同的效果。 \nsource 一个只读属性,包含正则表达式定义的模式,不包侨forward slashes和\"g\"或\"i\"标记。 RegExp的属性,只读 \n从JavaScript 1.2, NES 3.0以上版本开始提供 \n描述:source是个别正则表达式对象的属性,你不能直接改变它的值,但可以通过调用compile 方法来改变它。 test \n执\u003Cem\u003E行\u003C\u002Fem\u003E指定字符串的正则表达式匹配搜索,返回true或false。 RegExp的方法 \n从JavaScript 1.2, NES 3.0以上版本开始提供 语法:regexp.test([str]) \n参数:regexp,正则表达式的名称,可以是变量名或正则表达式定义文字串 \nstr,要匹配的字符串,如果省略,将使用RegExp.input的值为作参数 \n描述:当你需要知道一个字符串能否匹配某个正则表达工,可以使用test方法(与String.search方 \n法类似); 为了获得更多的信息(但速度将变慢),可以使用exec方法(与String.match方法类似)。 例子:下面的例子显示test是否成功的提示: \nfunction testinput(re, str){ \nif (re.test(str)) midstring = \" contains \"; \nelse midstring = \" does not contain \"; \ndocument.write (str + midstring + re.source); } toSource \n返回一个字符串象征对象的源码 RegExp的方法 从JavaScript 1.3以上版本开始提供 语法:toSource() \n参数:没有 描述:toSource方法返回下述的值: 对于内置的RegExp对象,toSource返回下面的字符象征源码不可用: \nfunction Boolean(){ [native code] } \n在RegExp场合中, toSource返回象征源码的字符串,通常这个方法是由JavaScript内部\u003Cem\u003E自动\u003C\u002Fem\u003E调用而不是不代码中显式调用。 \n更多请看Object.toSource toString 返回描绘指定对象的字符串。 RegExp的方法 \n从JavaScript 1.1, NES 2.0开始提供 ECMA版本ECMA-262 语法:toString() 参数:无 \n描述:RegExp对象不考虑Object对象的toString方法;它不继承Object.toString,对于RegExp 对 \n象,toString方法返回一个代表该对象的字符串。 例如:下面的例子显示象征RegExp对象的字符串 \nmyExp = new RegExp(\"a+b+c\"); alert(myExp.toString()) \ndisplays \"\u002Fa+b+c\u002F\" 更多请看:Object.toString valueOf 返回一个RegExp对象的原始值 \nRegExp的方法 从JavaScript 1.1版本开始提供 ECMA版本:ECMA-262 语法:valueOf() \n参数:无 描述:RegExp的valueOf方法以字符串形式返回RegExp对象的原始值,这个值与RegExp.toString相等。 \n该方法通常由JavaScript内部\u003Cem\u003E自动\u003C\u002Fem\u003E调用而不是显式调用 例子: myExp = new RegExp(\"a+b+c\"); \nalert(myExp.valueOf()) displays \"\u002Fa+b+c\u002F\" \n \n正则表达式在javascript中的几个实例1(转)\n! 去除字符串两端空格的处理 \n\n如果采用传统的方式,就要可能就要采用下面的方式了 \n\u002F\u002F清除左边空格 \nfunction \u003Cem\u003Ejs\u003C\u002Fem\u003E_ltrim(deststr) \n{ \nif(deststr==null)return \"\"; \nvar pos=0; \nvar retStr=new String(deststr); \nif (retStr.lenght==0) return retStr; \nwhile (retStr.substring(pos,pos+1)==\" \") pos++; \nretStr=retStr.substring(pos); \nreturn(retStr); \n} \n\u002F\u002F清除右边空格 \nfunction \u003Cem\u003Ejs\u003C\u002Fem\u003E_rtrim(deststr) \n{ \nif(deststr==null)return \"\"; \nvar retStr=new String(deststr); \nvar pos=retStr.length; \nif (pos==0) return retStr; \nwhile (pos && retStr.substring(pos-1,pos)==\" \" ) pos--; \nretStr=retStr.substring(0,pos); \nreturn(retStr); \n} \n\u002F\u002F清除左边和右边空格 \nfunction \u003Cem\u003Ejs\u003C\u002Fem\u003E_trim(deststr) \n{ \nif(deststr==null)return \"\"; \nvar retStr=new String(deststr); \nvar pos=retStr.length; \nif (pos==0) return retStr; \nretStr=\u003Cem\u003Ejs\u003C\u002Fem\u003E_ltrim(retStr); \nretStr=\u003Cem\u003Ejs\u003C\u002Fem\u003E_rtrim(retStr); \nreturn retStr; \n} \n\n采用正则表达式,来去除两边的空格,只需以下代码 \nString.prototype.trim = function() \n{ \nreturn this.replace(\u002F(^\\s*)|(\\s*$)\u002Fg, \"\"); \n} \n\n一句就搞定了, \n可见正则表达式为我们节省了相当的编写代码量 \n\n\n! 移动手机号的校验 \n\n如果采用传统的校验方式至少就要完成下面三步的校验, \n(1). 是否是数字 \n(2).是否是11位 \n(3).数字的第三位是否是5,6,7,8,9 \n如果采用正则表达式校验,只需以下代码 \nfunction checkMobile1(form) \n{ \nif (form.mobile.value \u003E \"\") \n{ \nvar reg=\u002F13[5,6,7,8,9]\\d{8}\u002F; \nif ( form.mobile.value.match(reg)== null) \n{ \nalert(\"请输入正确的移动手机号码!\"); \nform.mobile.focus(); return false; \n} \n} \nreturn true; \n} \n\n从上面的代码可以看出校验移动手机号只需定义一个var reg=\u002F13[5,6,7,8,9]\\d{8}\u002F;模式匹配串就可以完成合法性校验了 \n\n! URL的校验, \n条件:必须以http:\u002F\u002F 或 https:\u002F\u002F 开头, 端口号必须为在1-65535 之间, 以下代码完成了合法性校验 \n\n\u002F\u002Fobj:\u003Cem\u003E数据\u003C\u002Fem\u003E对象 \n\u002F\u002FdispStr :失败提示内容显示字符串 \nfunction checkUrlValid( obj, dispStr) \n{ \nif(obj == null) \n{ \nalert(\"传入对象为空\"); \nreturn false; \n} \nvar str = obj.value; \n\nvar urlpatern0 = \u002F^https?:\\\u002F\\\u002F.+$\u002Fi; \nif(!urlpatern0.test(str)) \n{ \nalert(dispStr+\"不合法:必须以'http:\\\u002F\\\u002F'或'https:\\\u002F\\\u002F'开头!\"); \nobj.focus(); \nreturn false; \n} \n\nvar urlpatern2= \u002F^https?:\\\u002F\\\u002F(([a-zA-Z0-9_-])+(\\.)?)*(:\\d+)?.+$\u002Fi; \nif(!urlpatern2.test(str)) \n{ \nalert(dispStr+\"端口号必须为数字且应在1-65535之间!\"); \nobj.focus(); \nreturn false; \n} \n\n\nvar urlpatern1 =\u002F^https?:\\\u002F\\\u002F(([a-zA-Z0-9_-])+(\\.)?)*(:\\d+)?(\\\u002F((\\.)?(\\?)?=?&?[a-zA-Z0-9_-](\\?)?)*)*$\u002Fi; \n\nif(!urlpatern1.test(str)) \n{ \nalert(dispStr+\"不合法,请检查!\"); \nobj.focus(); \nreturn false; \n} \n\nvar s = \"0\"; \nvar t =0; \nvar re = new RegExp(\":\\\\d+\",\"ig\"); \nwhile((arr = re.exec(str))!=null) \n{ \ns = str.substring(RegExp.index+1,RegExp.lastIndex); \n\nif(s.substring(0,1)==\"0\") \n{ \nalert(dispStr+\"端口号不能以0开头!\"); \nobj.focus(); \nreturn false; \n} \n\nt = parseInt(s); \nif(t65535) \n{ \nalert(dispStr+\"端口号必须为数字且应在1-65535之间!\"); \nobj.focus(); \nreturn false; \n} \n} \nreturn true; \n} \n\n对url的校验,看上去有很多的代码,这是因为要给予出错提示, 否则只需var urlpatern1 =\u002F^https?:\\\u002F\\\u002F(([a-zA-Z0-9_-])+(\\.)?)*(:\\d+)?(\\\u002F((\\.)?(\\?)?=?&?[a-zA-Z0-9_-](\\?)?)*)*$\u002Fi; 一句就可以校验出url合法性了\n \n \n \n 正则表达式在JavaScript应用\t\n \t\n时间戳: 2004-11-30 15:29:30 人气: 23\t\n作者: AnyRock 来源:www.mending.cn\t\n \t\n-------------------------------------------------------------- \n去掉字符串头尾多余的空格 \n\u002Fg是全文查找所有匹配 \n\nfunction String.prototype.Trim(){return this.replace(\u002F(^\\s*)|(\\s*$)\u002Fg, \"\");} \n\nfunction String.prototype.LTrim(){return this.replace(\u002F(^\\s*)\u002Fg, \"\");} \n\nfunction String.prototype.RTrim(){return this.replace(\u002F(\\s*$)\u002Fg, \"\");} \n\n-------------------------------------------------------------- \n应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) \n\nString.prototype.len=function(){return this.replace([^\\x00-\\xff]\u002Fg,\"aa\").length;} \n\n-------------------------------------------------------------- \n应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下: \n\nString.prototype.trim = function() \n{ \nreturn this.replace(\u002F(^\\s*)|(\\s*$)\u002Fg, \"\"); \n} \n得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1 \n\ns=\"http:\u002F\u002Fwww.9499.net\u002Fpage1.htm\" \ns=s.replace(\u002F(.*\\\u002F){0,}([^\\.]+).*\u002Fig,\"$2\") \nalert(s) \n\n##利用正则表达式限制网页表单里的文本框输入内容: \n\n-------------------------------------------------------------- \n用正则表达式限制只能输入中文:onkeyup=\"value=value.replace(\u002F[^\\u4E00-\\u9FA5]\u002Fg,')\" onbeforepaste=\"clipboardData.setData('text',clipboardData.getData('text').replace(\u002F[^\\u4E00-\\u9FA5]\u002Fg,'))\" \n\n-------------------------------------------------------------- \n用正则表达式限制只能输入全角字符: onkeyup=\"value=value.replace(\u002F[^\\uFF00-\\uFFFF]\u002Fg,')\" onbeforepaste=\"clipboardData.setData('text',clipboardData.getData('text').replace(\u002F[^\\uFF00-\\uFFFF]\u002Fg,'))\" \n\n-------------------------------------------------------------- \n用正则表达式限制只能输入数字:onkeyup=\"value=value.replace(\u002F[^\\d]\u002Fg,') \"onbeforepaste=\"clipboardData.setData('text',clipboardData.getData('text').replace(\u002F[^\\d]\u002Fg,'))\"\n\n-------------------------------------------------------------- \n用正则表达式限制只能输入数字和英文:onkeyup=\"value=value.replace(\u002F[\\W]\u002Fg,') \"onbeforepaste=\"clipboardData.setData('text',clipboardData.getData('text').replace(\u002F[^\\d]\u002Fg,'))\"\t\n \t\n\n用正则表达式和javascript对表单进\u003Cem\u003E行\u003C\u002Fem\u003E全面验证\n代码:\u003C!-- \n使用时请将下面的javascript代码存到一个单一的\u003Cem\u003Ejs\u003C\u002Fem\u003E文件中。 \n1、表单要求 \n \n将对表单中的所有以下类型的域依次验证,所有验证是去除了前导和后缀空格的,要注意是区分大小写的。 \n2、空值验证 \n表单中任意域加上emptyInfo属性将对此域是否为空进\u003Cem\u003E行\u003C\u002Fem\u003E验证(可以和最大长度验证\\一般验证方式同时使用)。 \n无此属性视为此域允许空值。 \n   如: \n3、最大长度验证(可以和空值验证、一般验证方式同时使用): \n \n或, \n3、一般验证方式(不对空值\u003Cem\u003E做\u003C\u002Fem\u003E验证): \n   如: \n4、标准验证(不与其它验证方式同时使用): \n全部通过来实现,并且不需要name属性以免提交到服务器。 \n   4.1、合法日期验证: \n注:这里也可以是,以下同 \n \n \n \nyearfieldName、monthfieldName、dayfieldName分别为年月日字段,月和日可以是两位(MM)或一位格式(M), \n此处不对每个字段分别检验(如果要检验,请在年月日三个域分别使用前面的一般验证方式),只对日期的最大值是否合法检查; \n4.2、日期格式验证(请注意,此验证不对日期是否有效进\u003Cem\u003E行\u003C\u002Fem\u003E验证,还未找到从格式中得到年月日\u003Cem\u003E数据\u003C\u002Fem\u003E的方法^_^): \n \n \n其中格式仅对y、M、d、H、m、s进\u003Cem\u003E行\u003C\u002Fem\u003E支持(其它字符视为非时间的字符) \n4.3、列表验证: \n检验列表(checkbox、redio、select)是否至少选中了一条记录(对select主要用于多项选择) \n \n \n其中validatorType可以是Checkbox、R、Select; \n对于一个select表单,如果要求选择一条不能是第一条的记录,请用下列方式: \n \n==请选择== \n1 \n \n4.4、Email验证: \n \n \n其中separator为可选项,表示输入多个email时的分隔符(无此选项只能是一个地址) \n4.5、加入其它javascript操作: \n \nfunction functionname(){ \n自定义方法 \n} \n \n表单中加入(此时emptyInfo等属性无效) \n时将调用function属性中指定的javascript方法(要求方法返回true或false,返回false将不再验证表单,也不提交表单)。 \n5、在表单通过验证提交前disable一个按钮(也可将其它域disable,不能与其它验证同在一个域),不要求按钮是表单中的最后一个 \n \n6、不验证表单 \n   \n当validator域值为0时不对表单进\u003Cem\u003E行\u003C\u002Fem\u003E验证,直接提交表单或执\u003Cem\u003E行\u003C\u002Fem\u003E指定function并返回true后提交表单 \nfunctionName为可选\n--\u003E \n \nfunction getStringLength(str){ \nvar endvalue=0; \nvar sourcestr=new String(str); \nvar tempstr; \nfor (var strposition = 0; strposition 255 || tempstr.charCodeAt(0)\u003C0) { \nendvalue=endvalue+2; \n} else { \nendvalue=endvalue+1; \n} \n} \nreturn(endvalue); \n} \nfunction trim(str){ \nif(str==null) return \"\"; \nif(str.length==0) return \"\"; \nvar i=0,j=str.length-1,c; \nfor(;i-1;j--){ \nc=str.charAt(j); \nif(c!=' ') break; \n} \nif(i\u003Ej) return \"\"; \nreturn str.substring(i,j+1); \n} \nfunction validateDate(date,format,alt){ \nvar time=trim(date.value); \nif(time==\"\") return; \nvar reg=format; \nvar reg=reg.replace(\u002Fyyyy\u002F,\"[0-9]{4}\"); \nvar reg=reg.replace(\u002Fyy\u002F,\"[0-9]{2}\"); \nvar reg=reg.replace(\u002FMM\u002F,\"((0[1-9])|1[0-2])\"); \nvar reg=reg.replace(\u002FM\u002F,\"(([1-9])|1[0-2])\"); \nvar reg=reg.replace(\u002Fdd\u002F,\"((0[1-9])|([1-2][0-9])|30|31)\"); \nvar reg=reg.replace(\u002Fd\u002F,\"([1-9]|[1-2][0-9]|30|31))\"); \nvar reg=reg.replace(\u002FHH\u002F,\"(([0-1][0-9])|20|21|22|23)\"); \nvar reg=reg.replace(\u002FH\u002F,\"([0-9]|1[0-9]|20|21|22|23)\"); \nvar reg=reg.replace(\u002Fmm\u002F,\"([0-5][0-9])\"); \nvar reg=reg.replace(\u002Fm\u002F,\"([0-9]|([1-5][0-9]))\"); \nvar reg=reg.replace(\u002Fss\u002F,\"([0-5][0-9])\"); \nvar reg=reg.replace(\u002Fs\u002F,\"([0-9]|([1-5][0-9]))\"); \nreg=new RegExp(\"^\"+reg+\"$\"); \nif(reg.test(time)==false){\u002F\u002F验证格式是否合法 \nalert(alt); \ndate.focus(); \nreturn false; \n} \nreturn true; \n} \nfunction validateDateGroup(year,month,day,alt){ \nvar array=new Array(31,28,31,30,31,30,31,31,30,31,30,31); \nvar y=parseInt(year.value); \nvar m=parseInt(month.value); \nvar d=parseInt(day.value); \nvar maxday=array[m-1]; \nif(m==2){ \nif((y%4==0&&y0!=0)||y%400==0){ \nmaxday=29; \n} \n} \nif(d\u003Emaxday){ \nalert(alt); \nreturn false; \n} \nreturn true; \n} \nfunction validateCheckbox(obj,alt){ \nvar rs=false; \nif(obj!=null){ \nif(obj.length==null){ \nreturn obj.checked; \n} \nfor(i=0;i\u003Cobj.length;i++){ \nif(obj[i].checked==true){ \nreturn true; \n} \n} \n} \nalert(alt); \nreturn rs; \n} \nfunction validateRadio(obj,alt){ \nvar rs=false; \nif(obj!=null){ \nif(obj.length==null){ \nreturn obj.checked; \n} \nfor(i=0;i\u003Cobj.length;i++){ \nif(obj[i].checked==true){ \nreturn true; \n} \n} \n} \nalert(alt); \nreturn rs; \n} \nfunction validateSelect(obj,alt){ \nvar rs=false; \nif(obj!=null){ \nfor(i=0;i\u003Cobj.options.length;i++){ \nif(obj.options[i].selected==true){ \nreturn true; \n} \n} \n} \nalert(alt); \nreturn rs; \n} \nfunction validateEmail(email,alt,separator){ \nvar mail=trim(email.value); \nif(mail==\"\") return; \nvar em; \nvar myReg = \u002F^[_a-z0-9]+@([_a-z0-9]+\\.)+[a-z0-9]{2,3}$\u002F; \nif(separator==null){ \nif(myReg.test(email.value)==false){ \nalert(alt); \nemail.focus(); \nreturn false; \n} \n} \nelse{ \nem=email.value.split(separator); \nfor(i=0;i0&&myReg.test(em[i])==false){ \nalert(alt); \nemail.focus(); \nreturn false; \n} \n} \n} \nreturn true; \n} \nfunction validateForm(theForm){\u002F\u002F 若验证通过则返回true \nvar disableList=new Array(); \nvar field = theForm.elements; \u002F\u002F 将表单中的所有元素放入数组 \nfor(var i = 0; i field[i].maxLength){ \nalert(lengthInfo); \nfield[i].focus(); \nreturn false; \n}\nvar validatorType=field[i].validatorType; \nif(validatorType!=null){\u002F\u002F其它javascript \nvar rs=true; \nif(validatorType==\"javascript\"){ \neval(\"rs=\"+field[i].functionName+\"()\"); \nif(rs==false){ \nreturn false; \n} \nelse{ \ncontinue; \n} \n} \nelse if(validatorType==\"disable\"){\u002F\u002F提交表单前disable的按钮 \ndisableList.length++; \ndisableList[disableList.length-1]=field[i]; \ncontinue; \n} \nelse if(validatorType==\"Date\"){ \nrs=validateDate(theForm.elements(field[i].fieldName),field[i].format,field[i].errorInfo); \n} \nelse if(validatorType==\"DateGroup\"){ \nrs=validateDateGroup(theForm.elements(field[i].year),theForm.elements(field[i].month),theForm.elements(field[i].day),field[i].errorInfo);\n} \nelse if(validatorType==\"Checkbox\"){ \nrs=validateCheckbox(theForm.elements(field[i].fieldName),field[i].errorInfo); \n} \nelse if(validatorType==\"Radio\"){ \nrs=validateRadio(theForm.elements(field[i].fieldName),field[i].errorInfo); \n} \nelse if(validatorType==\"Select\"){ \nrs=validateSelect(theForm.elements(field[i].fieldName),field[i].errorInfo); \n} \nelse if(validatorType==\"Email\"){ \nrs=validateEmail(theForm.elements(field[i].fieldName),field[i].errorInfo); \n} \nelse{ \nalert(\"验证类型不被支持, fieldName: \"+field[i].name); \nreturn false; \n} \nif(rs==false){ \nreturn false; \n} \n} \nelse{\u002F\u002F一般验证 \nif(empty==false){ \nvar v = field[i].validator; \u002F\u002F 获取其validator属性 \nif(!v) continue; \u002F\u002F 如果该属性不存在,忽略当前元素 \nvar reg=new RegExp(v); \nif(reg.test(field[i].value)==false){ \nalert(field[i].errorInfo); \nfield[i].focus(); \nreturn false; \n} \n} \n} \n} \nfor(i=0;i\u003CdisableList.length;i++){ \ndisableList[i].disabled=true; \n} \nreturn true; \n} \n","createTime":"2014-12-03 14:51:39","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fu013013722\u002F8220345\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"4\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fu013013722\u002F8220345\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-4-8220345-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"},{"url":"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fa525235942\u002F2284257","title":"网管教程 从入门到精通软件篇.txt","desc":"网管教程 从入门到精通软件篇\n\n\n★一。★详细的xp修复控制台命令和用法!!! \n放入xp(2000)的光盘,安装时候选R,修复! \nWindows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令\u003Cem\u003E做\u003C\u002Fem\u003E个总结,这次辛苦老范给我们整理了这份实用的秘笈。 \n  Bootcfg \n  bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。 \n  含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。 \n  用法: \n  bootcfg \u002Fdefault  设置默认引导项。 \n  bootcfg \u002Fadd    向引导列表中\u003Cem\u003E添加\u003C\u002Fem\u003E Windows 安装。 \n  bootcfg \u002Frebuild  重复全部 Windows 安装过程并允许用户选择要\u003Cem\u003E添加\u003C\u002Fem\u003E的内容。 \n  注意:使用 bootcfg \u002Frebuild 之前,应先通过 bootcfg \u002Fcopy 命令备份 boot.ini 文件。 \n  bootcfg \u002Fscan    扫描用于 Windows 安装的所有磁盘并显示结果。 \n  注意:这些结果被静态存储,并用于本次\u003Cem\u003E会\u003C\u002Fem\u003E话。如果在本次\u003Cem\u003E会\u003C\u002Fem\u003E话期间磁盘配置发生变化,为获得更新的扫描,必须先重新启动计算机,然后再次扫描磁盘。 \n  bootcfg \u002Flist   列出引导列表中已有的条目。 \n  bootcfg \u002Fdisableredirect 在启动引导程序中禁用重定向。 \n  bootcfg \u002Fredirect [ PortBaudRrate] |[ useBiosSettings] \n  在启动引导程序中通过指定配置启用重定向。 \n  范例: \nbootcfg \u002Fredirect com1 115200 \nbootcfg \u002Fredirect useBiosSettings \n  hkdsk \n  创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。 \n  含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。 \n  vol [drive:] [ chkdsk [drive:] [\u002Fp] [\u002Fr] \n  参数  无 \n  如果不带任何参数,chkdsk 将显示当前驱动器中的磁盘状态。 \ndrive: 指定要 chkdsk 检查的驱动器。 \n\u002Fp   即使驱动器不在 chkdsk 的检查范围内,也执\u003Cem\u003E行\u003C\u002Fem\u003E彻底检查。该参数不对驱动器\u003Cem\u003E做\u003C\u002Fem\u003E任何更改。 \n\u002Fr   找到坏扇区并恢复可读取的信息。隐含着 \u002Fp 参数。 \n  注意 \nChkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)中找到该文件,将试着在 Windows 安装 CD 中找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 \nDiskpart \n  创建和删除硬盘驱动器上的分区。diskpart 命令仅在使用故障恢复控制台时才可用。 \n  diskpart [ \u002Fadd |\u002Fdelete] [device_name |drive_name |partition_name] [size] \n  参数 无 \n  如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。 \n  \u002Fadd \n  创建新的分区。 \n  \u002Fdelete \n  删除现有分区。 \n  device_name \n  要创建或删除分区的设备。设备名称可从 map 命令的输出获得。例如,设备名称: \n  DeviceHardDisk0 \n  drive_name \n  以驱动器号表示的待删除分区。仅与 \u002Fdelete 同时使用。以下是驱动器名称的范例: \n  D: \n  partition_name \n  以分区名称表示的待删除分区。可代替 drive_name 使用。仅与 \u002Fdelete 同时使用。以下是分区名称的范例: \n  DeviceHardDisk0Partition1 \n   大小 \n  要创建的分区大小,以兆字节 (MB)表示。仅与 \u002Fadd 同时使用。 \n  范例 \n  下例将删除分区: \ndiskpart \u002Fdelete Device HardDisk0 Partition3 \ndiskpart \u002Fdelete F: \n  下例将在硬盘上\u003Cem\u003E添加\u003C\u002Fem\u003E一个 20 MB 的分区: \n  diskpart \u002Fadd Device HardDisk0 20 \n  Fixboot \n","createTime":"2010-04-25 22:43:49","dataReportQuery":"spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default&depth_1-utm_source=distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default","dataReportClick":"{\"mod\":\"popu_645\",\"index\":\"5\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fa525235942\u002F2284257\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","dataReportView":"{\"mod\":\"popu_645\",\"index\":\"5\",\"dest\":\"https:\u002F\u002Fdownload.csdn.net\u002Fdownload\u002Fa525235942\u002F2284257\",\"strategy\":\"2~default~OPENSEARCH~Rate\",\"extra\":\"{\\\"utm_medium\\\":\\\"distribute.pc_relevant_bbs_down_v2.none-task-download-2~default~OPENSEARCH~Rate-5-2284257-bbs-392175119.264^v3^pc_relevant_bbs_down_v2_default\\\",\\\"dist_request_id\\\":\\\"1713939179176_97254\\\"}\",\"spm\":\"1035.2023.3001.6557\"}","type":"download"}],"staffDOList":[{"id":null,"communityId":143,"username":"community_24","userNickname":"ASP","roleCode":1,"status":1,"createUsername":"","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002Fdefault.jpg!1","createTime":"2021-05-12 18:05:56","updateTime":"2021-05-12 18:05:56","lastLoginTime":"2021-05-12 18:05:56"},{"id":null,"communityId":143,"username":"sysdzw","userNickname":"无·法","roleCode":2,"status":1,"createUsername":"community_24","updateUsername":"","avatarUrl":"https:\u002F\u002Fprofile-avatar.csdnimg.cn\u002F45dcec50fd694b578374e7167ff7914a_sysdzw.jpg!1","createTime":"2021-06-16 19:25:33","updateTime":"2021-06-16 19:25:33","lastLoginTime":"2021-06-16 19:25:33"}],"communityConfig":{"scoreType":0,"scoreItems":{"0":"给本帖投票","1":"锋芒小试,眼前一亮","2":"潜力巨大,未来可期","3":"持续贡献,值得关注","4":"成绩优异,大力学习","5":"贡献巨大,全力支持"}},"shouldApply":false,"subscribeAble":false,"operatorAble":false,"commentNeedJoinCommunity":false},"default2014LiveRoom":[{"itemType":"","description":"高峰论坛","title":"2022 技术英雄会","url":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fiframe\u002Fcsdnnews\u002FfsNR5NWp?chat=1&title=1&footer=1","images":["https:\u002F\u002Fimg-home.csdnimg.cn\u002Fimages\u002F20221016050009.png"],"ext":{"time":"9:00","liveRoomUrl":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fcsdnnews\u002FfsNR5NWp"}}]},"isGooglebot":false,"canonical":"https:\u002F\u002Fwww.csdn.net\u002Ftopics\u002F392175119","openUrl":"","isApp":false,"localUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F392175119","typeId":"index","hasIndex":false},"CFG":{"ALIPLAYER_VERSION":"v4","ALIPLAYER_H5_VERSION":"mobile_v1","ENV":"prod","ROOT_URL":"https:\u002F\u002Fcms-mall.csdn.net\u002F","VUE_APP_API_URL_SERVER":"http:\u002F\u002Fcms-community-api.internal.csdn.net\u002F","VUE_APP_API_URL":"https:\u002F\u002Fcms-api.csdn.net\u002F","LOGIN_URL":"https:\u002F\u002Fpassport.csdn.net\u002Faccount\u002Flogin","VUE_APP_DOMAIN_SKILL":"https:\u002F\u002Fedu.csdn.net\u002F","VUE_APP_DOMAIN_PATH":"https:\u002F\u002Fedu.csdn.net\u002F","VUE_APP_COMMUNITY_API_URL":"https:\u002F\u002Fcommunity-api.csdn.net\u002F","VUE_APP_CCLOUD_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fcommunity-cloud\u002Fv1\u002F","VUE_APP_SKILL_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fskilltree\u002Fapi\u002F","VUE_APP_SEARCH_PLUGIN_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002Fsearchplugin\u002F","VUE_APP_COMMUNITY_ASK_API_URL":"https:\u002F\u002Fmp-ask.csdn.net\u002F","VUE_APP_ME_URL":"https:\u002F\u002Fme.csdn.net\u002F","VUE_APP_CCLOUD_RESUME":"https:\u002F\u002Fbizapi.csdn.net\u002Fjob-api\u002F","VUE_APP_CCLOUD_MAIN":"https:\u002F\u002Fwww.csdn.net\u002F","VUE_APP_CCLOUD_UC":"https:\u002F\u002Fwww.csdn.net\u002F","VUE_APP_CCLOUD_BZP_API_URL":"https:\u002F\u002Fbizapi.csdn.net\u002F","VUE_APP_CCLOUD_START_API_URL":"https:\u002F\u002Fmp-action.csdn.net\u002F","VUE_APP_PRACTIVE":"https:\u002F\u002Fbizapi.csdn.net\u002Fdaily-practice\u002F","VUE_APP_CCLOUD_HOSTPATH":"https:\u002F\u002Fbbs.csdn.net\u002F"},"queries":{"pageId":[],"domain":["ccloud.csdn.net\u002Fccloud\u002Fdetail1"],"id":["392175119"],"deviceType":"pc","isSpider":"","hostname":["bbs.csdn.net"]},"basePath":"bbs.csdn.net\u002Fccloud\u002Ftopics\u002F392175119","hrefUrl":"https:\u002F\u002Fbbs.csdn.net\u002Ftopics\u002F392175119","active":0,"navBarFixed":false,"title":"asp+js做的动态添加数据行,为何数据表会自动多添加一空白行","isLive":false,"contentType":{"text":"text","picture":"picture","link":"link","video":"video","vote":"vote","live":"live","blog":"blog","long_text":"long_text","task_text":"task_text"},"liveUrl":"https:\u002F\u002Flive.csdn.net\u002Froom\u002Fiframe\u002F","spmExtra":{"id":143,"topicId":392175119},"keywords":"","description":"以下内容是CSDN社区关于asp+js做的动态添加数据行,为何数据表会自动多添加一空白行相关内容,如果想了解更多关于ASP社区其他内容,请访问CSDN社区。"};</script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/runtime.3e5c09eb.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/common.7672e502.js"></script><script type="text/javascript" src="https://csdnimg.cn/release/cmsfe/public/js/chunk/tpl/ccloud-detail/index.243a94d0.js"></script></body> <!----> <script> window.csdn.sideToolbar = { options: { qr: { isShow: true, data: [ { imgSrc: 'https://csdnimg.cn/release/cmsfe/public/img/ewm.9010d6e5.png', desc: "关注公众号" }, ] }, help: { isShow: false, }, contentEl: document.getElementsByClassName("cloud-maintainer")[0] }, }; </script> <script src="https://g.csdnimg.cn/side-toolbar/2.9/side-toolbar.js" ></script> <!----> <!----> <!----> <script src="https://csdnimg.cn/release/blog_editor_html/release1.7.5/ckeditor/plugins/codesnippet/lib/highlight/highlight.pack.js"></script> <script src="https://g.csdnimg.cn/lib/editor-page-detail/v2.2.0/js/runDetail.min.js"></script> <!----> <!----> <!----> <!----> <!----> <!----> <script src="https://g.csdnimg.cn/collection-box/2.1.0/collection-box.js"></script> <!----> <!----> <!----> <!----> <script src="https://g.csdnimg.cn/common/csdn-cert/csdn-cert.js"></script> <!----></html>