日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Coolite Toolkit学习笔记九:表单布局控件FormLayout与FromPanel

發(fā)布時(shí)間:2025/4/16 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Coolite Toolkit学习笔记九:表单布局控件FormLayout与FromPanel 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?????FormLayout在我們平時(shí)開發(fā)中使用頻率非常高,使用它可快速、方便的實(shí)現(xiàn)表單界面布局,以及使用一些其他控件自身的特性組合起來實(shí)現(xiàn)豐富強(qiáng)大的UI界面。下面通過一個(gè)簡單示例來體驗(yàn)FormLayout的強(qiáng)大功能。

<ext:Panel?ID="Panel1"?runat="server"?Title="用戶登錄"?Width="300"?BodyStyle="padding:5px;"?>
????
<Body>
????????
<ext:FormLayout?ID="FormLayout1"?runat="server"?Width="150"?>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:TextField?ID="tfUserName"?runat="server"?FieldLabel="用戶名"?/>
????????????
</ext:Anchor>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:TextField?ID="tfPassword"?runat="server"?FieldLabel="用戶密碼"?/>
????????????
</ext:Anchor>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:Button?ID="btnLogin"?runat="server"?Text="登錄"/>
????????????
</ext:Anchor>
????????
</ext:FormLayout>
????
</Body>
</ext:Panel>


??????Coolite Toolkit規(guī)定FromLayout控件必須放置在一個(gè)容器控件里,如上則將其放置在Panel控件里,通過FormLayout布局了一個(gè)用戶登錄界面,運(yùn)行效果如下所示:

??????????????????

??????如上只是實(shí)現(xiàn)了最基本的界面布局,而且效果并不是很理想。OK,下面基于這個(gè)上面來做一些調(diào)整?,F(xiàn)在要實(shí)現(xiàn)文本框沒有輸入數(shù)據(jù)的時(shí)候則提示用戶輸入,并為其加上非空驗(yàn)證,通過AjaxEvents提供表單提交的事件處理函數(shù),通過Listeners提供表單的提交前的客戶端驗(yàn)證功能。相關(guān)代碼如下:

????<Body>
????????
<ext:FormLayout?ID="FormLayout1"?runat="server"?Width="150"?>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:TextField?ID="tfUserName"?runat="server"?
????????????????FieldLabel
="用戶名"?
????????????????EmptyText
="請輸入用戶名"
????????????????AllowBlank
="false"??
????????????????BlankText
="用戶名不能為空!"/>
????????????
</ext:Anchor>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:TextField?ID="tfPassword"?runat="server"?
????????????????FieldLabel
="用戶密碼"?
????????????????EmptyText
="請輸入登錄密碼"
????????????????InputType
="Password"??
????????????????AllowBlank
="false"?
????????????????BlankText
="用戶密碼不能為空!"/>
????????????
</ext:Anchor>
????????
</ext:FormLayout>
????
</Body>
????
<Buttons>
????????
<ext:Button?ID="btnLogin"?Text="登錄"?runat="server"?Icon="Accept">
????????????
<AjaxEvents>
????????????????
<Click?OnEvent="LoginClick">
????????????????????
<EventMask?ShowMask="true"?Msg="正在登錄系統(tǒng)"?MinDelay="500"?/>
????????????????
</Click>
????????????
</AjaxEvents>
????????????
<Listeners>
????????????????
<Click?Handler="if(!#{tfUserName}.validate()?||?!#{tfPassword}.validate())?{
????????????????????Ext.Msg.alert('錯(cuò)誤提示','用戶名和用戶密碼不能為空!');
????????????????????return?false;?
????????????????}"
?/>
????????????
</Listeners>
????????
</ext:Button>
????????
<ext:Button?ID="btnCancel"?Text="清空"?runat="server"?Icon="Cancel">
????????????
<AjaxEvents>
????????????????
<Click?OnEvent="CancelClick"/>
????????????
</AjaxEvents>
????????
</ext:Button>
????
</Buttons>
</ext:Panel>


??????

??????仔細(xì)看來FormLayout?控件使用是非常簡單的,表單里面具體要設(shè)計(jì)為什么樣子的,最終還得看使用的其他相關(guān)控件。在前面提到FormLayout控件需要放置在一個(gè)容器內(nèi)部,其實(shí)Coolite Toolkit專們?yōu)镕romLayout控件提供了一個(gè)容器控件FromPanel于之搭配,其使用方法和Panel基本相同,通過FromPanel+FromLayout組合設(shè)計(jì)出來的UI界面效果更佳。如下郵件發(fā)送表單示例:

<ext:FormPanel?ID="FormPanel1"?runat="server"?BodyStyle="padding:5px;"?ButtonAlign="Right"
????Frame
="true"?Title="郵件發(fā)送表單"?Width="450">
????
<Body>
????????
<ext:FormLayout?ID="FormLayout2"?runat="server"?LabelWidth="60">
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:TextField?ID="tfTitle"?runat="server"?FieldLabel="郵件主題"?
????????????????????AllowBlank
="false"?BlankText="郵件主題不能為空"/>
????????????
</ext:Anchor>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:TextArea?ID="tfContent"?runat="server"?FieldLabel="郵件內(nèi)容"?Height="150"/>
????????????
</ext:Anchor>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:FileUploadField?ID="upAttachment"?runat="server"?FieldLabel="郵件附件"?
????????????????????ButtonText
="選擇附件"?/>
????????????
</ext:Anchor>
????????????
<ext:Anchor?Horizontal="100%">
????????????????
<ext:DateField?ID="tfTime"?runat="server"?FieldLabel="發(fā)送時(shí)間"/>
????????????
</ext:Anchor>
????????
</ext:FormLayout>
????
</Body>
????
<Buttons>
????????
<ext:Button?ID="btnSend"?runat="server"?Icon="WorldGo"?Text="發(fā)送"?>
????????????
<AjaxEvents>
????????????????
<Click?OnEvent="SendClick"?/>
????????????
</AjaxEvents>
????????
</ext:Button>
????
</Buttons>
</ext:FormPanel>

??????????????????

?????
??????需要注意的就是FormLayout?的LabelWidth屬性,很多新手朋友在學(xué)習(xí)Coolite Toolkit的FromLayout的時(shí)候,都遇到字段名和TextBox中間存在很長的距離怎么也調(diào)不了,其實(shí)這個(gè)距離是可以調(diào)整的,通過設(shè)置LabelWidth屬性值既可。


注:此文章轉(zhuǎn)載至Bēniaǒ成長筆記

總結(jié)

以上是生活随笔為你收集整理的Coolite Toolkit学习笔记九:表单布局控件FormLayout与FromPanel的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。