![](https://www.a-assist.co.jp/wp-content/uploads/2023/07/POST_0024_01.jpg)
#検証 : グローバルイベントについて
2021年04月26日
こんにちは、鎌倉です。
早速ですが、
グローバルイベントを使用したことはありますか。
グローバルイベントは、Genexus15以降で使用できるようになった比較的新しい機能で
RootModule配下のGeneXus フォルダの中のCommon 内に用意されています。
![](/wp-content/uploads/2023/07/POST_0024_02-1024x287.png)
グローバルイベントは、
通常のイベントとは異なりすべてのコンポーネントに有効なイベントで 、
下記のオブジェクトに定義することで、
自由に任意のコンポーネントからイベントを呼び出すことができる便利な機能です。
![](/wp-content/uploads/2023/07/POST_0024_03-1024x430.png)
※参考リンク:グローバルイベント
そこで今回の記事では、
グローバルイベントはどこまでの範囲が有効なのか疑問に思ったので
検証した内容をご紹介したいと思います。
検証
![](/wp-content/uploads/2023/07/POST_0024_04-1024x149.png)
①検証準備
まずそれぞれのオブジェクトに画像のように定義を行いました。
■グローバルイベント
イベントを追加します。
今回は引数にメッセージ内容を持たせたいのでvarcharにしました。
![](/wp-content/uploads/2023/07/POST_0024_05.png)
■WebPanel
同じWebCompornentが配置してあるWebPanelを2つ作成し、
グローバルイベントが発生するとメッセージが表示されるようにします。
![](/wp-content/uploads/2023/07/POST_0024_06-1024x549.png)
![](/wp-content/uploads/2023/07/POST_0024_07-1024x549.png)
■WebCompornent
WebCompornent内のボタンを押下すると、グローバルイベントが呼び出されるように定義を行います。
![](/wp-content/uploads/2023/07/POST_0024_08-1024x549.png)
②検証実行
プラウザに画面Aと画面Bを別タブで表示させます。
![](/wp-content/uploads/2023/07/POST_0024_09-1024x853.png)
次に、A画面のボタンを押下し
メッセージが表示されるのか各ページを確認します。
A画面↓
![](/wp-content/uploads/2023/07/POST_0024_10-1024x858.png)
B画面↓
![](/wp-content/uploads/2023/07/POST_0024_11-1024x860.png)
③検証結果
![](/wp-content/uploads/2023/07/POST_0024_12-1024x176.png)
稼働しているアプリケーション全体に効果を及ぼすものではなく
Webページ(タブ内)でのみ有効であることがわかりました。
複数同じ画面を開いていても、影響なく動作させることが出来そうですね。
では、アプリケーション全体を有効とすることが出来る機能はあるのでしょうか。
続いての記事では、アプリケーション全体を有効とすることができる
Server.Socket 外部オブジェクトを使用して実装方法や検証内容を紹介したいと思います。
最後までお読みいただきありがとうございました。