WPS JSA 宏編程(JS):7.用戶窗體


一、與 VBA 窗體的差異

WPS JSA 也提供了用戶窗體,用戶也可以通過拖控件的方式,制作自己的對話框,以完成宏編程中的交互任務。

但它與 VBA 中的用戶窗體有很大的不同:

  1. 界面與事件邏輯分離,界面元素的繪制是一個模塊,事件邏輯放在之外的模塊,不是嵌入到窗體界面模塊的。
  2. 界面元素的 Name 屬性不可修改,屬性編輯器中也不提供這個屬性。雖然在官方文檔上說的是支持修改,但從 JSA 事件訂閱入口,即可知道,Name 屬性可能在以后的升級版本中也無法修改,因為它的名稱不變,才能方便事件訂閱,也就是事件訂閱機制鎖死了這方面的改進的可能性。
  1. 界面對象繪制完成后,它是一個實例,不是一個類型,不允許使用 new 語句,來構造它的新實例
  2. 只有頂級容器,也就是窗體本身有 Controls 成員,且它是一個方法,不是集合,它只接受字符串的 Name 參數,不接受 Index 參數,且 Name 參數不可省,無法直接得到整個子控件集合
  1. 因為無法得到整個子控件集合,也就無法對它進行動態的添加控件
  2. 控件元素都有 Move(Left, Top, Width, Height) 方法,竊以為拆分成 Move(Left, Top)Resize(Width, Height),更符合邏輯
  1. 再沒有 Load/Unload 了,都是 Show()/Hide() 方法,這很好,這是面向對象的。
  2. 新增了 HLayout/VLayout/HSpacer/VSpacer 控件,用來協助布局控件,有了它們你可以更方便地拖控件了

 

二、吐槽

  1. 相較於 VBA 的用戶窗體,JSA 的用戶窗體太死板了,主要體現在:
    1. 不能對控件集合,動態增刪新控件,動態性太差,想要玩兒點花活兒,比如按需求動態生成界面,是不可能的。當然,就這一點而言,因為這只是初版,也許以后升級可以支持這個,這本身也不會破壞現有的規則。只需要在不給 Controls(Name) 傳遞參數時,返回整個控件集合就好,這樣就可以在這個集合上進行動態增刪控件了。也即只需要增量改進即可,其它容器控件添加上 Controls(Name) 方法,也不是難事兒。
    2. 修改控件元素的 Name 是無效的,簡單的界面還好,控件多了,分組多了,很容易亂套
    1. 創建的窗體界面,它不是一個類型,而是一個實例,不允許new 出新實例,這一點都不面向對象
  1. ZOrder 或者BringToFront()/SendToBack(),都不支持,控件堆疊是不可能的了
  2. CommandButton 的類型實際上是 PushButton,連官方文檔上都是 CommandButton,這叫用戶如何是從啊。而且直接訪問這個 PushButton 也是不存在的,而且 CommandButton 也不存在

 

三、總結

基於以上了解,JSA 的用戶窗體,還非常初級,死板而孱弱,功能也不健全。直接用基於網頁的 HTA 都要比它強。

還不如直接在文檔中使用代碼繪制控件,用這種方式封裝出一個庫,也比現在這個要強,要好用。

渣渣渣。。。也就將將滿足可用,遠遠談不上強大,更沒有任何靈活性。

希望官方推倒重來,這套界面,無論是類型系統,還是窗體模塊的組織形式,事件的訂閱機制,整個都太差勁了,遠古 UI 也比這個健全、強大吧。

.NET WinForm 風格的 UI 就很不錯,既靈活,又強大。建議用這套風格實現一套 UI。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM