前言 :
在程序開發中最常見也最常用的組件就是信息提示框了, 在 Web 頁面中 alert() 可以用來向用戶提示各種信息. 但其單調的介面卻不足以滿足用戶挑剔的目光. ExtJS 提供了一系列美觀實用的信息提示組件, 現在來看看它們如何配置與使用.
認識 Ext.MessageBox :
Ext.MessageBox 是一個工具類, 它繼承自 Object 對像, 用來生成各種風格的信息提示對話框. Ext.Msg 是該類別的別名, 使用 Ext.MessageBox 和使用 Ext.Msg 有相同效果. 在介紹前先來了解一下 Ext.MessageBox 提供的信息提示框與 JavaScript 提供的原始信息提示框的差別. 主要比較三個方面 : 實作方式, 顯示信息的格式和對程序運行的影響. 下面針對這三方面進行說明.
- 實現方式
標準 JavaScript 提供的信息對話框是一個真正的彈出視窗. Ext.MessageBox 提供的信息提示對話框並不是真正的彈出窗口, 它只是當前頁面的一個層 (div), 所以無法用窗口捕抓軟件來得到它.
- 顯示信息的格式
標準 JavaScript 提供的信息提示框中所顯示的內容不是 HTML 而是純文本. 不能使用 HTML 中的格式方法進行排版, 只能以空格回車與各種符號來建構顯示格式. Ext.MessageBox 提供的信息提示框顯示的文本不僅支持純文本顯示, 也能使用 HTML 進行排版, 效果更加多樣化. 下面是一個簡單比較範例 :
在上面代碼我們可以看到 HTML 標籤在 ExtJS 的 alert() 產生了效果, 控制了顯示樣式. 底下為兩個樣式的比較 :
- 對程序運行的影響
標準 JavaScript 提供的訊息提示框會對 JavaScript 程序的運行產生阻塞效果. 但是 Ext.MessageBox 是異步的, 因此它的調用並不會停止瀏覽器中代碼的執行. 參考下面代碼可以發現在 Ext.MessageBox 的提示框出現後, 標準的 提示框還是能出現, 到是如果顛倒顯示的順序, 將只看到標準的提示框 (因為 Ext.MessageBox 被阻塞) :
執行結果 :
Ext.MessageBox.alert() :
一個訊息提示框可以提供一個回調函數, 該函數將在單擊"確定"按鈕後被調用 (包括右上角的退出按鈕), 而所單擊按鈕的 id 將被作為唯一的參數傳遞到回調函數中.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
Ext.MessageBox.confirm() :
顯示一個確認訊息框, 用來替代 JavaScript 標準 confirm() 方法. 具有兩個按鈕 "是" 與 "否", 如果為其提供一個回調函數, 則該函數將在點擊按鈕後被調用 (包括右上角的退出按鈕), 所單擊按鈕的 id 將被做為唯一參數傳遞到回調函數中.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
執行結果 :
Ext.MessageBox.prompt() :
顯示一個獲取用戶輸入訊息的提示框, 用來替代 JavaScript 標準的 prompt() 方法, 有兩個按鈕 "確定" 與 "取消". 並提供文本輸入框接收用戶輸入, 如果提供一個回調函數, 則該函數將在按鈕點擊後被調用, 點擊按鈕的 id 將是回調函數的傳入參數.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
執行結果 :
Ext.MessageBox.wait() :
顯示一個自動翻滾的進度條提示框. 它經常被用在一個耗時的交互操作中, 它不能定義一個時間間隔自動關閉, 程序員有責任在交互操作完成後關閉它.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
執行結果 :
Ext.MessageBox.show() :
用於配置來顯示信的訊息提示框或重置一個已經存在的訊息提示框, 前面介紹的 3 種提示框內部調用的都是這個方法. 儘管調用快捷, 但是它們並不支持所有的配置項, 要建立更加個性化, 功能更強大的提示框還需要從掌握 Ext.MessageBox.show() 方法做起.
Ext.MessageBox.show 方法支持的配置項非常豐富, 不但可以配置提示標題, 提示訊息, 回調函數等常見部分, 它還提供了配置按鈕文字及提示圖標等方法, 給我們控制訊息提示框的各種可能性. 下面將分別給出這些配置項並分為 2 個列表來說明.
表 3-1 主要包括常用配置項, 這裡並沒有包括所有的可配置項, 更多可參考線上API Ext.MessageBox Config Options 說明 :
表3-2 列舉了配置項 buttons 可選的各種常見值, 這些值決定提示框按鈕顯示方式 :
下面對 Ext.MessageBox.show 使用進行簡單說明.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
執行結果 :
Ext.MessageBox 的其他功能 :
到此已經介紹了 Ext.MessageBox 類的主要功能. 這些功能可以滿足大部分需求, 而 Ext.MessageBox 提供的功能還不止這些, 它還提供靈活客置能力. 包括改變默認的按鈕文字, 動態更新提示框, 下面將針對這兩個部分進行介紹.
1. 改變默認的按鈕文字
通過 Ext.Msg.YESNOCANCEL 等配置對像創建的按鈕文字不滿足需求, 該如何改變它呢? Ext.MessageBox 提供了 buttonText 配置項, 通過提供配置對像, 就能改變默認的按鈕文字. 為 buttonText 配置賦值有兩種方式, 都可以達到修改默認按鈕文字的目的, 下面範例代碼進行說明 :
執行結果 :
注意 :
第二個方法不用把 buttonText 的默認配置對像替換掉, 而只要改變某個屬性就可以, 參考範例代碼如下 :
執行結果 :
2. 動態更新提示框
下面我們來看看如何動態變更提示框的文字內容.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
執行結果 :
3. 更新進度條及提示訊息
在前一個範例代碼週期性地調用 updateText 方法, 它將最新的系統時間更新到信息提示框中, 在實際的應用中可以用來動態顯示程序的執行狀態. 下面說明如何透過 updateProgress() 動態更新提示框上面的進度條.
調用格式 :
參數說明 :
返回值 :
範例代碼 :
執行結果 :
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 /...
沒有留言:
張貼留言