App下載

Ext JS 6有什么新東西?

猿友 2020-12-31 16:17:48 瀏覽數 (2377)
反饋

工具包(ToolKits)

Ext JS 6最大的變化就是將 Ext JS 和 Touch 合并為一個單一的框架。之前的框架的核心(數據、控制器、模型等等)已被調和為一個單一的公共平臺。這樣,數據和邏輯就可以同享,從而幫助開發(fā)人員進一步去優(yōu)化他們的利用程序。

那些具有獨特功能的東西將會被分解為兩個絕然不同的兩個工具包:古典(Classic)和現代(Modern)。這些工具包通過 Ext JS 和Touch 的視圖層來進行劃分的。那些同享核心資源和邏輯,并使用這兩種工具包的利用程序被稱為通用(Universal)利用程序。

在使用 Cmd 生成利用程序的時候,需要選擇利用程序的工具包,這個可通過簡單調劑利用程序的 app.json 來實現,以下所示:

"toolkit": "classic", // or "modern"

發(fā)布

由于框架結合為了單一實體,SDK 的結構不能不根據 classic、modern 和 common 這3個區(qū)域進行重組。

微信截圖_20201231104617

一樣,生成和示例文件夾也包括 classic 和 modern 這兩個子目錄:

微信截圖_20201231104630

微信截圖_20201231104635

ext-all.js 這個文件在 build 文件夾中仍然存在。而 ext-modern.js 就相當于使用 sencha-touch.js。二者使用的是共同的核心。

在當前版本中,示例 kitchensink 就是所謂的通用利用程序,一個單一的結合了經典和現代兩個生成配置的利用程序。

包的命名

對各種不同包中的前綴“ext-”和“sencha-”已被刪除。這些前綴當初主要是用來辨別 Sencha Touch、Ext JS 和公共庫的。而現在,他們不再需要進行這類辨別了,所有這些代碼都已包括到了 Ext JS 中。這意味著“sencha-charts”現在應為“charts”,而“ext-theme-neptune”則為“theme-neptune”。

正如你所想的哪樣,要從 Ext JS 5 升級到 Ext JS 6,就需要在 app.json 文件中調劑包的援用名稱。

Fashion

Fashion 是 Sencha 推出的新的 SASS 編譯器,用于創(chuàng)建利用程序主題。它是使用 Javascript 編寫的,可在閱讀器中運行。結合PhantomJS 后,在 Sencha Cmd 中使用 Fashion 來創(chuàng)建 SASS 比 app watch 要好。這意味著 Ruby 不再是系統(tǒng)所需的!由于 Fashion 是運行在閱讀器的,因此能將 SASS 的構建減少到兩次(一次是進行切片(slicer),一次是最小化所需內容)。更重要的是,可以通過 app watch 迅速的以增量方式重建 SASS,這給開發(fā)人員帶來了實實在在的好處。

對 app watch,使用Fashion還有一個更大的好處:在線更新!在(現代)閱讀器中打開有一個利用程序并加載SASS文件來代替生成的CSS。Fashion 不必刷新頁面便可更改并編譯 SASS,并更新 CSS。

如果要啟用在西安更新,可將“?platformTags=fashion:true”添加到 URL。

由于不再使用 Ruby,因此依賴 Ruby 代碼的 Compass 功能將不能再使用。這就不能不使用 JavaScript 來創(chuàng)建。我們將會盡快編寫如作甚 Fashion 編寫自定義 JavaScript 擴大的文檔。有一些 Compass 中的SASS代碼已遷移到了 Fashion,因此其實不是所有的Compass 功能都會遭到利用??偟膩碇v,如果不使用自定義的 Compass 功能,就不會體會到之間的差別。

重要的是,在線更新只有在頁面視圖是運行在 Cmd Web server 的時候才會工作。在 Ext JS 的 classic 工具包中,一些 Sass 的修改可能需要一個布局或全部頁面重新加載。對 modern 工具包來講,很少會有這樣的問題,由于它很大程度上是基于 CSS 的,且更能適應積極的變化。

圖表

圖表包中最大的變化是在 3D餅圖中,它現在支持標簽和可配置的 3D方面。在圖表 kitchensink 中可以查看到這些示例。

微信截圖_20201231104646

ItemEdit插件

另外一個最大最新的功能是itemEdit插件,它運行用戶通過拖動標記去修改圖表值??赏ㄟ^查看Kitchen Sink中Scatter Chart的自定義圖標示例來查看itemEdit插件的行動。

微信截圖_20201231104652

序列標簽、條碼和提示信息的 renderer 現在支持通過 ViewController 的方法來命名(聲明式渲染)。軸標簽的 renderer 也行將到來。

值得注意的是,Ext JS 6 已拋棄舊的 ext-charts 包。任何使用 ext-charts 的都需要重構利用程序以使用 sencha-charts 包。

網格
電子表格

在 Ext JS 5.1 中引入的電子表格模型現在有了一些使人驚嘆的新功能。選擇現在可通過設置 extensible 為 true 來設置為可擴大的,這樣,便可拖動右下角的拖動角唆使器來添加選擇,從而對當前所選內容沿垂直方向或水平方向進行擴大。

微信截圖_20201231104539


這通常會結合使用當前選擇的插件來復制值到擴大區(qū)域,就像在一個典型的電子表格中所期望的哪樣。

可操作模式(Actionable Mode)和可訪問性

網格還支持ARIA的“可操作模式”,該模式是原始單元格編輯模式的延伸。這將允許所有類型的單元格內容能夠通過鍵盤獲得焦點或激活。這是對可訪問性的巨大進步,這對超級用戶來講,就能夠無需鼠標就可以導航到網格中的任何地方。

LazyItems插件

該插件可延遲子組件的渲染,直到顯現的時候再進行渲染,從而下降子組件的實例化和初始化的履行本錢。

例如,在標簽面板中設置 deferredRender 為 true,未顯現的標簽就不會對它的后代組件進行實例化和初始化,從而減少開消,直到標簽被激活的時候才會進行渲染。

屏幕瀏覽器支持(可訪問性)

ARIA 功能已直接到了組件的生命周期,這意味著不再需要指定 aria 包來獲得正確的 ARIA 行動了。利用程序現在支持屏幕瀏覽器(類似JAWS)而無需指定援用。

微加載(Microloader)

Sencha Cmd 6現在資源方面包括了本地存儲緩存,這類似于 Sencha Touch 的產品的微加載。雖然如此,還是有一些重要的改進:

緩存能在 app.json 中禁用

只有通過微加載方式加載的內容才不會被刪除

只有利用程序確當前版本才可保持在本地存儲

這些改進解決了當前 Touch 微加載所報告的問題。主要的是,它會在超越空間的時候積極的刪除本地存儲的內容。這問題經常產生是由于保存了沒必要要的舊版本利用程序,這讓完全刪除成為終究選擇。

Touch網格

Touch 網格不再是一個獨立的 Cmd 包,它現在已默許成為 modern 工具包的一部份。

ES6 的知識點還等待你的學習:


0 人點贊