前言 :
表單在 Web 應用在於收集用戶訊息並與用戶進行交互溝通, 並將收集到的訊息提交到後台服務器. 也就是說表單是客戶端與服務器之間溝通的橋梁.
傳統的表單形式單一, 無法複雜操作 (如數據驗證, 錯誤提示等), 並且無法滿足豐富的客戶端要求. 而 ExtJS 表單及其表單組件很好的改善這種情況而形成一系列美觀的 ExtJS 表單組件, 通過這些組件不但可以實現原本 HTML 標準表單的全部功能還可以使用大量的擴展特性 :
了解 Ext.form.BasicForm 基本表單 :
Ext.form.BasicForm 是基本的表單組件, 提供表單動作的支持並負責初始化已有的字段組件. 默認情況下表單採用 Ajax 方式進行異步數據提交, 如果要使用原始提交方式可以覆蓋表單的 onSubmit() 及 Submit() 方法. 在 ExtJS 文檔中給出標準實現, 代碼如下 :
上述代碼中介紹直接操作底層表單的做法. 在 表4-1 和 表4-2 分別列出 Ext.form.BasicForm 的主要配置項及常用方法, 這些配置項和方法基本上包含常見的表單操作, 掌握他們即掌握表單的基礎.
表 4-1 中列舉了 Ext.form.BasicForm 配置項, 這些配置項被繼承到 Ext.form.FormPanel 中, 在 FormPanel 中可以直接使用這些配置項.
表 4-2 列舉主要的 Ext.form.BasicForm 方法, 這些方法被繼承到 Ext.form.FormPanel 中, 在 FormPanel 中可以直接使用. 到這裡已經對基本表單組件有初步認識, 在開發過程中並不會直接使用 BasicForm 組件, 而是使用他的子類 - 表單面板組件 FormPanel, 該組件繼承 BasicForm 組件全部屬性與方法.
認識 Ext.form.FormPanel 表單面板 :
現在要介紹 ExtJS 的表單面板組件 Ext.form.FormPanel. 它擴展自 Ext.Panel (面板) 組件, 是表單項的容器, 它可以接受所有在 Ext.form.BasicForm 中出現的配置項. Ext.form.FormPanel 和 HTML 原始表單不僅表現形式不同, 對表單的操作及處理也並不相同, 這些不同表現在表單的提交方式, 表單驗證與對表單組件支持 3 個方面, 下面針對這三方面進行說明.
1. 表單提交方式
2. 對表單驗證的支持
3. 對表單組件的支持
Ext.form.Field 表單字段 :
Ext.form.Field 是表單字段的基類, 它擴展自 Ext.BoxComponent, 主要提供對表單字段一般功能的支持, 其他表單字段都需要從 Ext.form.Field 類別進行擴展, 如 Ext.form.TextField, Ext.form.Checkbox 等. 下表列出了 Ext.form.Field 的主要配置與常用方法 :
在下面例子中使用 Ext.form.TextField 組件與 Ext.form.NumberField 組件, 這兩個組件的詳細用法會在後續章節介紹. 這裡要示範不同位置的提示訊息 :
執行結果 (分別使用 'qtip', 'title', 'under' 與 'side') :
由上面介紹可以選擇適合自己的顯示訊息方式, 但是要注意使用 'under' 時容易發生表單高度固定導致不足以容納下移的表單字段 (多了提示訊息), 使得部分字段無法正常顯示. 或是使用 'side' 但是表單寬度過小導致字段右側錯誤訊息無法正常顯示. 如此可以自己調適表單的高度或寬度來解決問題.
另外如果你要一次性指定所有的表單提示訊息方式, 可以在 Ext.QuickTips.init(); 的下一句寫入下面一行就可以統一指定表單字段的錯誤訊息 :
This is a blog to track what I had learned and share knowledge with all who can take advantage of them
標籤
- [ 英文學習 ]
- [ 計算機概論 ]
- [ 深入雲計算 ]
- [ 雜七雜八 ]
- [ Algorithm in Java ]
- [ Data Structures with Java ]
- [ IR Class ]
- [ Java 文章收集 ]
- [ Java 代碼範本 ]
- [ Java 套件 ]
- [ JVM 應用 ]
- [ LFD Note ]
- [ MangoDB ]
- [ Math CC ]
- [ MongoDB ]
- [ MySQL 小學堂 ]
- [ Python 考題 ]
- [ Python 常見問題 ]
- [ Python 範例代碼 ]
- [心得扎記]
- [網路教學]
- [C 常見考題]
- [C 範例代碼]
- [C/C++ 範例代碼]
- [Intro Alg]
- [Java 代碼範本]
- [Java 套件]
- [Linux 小技巧]
- [Linux 小學堂]
- [Linux 命令]
- [ML In Action]
- [ML]
- [MLP]
- [Postgres]
- [Python 學習筆記]
- [Quick Python]
- [Software Engineering]
- [The python tutorial]
- 工具收集
- 設計模式
- 資料結構
- ActiveMQ In Action
- AI
- Algorithm
- Android
- Ansible
- AWS
- Big Data 研究
- C/C++
- C++
- CCDH
- CI/CD
- Coursera
- Database
- DB
- Design Pattern
- Device Driver Programming
- Docker
- Docker 工具
- Docker Practice
- Eclipse
- English Writing
- ExtJS 3.x
- FP
- Fraud Prevention
- FreeBSD
- GCC
- Git
- Git Pro
- GNU
- Golang
- Gradle
- Groovy
- Hadoop
- Hadoop. Hadoop Ecosystem
- Java
- Java Framework
- Java UI
- JavaIDE
- JavaScript
- Jenkins
- JFreeChart
- Kaggle
- Kali/Metasploit
- Keras
- KVM
- Learn Spark
- LeetCode
- Linux
- Lucene
- Math
- ML
- ML Udemy
- Mockito
- MPI
- Nachos
- Network
- NLP
- node js
- OO
- OpenCL
- OpenMP
- OSC
- OSGi
- Pandas
- Perl
- PostgreSQL
- Py DS
- Python
- Python 自製工具
- Python Std Library
- Python tools
- QEMU
- R
- Real Python
- RIA
- RTC
- Ruby
- Ruby Packages
- Scala
- ScalaIA
- SQLAlchemy
- TensorFlow
- Tools
- UML
- Unix
- Verilog
- Vmware
- Windows 技巧
- wxPython
訂閱:
張貼留言 (Atom)
[Git 常見問題] error: The following untracked working tree files would be overwritten by merge
Source From Here 方案1: // x -----删除忽略文件已经对 git 来说不识别的文件 // d -----删除未被添加到 git 的路径中的文件 // f -----强制运行 # git clean -d -fx 方案2: 今天在服务器上 gi...
-
前言 : 為什麼程序管理這麼重要呢?這是因為: * 首先,本章一開始就談到的,我們在操作系統時的各項工作其實都是經過某個 PID 來達成的 (包括你的 bash 環境), 因此,能不能進行某項工作,就與該程序的權限有關了。 * 再來,如果您的 Linux 系統是個...
-
屬性 : 系統相關 - 檔案與目錄 語法 : du [參數] [檔案] 參數 | 功能 -a | 顯示目錄中個別檔案的大小 -b | 以bytes為單位顯示 -c | 顯示個別檔案大小與總和 -D | 顯示符號鏈結的來源檔大小 -h | Hum...
-
來源自 這裡 說明 : split 是 Perl 中非常有用的函式之一,它可以將一個字串分割並將之置於陣列中。若無特別的指定,該函式亦使用 RE 與 $_ 變數 語法 : * split /PATTERN/,EXPR,LIMIT * split /...
沒有留言:
張貼留言