WO2016059677A1 - Webサーバシステム - Google Patents
Webサーバシステム Download PDFInfo
- Publication number
- WO2016059677A1 WO2016059677A1 PCT/JP2014/077363 JP2014077363W WO2016059677A1 WO 2016059677 A1 WO2016059677 A1 WO 2016059677A1 JP 2014077363 W JP2014077363 W JP 2014077363W WO 2016059677 A1 WO2016059677 A1 WO 2016059677A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- layout
- screen
- component
- template
- components
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
Definitions
- the present invention relates to a web application development technology, and in particular to a technology that is effective when applied to a web server system that executes a web application that performs screen display compatible with multiple devices.
- multi-device it is effective to promote the use of common parts and general-purpose parts in development products such as source code, and reuse of parts in development. Furthermore, it is also effective to reduce individual development parts for each device or platform by performing multi-device or multi-platform (which may be simply referred to as "multi-device” in the following).
- Patent Document 1 has a user interface including the appearance and attributes of a control for displaying input / output items, control processing, and the like according to the device.
- a web server system that changes dynamically without changing source code is described.
- the system includes, for example, a device acquisition unit that acquires information related to the type of device of the client terminal based on a request from the client terminal, and a client terminal acquired by the device acquisition unit for a part object included in the source code.
- a response that generates HTML data to display the corresponding control on the screen of the client terminal, based on the adjustment content when displaying the control, implemented in the upper class of the inheritance source of the part object according to the type of device
- a processing unit is described.
- parts can be reused in developing a Web application, and multi-device compatibility can be achieved with one source code. Become.
- the screen size of a smartphone is smaller than that of a PC (Personal Computer) or a tablet terminal, and the amount of information that can be displayed is restricted. Therefore, for example, while displaying a list of menus and the like in a state in which all are always expanded on one screen on a PC or a tablet terminal, in the case of a smartphone, usually only icons etc. for instructing menu display are displayed. In some cases, an interface may be adopted in which a menu list is displayed as a separate screen when menu display is instructed via the icon or the like. In the prior art, it is difficult to be able to correspond to each pattern with one source code in these cases.
- a web server system executes a business logic in response to a request from a client terminal, and responds with a processing result screen according to a type of a device of the client terminal. It has the following features.
- the Web server system comprises a combination of one or more screen parts, and a component having a first template that defines the appearance when each screen part is displayed on each screen of the device, and the process A layout having a second template that defines an arrangement pattern of one or more areas in which the component is arranged on the result screen, and the appearance when each area is displayed on the screen is defined for each type of device; Have.
- the layout to be applied to the processing result screen and the component to be arranged in the layout are acquired, and data obtained by execution of the business logic is set for the acquired component, and the acquired layout is An edit view is positioned to be arranged in the predetermined area.
- the process is performed according to an appearance defined by the second template and the first template corresponding to the type of the device of the client terminal. It has a component view that creates a result screen.
- a screen transition may be involved.
- FIG. 7 is a diagram showing an outline of an example of a designated content in an edit view according to an embodiment of the present invention and an exemplary flow of processing when displaying a screen according to the content.
- FIG. 1 is a diagram showing an outline of a configuration example of a Web server system according to an embodiment of the present invention.
- the Web server system 100 according to an embodiment of the present invention has a screen part as a component and has a list of the components 190, and the layout 180 as a layout pattern including one or more screen areas in which the components 190 are arranged. I have a list.
- Each layout 180 and each component 190 respectively have a template created so as to output an optimized screen for each device, and the Web server system 100 is optimized for each device based on these. Automaticized screen output.
- the web server system 100 is, for example, a server system composed of a server device and a virtual server built on a cloud computing service, and, for example, an operating system (OS) (not shown), a web server program 110, a language processing system 120, A controller 140, a model 150, an edit view 160, a component view 170, developed and implemented by a model view controller (MVC) model, as software operating on or using middleware or a framework such as the framework 130. It has parts (modules) such as a layout 180 and a component 190.
- OS operating system
- MVC model view controller
- the web server program 110 for example, one commonly used in a web server such as Apache (registered trademark) HTTP Server can be appropriately used.
- a web server such as Apache (registered trademark) HTTP Server
- the language processing system 120 and the framework 130 that are the foundation of the application system that runs on the Web server program 110 for example, a script language such as PHP used to create a dynamic Web page, and PHP The implemented Zend Framework can be used as appropriate.
- the controller 140 has a function as a controller (C) in the MVC model, receives a request from a web browser or the like (not shown) on the client terminal 200, makes a data manipulation request to the model 150, and acquires data. Request the screen display to the edit view 160.
- the model 150 has a function as a model (M) in the MVC model, and has a function of executing business logic and performing data manipulation and acquisition.
- the business logic (BL) may, for example, issue a request to another BL server 300 having a database or the like for execution.
- the edit view 160 and the component view 170 have a function as a view (V) in the MVC model, and have a function to perform screen generation and display based on data of the model 150.
- the edit view 160 has a function of configuring the screen, and as described later, designates the layout 180 used on the screen, and calls the components 190 arranged in the area displayed by the layout 180 to make settings.
- the component view 170 performs rendering based on the information of the layout 180 and the component 190 to create HTML (Hyper Text Markup Language) data, and outputs the data to the client terminal 200.
- HTML Hyper Text Markup Language
- the component view 170 processes the Web template for screen display set for the layout 180 and the component 190 according to the device of the client terminal 200 by the template engine 171 as described later. Perform screen output optimized for the target device.
- the web template is a template (for PC) 181p and a template (for smartphone) 181s, for each type (PC, smartphone (smartphone), tablet terminal) of the client terminal 200 as the layout 180, as shown.
- Template (for tablet) 181t (these may be generically referred to as template 181) and for component 190, template (for PC) 191p, template (for smartphone) 191s, template (for tablet), respectively.
- 191t (these may be collectively referred to as a template 191).
- the templates 181 and 191 are prepared separately for the PC, the smartphone, and the tablet terminal, but the present invention is not limited to this.
- the browser may have different devices.
- the template engine 171 has a function of creating an actual screen based on the contents of the design and appearance defined in the web template such as the templates 181 and 191.
- a general template engine such as Smarty mainly used in PHP can be used as appropriate.
- the controller 140 and the component view 170 can be provided generically as the web server system 100. Also, as the layout 180 and component 190 (including the templates 181 and 191) as screen parts, those created in other development cases are reused, or those created in advance in the target development case are used. be able to. In addition, as for the model 150, it is possible to use one that is separately created in the target development project or the like. On the other hand, the screen view developer creates the edit view 160 as source code, but since the differences between the devices are absorbed by the templates 181 and 191 (and the template engine 171), the screen developers differ between the devices. It is not necessary to be conscious of
- FIG. 2 is a diagram schematically showing an example of the difference in layout between devices in the present embodiment.
- the layout divides the whole screen into one or more areas, and indicates the pattern of the arrangement of the areas.
- FIG. 2A the layout on the tablet terminal, and in FIG. 2B, the smartphone An example of the layout of is shown.
- FIG. 2 shows the case where “list, detailed layout” is selected as the layout 180, and a plurality of header areas (header areas 401 and 411) and footer areas (footer areas 404 and 414) are displayed. Show a layout having a list area (list areas 402 and 412) for displaying items in a list, and a content area (content areas 403 and 413) for displaying the detailed contents when a specific item is selected from them. There is.
- FIG. 3 is a diagram schematically showing another example of the difference in layout between devices in the present embodiment. Similar to FIG. 2, FIG. 3A shows an example of the layout of the tablet terminal, and FIG. 3B shows an example of the layout of the smartphone.
- the example of FIG. 3 shows the case where “search condition, result display type layout” is selected as the layout 180, and in addition to the header area (header areas 401 and 411) and footer area (footer areas 404 and 414), A search condition area (search condition areas 405 and 415) for displaying a part or the like for which a condition for search is input and designated and a search result area (search result area 406 and 416) for displaying a search result based on the search condition It shows about the layout which has.
- the design of each area is performed by the template engine 171 of the component view 170.
- the appearance can be switched automatically.
- FIG. 4 is a diagram schematically showing an example of the difference in component display for each device according to the present embodiment. Similar to FIG. 2, FIG. 4 (a) shows an example of a layout on a tablet terminal, and FIG. 4 (b) shows an example of a layout on a smartphone, and “lists and details shown in the example of FIG. In the “type layout”, the case is shown where the component 190 of “menu” is displayed in the header areas 401 and 411.
- the layout of the tablet terminal in FIG. 4A four menu buttons are displayed side by side in the header area 401.
- the icon for displaying the menu is displayed in the header area 411 in the screen on the left side.
- the screen changes to the screen on the right and the header area 411 is expanded (header area 411 '), indicating that menu buttons are displayed vertically in this area.
- Such a device-to-device difference in the same component 190 is defined in the template 191 (in this case, the template (for tablet) 191t and the template (for smartphone) 191s) in the component view 170, as in the layout 180.
- the template engine 171 reflects the actual screen.
- the component 190 in the present embodiment is not limited to one including screen parts and controls, but as illustrated, by a set or combination of a plurality of parts and controls (four menu buttons in the example of FIG. 4) It may be configured.
- FIG. 5 is a diagram schematically showing another example of the difference in component display for each device according to the present embodiment. Similar to FIG. 3, FIG. 5 (a) shows the layout on the tablet terminal, and FIG. 5 (b) shows an example of the layout on the smartphone, and “search conditions,” shown in the example of FIG. In the result display type layout, the case where the component 190 of “search result list” is displayed in the search result areas 406 and 416 is shown. As illustrated, in the layout of the tablet terminal in FIG. 5A, a search result list is displayed in a table form in the search result area 406. On the other hand, the layout of the smartphone shown in FIG. 5B indicates that the search result list is displayed vertically in the form of a list in the search result area 416 of the right screen after transition.
- FIG. 6 is a diagram showing an outline of an example of the designated content in the edit view 160 and the flow of processing upon screen display associated therewith.
- the screen developer creates the edit view 160 that performs the following processing as source code, in which the layout 180 and the component 190 are specified without being aware of the differences among the devices. All you have to do is place and set.
- the screen display optimized for each device is dynamically performed at runtime by the component view 170 (and the template engine 171) based on the contents defined in the templates 181 and 191.
- the layout 180 used for screen display is acquired from the list of layouts 180 created in advance (S01). At this point in time, there are no components 190 to be displayed in each area set in the layout 180 yet. Next, among the list of components 190 created in advance, one or more components 190 to be arranged in the layout 180 acquired in step S01 are acquired (S02). At this point in time, no setting such as data to be displayed has been made in the component 190.
- each component 190 acquired in step S190 is set as data to be displayed for each component 190 acquired in step S190 (S03). Acquisition of data by the model 150 is executed by an instruction via the controller 140. Next, each component 190 for which data is set is designated so as to be arranged in an appropriate area in the layout 180 acquired in step S01 (S04). Then, the layout 180 specifying the arrangement position of each component 190 is passed to the component view 170 to instruct screen drawing (S05).
- information related to the type of device of the client terminal 200 is also passed to the component view 170 (or the component view 170 itself is acquired from the content of the request message).
- the information related to the type of device can be acquired by a known technique, such as acquisition from the User-Agent header of the request message from the client terminal 200, for example.
- the information on the type of device here includes, for example, information such as an OS, a web browser, and its version.
- the component view 170 acquires templates 181 and 191 corresponding to the type of device for the passed layout 180 and each component 190, and performs screen drawing including data according to the design specified in the template. For example, for each component 190, a template (for smartphone) 191s corresponding to the type of device (smartphone in the example of FIG. 6) is acquired, and the component 190 is included including data based on the design defined therein. Screen drawing is performed (in the example of FIG. 6, a list of search results is displayed). In addition, for the layout 180, the template 181s is acquired, and each area is drawn based on the design defined in this, and each component 190 drawn on the screen is arranged at the position of the specified area (see FIG. In the example of 6, a list display of search results is arranged in the search result area 416).
- the pattern of the layout 180 consisting of one or more areas in which the component 190 is arranged while the screen parts are componentized.
- each layout 180 and each component 190 respectively have the templates 181 and 191 created so that the screen output optimized for every device may be performed, and the Web server system 100 processes these templates.
- Component view 170 having a template engine 171.
- the screen layout and components are componentized, and by calling these in the source code of the edit view 160, it is possible to dynamically perform screen display optimized according to the device. That is, the screen developer can create the source code of the edit view 160 without being aware of the differences between the devices. Furthermore, the result of development by the designer can be achieved by separating the function for controlling data processing and behavior in the layout 180 and component 190 and the design (HTML, CSS (Cascading Style Sheets), etc.) defined by the templates 181 and 191. It becomes possible to easily capture an object as a screen part.
- HTML HyperText Markup Language
- CSS CSS
- the present invention is not limited to the above-mentioned embodiment, and can be variously changed in the range which does not deviate from the summary. It goes without saying.
- the above embodiments have been described in detail in order to explain the present invention in an easy-to-understand manner, and are not necessarily limited to those having all the described configurations.
- the present invention is applicable to a web server system that executes a web application that performs screen display compatible with multiple devices.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Information Transfer Between Computers (AREA)
- User Interface Of Digital Computer (AREA)
Abstract
部品化された要素を再利用することで画面開発できるようにするとともに、画面遷移を伴う場合でも1つのソースコードによってマルチデバイス対応を可能とする。代表的な実施の形態によれば、画面パーツが表示される際の外観をデバイスの種類毎に規定したテンプレートを有するコンポーネントと、コンポーネントが配置される領域が画面表示される際の外観をデバイスの種類毎に規定したテンプレートを有するレイアウトと、処理結果画面に適用するレイアウトと配置するコンポーネントを取得し、コンポーネントに対してデータを設定してレイアウトの所定の領域に位置指定するエディットビューと、レイアウトおよびコンポーネントの内容に基づいて、クライアント端末のデバイスの種類に対応したテンプレートによって規定される外観により処理結果画面を作成するコンポーネントビューとを有する。
Description
本発明は、Webアプリケーションの開発技術に関し、特に、マルチデバイスに対応した画面表示を行うWebアプリケーションを実行するWebサーバシステムに適用して有効な技術に関するものである。
近年、例えば、タブレット端末やスマートフォンなどのいわゆるスマートデバイスの業務活用が本格化しており、企業の基幹システムと連携するような中・大規模なシステムの開発案件も増える傾向にある。このような状況で、ユーザ企業の要件は複雑となり、ITベンダー等の開発者にとって開発難易度も高くなってきていることから、開発の効率化を図って生産性を向上させることが重要となる。
この点につき、例えば、ソースコードなどの開発成果物における共通部分・汎用部分の部品化や、開発時の部品の再利用を推進することが効果的である。さらに、マルチデバイスやマルチプラットフォーム(以下では単に「マルチデバイス」と総称する場合がある)対応を行うことで、デバイスやプラットフォーム毎の個別の開発部分を低減させることも有効である。
これに関連して、例えば、特開2013-235387号公報(特許文献1)には、入出力項目を表示するためのコントロールの外観や属性、制御処理などを含むユーザインタフェースを、デバイスに応じてソースコードを変更することなく動的に変更するWebサーバシステムが記載されている。当該システムは、例えば、クライアント端末からの要求に基づいて、クライアント端末のデバイスの種類に係る情報を取得するデバイス取得部と、ソースコードに含まれるパーツオブジェクトについて、デバイス取得部により取得したクライアント端末のデバイスの種類に応じた、パーツオブジェクトの承継元の上位クラスに実装された、コントロールを表示する際の調整内容に基づいて、クライアント端末の画面上に対応するコントロールを表示させるHTMLデータを生成する応答処理部とを有する。
例えば、特許文献1に記載されたような技術を用いることで、Webアプリケーションの開発に際して、部品(パーツオブジェクト)を再利用可能とするとともに、1つのソースコードでマルチデバイス対応をすることが可能となる。
しかしながら、実際は、1つのソースコードによるマルチデバイス対応といっても、例えば、ソースコード中でif文などによりデバイス毎に処理を書き分けることが必要となる場合もある。また、新たにデバイスが追加された場合にソースコードに処理を追記しなければならないなど、画面開発者にとって1つのソースコードによって完全なマルチデバイス対応をすることは困難である。
また、マルチデバイス対応として、例えば、デバイスの画面サイズに応じてユーザインタフェースを切り替えることができる場合でも、実際は、ある画面において表示されるコントロールやパーツなどの大きさや表示形式、配置などを変更できるのみであり、複数画面の遷移を伴った変更を行うことは困難である。
例えば、PC(Personal Computer)やタブレット端末に比べてスマートフォンの画面サイズは小さく、表示できる情報量に制約がある。そのため、例えば、メニューなどの一覧表示について、PCやタブレット端末では1つの画面に常時全て展開した状態で一覧表示するのに対し、スマートフォンでは、通常時はメニュー表示を指示するアイコン等のみを表示しておき、当該アイコン等を介してメニュー表示が指示された際に別画面としてメニュー一覧を表示する、というようなインタフェースが採用される場合がある。従来技術ではこれらの場合に1つのソースコードで各パターンに対応できるようにすることは困難である。
そこで本発明の目的は、Webアプリケーションの開発の際に、部品化された要素を再利用することで画面開発できるようにするとともに、デバイスによっては画面遷移を伴う場合でも、1つのソースコードによってマルチデバイス対応を可能とするWebサーバシステムを提供することにある。
本発明の前記ならびにその他の目的と新規な特徴は、本明細書の記述および添付図面から明らかになるであろう。
本願において開示される発明のうち、代表的なものの概要を簡単に説明すれば、以下のとおりである。
本発明の代表的な実施の形態によるWebサーバシステムは、クライアント端末からのリクエストを受けて、ビジネスロジックを実行し、前記クライアント端末のデバイスの種類に応じた処理結果画面を応答するWebサーバシステムであって、以下の特徴を有するものである。
すなわち、Webサーバシステムは、1つ以上の画面パーツの組み合わせからなり、前記各画面パーツが画面表示される際の外観を前記デバイスの種類毎に規定した第1のテンプレートを有するコンポーネントと、前記処理結果画面上において前記コンポーネントが配置される1つ以上の領域の配置パターンからなり、前記各領域が画面表示される際の外観を前記デバイスの種類毎に規定した第2のテンプレートを有するレイアウトと、を有する。
さらに、前記処理結果画面に適用する前記レイアウトと、前記レイアウトに配置する前記コンポーネントを取得し、取得した前記コンポーネントに対して前記ビジネスロジックの実行により得られるデータを設定して、取得した前記レイアウトの所定の前記領域に配置されるよう位置指定するエディットビューを有する。また、前記エディットビューにより取得された前記レイアウトおよび前記コンポーネントの内容に基づいて、前記クライアント端末の前記デバイスの種類に対応した前記第2のテンプレートおよび前記第1のテンプレートによって規定される外観により前記処理結果画面を作成するコンポーネントビューを有する。
本願において開示される発明のうち、代表的なものによって得られる効果を簡単に説明すれば以下のとおりである。
すなわち、本発明の代表的な実施の形態によれば、Webアプリケーションの開発の際に、部品化された要素を再利用することで画面開発できるようにするとともに、デバイスによっては画面遷移を伴う場合でも、1つのソースコードによってマルチデバイス対応をすることが可能となる。これにより、Webアプリケーションの画面開発の生産性や保守の効率性を大幅に向上させることが可能となる。
以下、本発明の実施の形態を図面に基づいて詳細に説明する。なお、実施の形態を説明するための全図において、同一部には原則として同一の符号を付し、その繰り返しの説明は省略する。
<システム構成>
図1は、本発明の一実施の形態であるWebサーバシステムの構成例について概要を示した図である。本発明の一実施の形態であるWebサーバシステム100は、画面パーツをコンポーネント化してコンポーネント190の一覧として有するとともに、コンポーネント190が配置される1つ以上の画面領域からなるレイアウトのパターンとしてレイアウト180の一覧を有している。そして、各レイアウト180および各コンポーネント190は、それぞれ、デバイス毎に最適化された画面出力をするように作成されたテンプレートを有しており、Webサーバシステム100は、これらに基づいてデバイス毎に最適化された画面出力を自動的に行う。
図1は、本発明の一実施の形態であるWebサーバシステムの構成例について概要を示した図である。本発明の一実施の形態であるWebサーバシステム100は、画面パーツをコンポーネント化してコンポーネント190の一覧として有するとともに、コンポーネント190が配置される1つ以上の画面領域からなるレイアウトのパターンとしてレイアウト180の一覧を有している。そして、各レイアウト180および各コンポーネント190は、それぞれ、デバイス毎に最適化された画面出力をするように作成されたテンプレートを有しており、Webサーバシステム100は、これらに基づいてデバイス毎に最適化された画面出力を自動的に行う。
Webサーバシステム100は、例えば、サーバ機器やクラウドコンピューティングサービス上に構築された仮想サーバからなるサーバシステムであり、例えば、図示しないOS(Operating System)や、Webサーバプログラム110、言語処理系120、フレームワーク130などのミドルウェアや基盤等の上で稼働する、もしくはこれらを利用するソフトウェアとして、MVC(Model View Controller)モデルによって開発、実装されたコントローラ140、モデル150、エディットビュー160、コンポーネントビュー170、レイアウト180およびコンポーネント190などの各部(モジュール)を有する。
Webサーバプログラム110としては、例えば、Apache(登録商標) HTTP Serverなど、Webサーバにおいて一般的に用いられているものを適宜用いることができる。また、Webサーバプログラム110上で稼働するアプリケーションシステムの基盤となる言語処理系120およびフレームワーク130としては、例えば、動的なWebページを作成するために用いられるPHPなどのスクリプト言語、およびPHPで実装されたZend Frameworkなどを適宜用いることができる。
コントローラ140は、MVCモデルにおけるコントローラ(C)としての機能を有し、クライアント端末200上の図示しないWebブラウザ等からのリクエストを受けて、モデル150に対してデータの操作要求を行ってデータを取得したり、エディットビュー160に対して画面表示を要求したりする。モデル150は、MVCモデルにおけるモデル(M)としての機能を有し、ビジネスロジックを実行してデータの操作や取得を行う機能を有する。ビジネスロジック(BL)は、例えば、データベースなどを有する他のBLサーバ300に対して要求を行って実行させるようにしてもよい。
エディットビュー160およびコンポーネントビュー170は、MVCモデルにおけるビュー(V)としての機能を有し、モデル150のデータに基づいて画面生成を行って表示する機能を有する。エディットビュー160は、画面の構成を行う機能を有し、後述するように、画面において用いるレイアウト180を指定するとともに、レイアウト180によって表示される領域に配置するコンポーネント190をそれぞれ呼び出して設定を行う。コンポーネントビュー170は、このレイアウト180およびコンポーネント190の情報に基づいてレンダリングを行ってHTML(HyperText Markup Language)データを作成し、クライアント端末200に対して出力する。
このとき、コンポーネントビュー170は、後述するように、クライアント端末200のデバイスに応じてレイアウト180およびコンポーネント190に対して設定されている画面表示のためのWebテンプレートをテンプレートエンジン171により処理することで、対象のデバイスに最適化された画面出力を行う。
Webテンプレートは、図示するように、クライアント端末200の種別(PC、スマートフォン(スマホ)、タブレット端末)毎に、レイアウト180に対するものとして、それぞれ、テンプレート(PC用)181p、テンプレート(スマホ用)181s、テンプレート(タブレット用)181t(これらを総称してテンプレート181と記載する場合がある)、およびコンポーネント190に対するものとして、それぞれ、テンプレート(PC用)191p、テンプレート(スマホ用)191s、テンプレート(タブレット用)191t(これらを総称してテンプレート191と記載する場合がある)を有する。図1の例では、PC、スマートフォン、およびタブレット端末の別にテンプレート181および191を用意しているが、これに限らず、他のデバイスのものや、同じ種類でも画面サイズが異なったり、OSやWebブラウザが異なるデバイスのものを有していてもよい。
テンプレートエンジン171は、テンプレート181および191などのWebテンプレートに規定されたデザインや外観の内容に基づいて実際の画面を作成する機能を有する。なお、テンプレートエンジン171には、例えば、PHPにおいて主に用いられているSmartyなどの一般的なテンプレートエンジンを適宜用いることができる。
コントローラ140やコンポーネントビュー170は、Webサーバシステム100として汎用的に提供することができる。また、画面部品としてのレイアウト180やコンポーネント190(テンプレート181および191も含む)は、他の開発案件で作成されたものを再利用したり、対象の開発案件において予め作成されたものを用いたりすることができる。また、モデル150についても、対象の開発案件等において別途作成されたものを用いることができる。一方、エディットビュー160は、画面開発者がソースコードとして作成することになるが、デバイス毎の相違は、テンプレート181や191(およびテンプレートエンジン171)が吸収するため、画面開発者がデバイス毎の相違を意識することは不要である。
<レイアウトとコンポーネント>
図2は、本実施の形態におけるデバイス毎のレイアウトの相違の例について概要を示した図である。レイアウトとは、画面全体を1つ以上の領域に区分し、その領域の配置のパターンを指すものであり、図2(a)では、タブレット端末でのレイアウト、図2(b)では、スマートフォンでのレイアウトの例をそれぞれ示している。
図2は、本実施の形態におけるデバイス毎のレイアウトの相違の例について概要を示した図である。レイアウトとは、画面全体を1つ以上の領域に区分し、その領域の配置のパターンを指すものであり、図2(a)では、タブレット端末でのレイアウト、図2(b)では、スマートフォンでのレイアウトの例をそれぞれ示している。
図2の例では、レイアウト180として「一覧、明細型レイアウト」を選択した場合を示しており、ヘッダ領域(ヘッダ領域401、411)およびフッタ領域(フッタ領域404、414)の他に、複数の項目を一覧表示する一覧領域(一覧領域402、412)と、その中から特定の項目を選択した際にその詳細な内容を表示するコンテンツ領域(コンテンツ領域403、413)とを有するレイアウトについて示している。
図示するように、図2(a)のレイアウトでは、1つの画面内に4つの領域が全て配置されている。一方、図2(b)のレイアウトでは、左側の画面において一覧領域412が表示されている状態で、一覧領域412の中から特定の項目を選択すると、右側の画面に遷移して、一覧領域412に代って、選択された項目を表示するためのコンテンツ領域413が表示されることを示している。同一のレイアウト180におけるこのようなデバイス毎の相違は、上述したように、テンプレート181(この場合はテンプレート(タブレット用)181tおよびテンプレート(スマホ用)181s)に規定され、コンポーネントビュー170のテンプレートエンジン171によって実際の画面に反映される。
このように、画面上に表示される部品やコントロールの単位だけではなく、画面全体のレイアウト(画面遷移を伴うものも含む)の単位でも、レイアウト180およびテンプレート181によりデバイス毎の相違を吸収・隠蔽する。これにより、デバイスによっては画面遷移を伴うレイアウトを有しているような場合であっても、エディットビュー160についてはデバイスを意識することなく開発することができる。
図3は、本実施の形態におけるデバイス毎のレイアウトの相違の他の例について概要を示した図である。図2と同様に、図3(a)では、タブレット端末でのレイアウト、図3(b)では、スマートフォンでのレイアウトの例をそれぞれ示している。図3の例では、レイアウト180として「検索条件、結果表示型レイアウト」を選択した場合を示しており、ヘッダ領域(ヘッダ領域401、411)およびフッタ領域(フッタ領域404、414)の他に、検索の際の条件を入力、指定するパーツ等を表示する検索条件領域(検索条件領域405、415)と、その検索条件に基づく検索結果を表示する検索結果領域(検索結果領域406、416)とを有するレイアウトについて示している。
例えば、図3(a)と図2(a)において各領域の配置が異なるように、エディットビュー160において指定するレイアウト180を変更することで、コンポーネントビュー170のテンプレートエンジン171によって各領域のデザイン、外観を自動的に切り替えることができる。
図4は、本実施の形態におけるデバイス毎のコンポーネント表示の相違の例について概要を示した図である。図2と同様に、図4(a)では、タブレット端末でのレイアウト、図4(b)では、スマートフォンでのレイアウトの例を示しており、それぞれ、図2の例で示した「一覧、明細型レイアウト」において「メニュー」のコンポーネント190をヘッダ領域401、411に表示させた場合を示している。
図示するように、図4(a)のタブレット端末でのレイアウトでは、ヘッダ領域401に4つのメニューボタンが横並びに表示されている。一方、図4(b)のスマートフォンのレイアウトでは、左側の画面において、ヘッダ領域411にはメニューを表示させるアイコンのみが表示されており、このアイコンをタップすると右側の画面に遷移して、ヘッダ領域411が拡張され(ヘッダ領域411’)、この領域にメニューボタンが縦並びに表示されることを示している。同一のコンポーネント190におけるこのようなデバイス毎の相違は、レイアウト180の場合と同様に、テンプレート191(この場合はテンプレート(タブレット用)191tおよびテンプレート(スマホ用)191s)に規定され、コンポーネントビュー170のテンプレートエンジン171によって実際の画面に反映される。
なお、本実施の形態におけるコンポーネント190は、1つの画面パーツやコントロールからなるものに限らず、図示するように、複数のパーツやコントロール(図4の例では4つのメニューボタン)の集合や組み合わせによって構成してもよい。
図5は、本実施の形態におけるデバイス毎のコンポーネント表示の相違の他の例について概要を示した図である。図3と同様に、図5(a)では、タブレット端末でのレイアウト、図5(b)では、スマートフォンでのレイアウトの例を示しており、それぞれ、図3の例で示した「検索条件、結果表示型レイアウト」において「検索結果一覧」のコンポーネント190を検索結果領域406、416に表示させた場合を示している。図示するように、図5(a)のタブレット端末でのレイアウトでは、検索結果領域406に検索結果一覧が表形式で表示されている。一方、図5(b)のスマートフォンのレイアウトでは、遷移した右側の画面の検索結果領域416に検索結果一覧がリスト形式で縦並びに表示されることを示している。
<処理の流れ>
図6は、エディットビュー160での指定内容と、これに伴う画面表示時の処理の流れの例について概要を示した図である。上述したように、画面開発者は、ソースコードとして以下の処理を行うようなエディットビュー160を作成するが、その中では、デバイス毎の相違を意識することなくレイアウト180およびコンポーネント190を指定して配置、設定するだけでよい。デバイス毎に最適化された画面表示は、テンプレート181や191に規定された内容に基づいてコンポーネントビュー170(およびテンプレートエンジン171)が実行時に動的に行う。
図6は、エディットビュー160での指定内容と、これに伴う画面表示時の処理の流れの例について概要を示した図である。上述したように、画面開発者は、ソースコードとして以下の処理を行うようなエディットビュー160を作成するが、その中では、デバイス毎の相違を意識することなくレイアウト180およびコンポーネント190を指定して配置、設定するだけでよい。デバイス毎に最適化された画面表示は、テンプレート181や191に規定された内容に基づいてコンポーネントビュー170(およびテンプレートエンジン171)が実行時に動的に行う。
エディットビュー160では、まず、予め作成されているレイアウト180の一覧の中から、画面表示に用いるレイアウト180を取得する(S01)。この時点ではレイアウト180に設定された各領域にはまだ何も表示すべきコンポーネント190は配置されていない。次に、予め作成されているコンポーネント190の一覧の中から、ステップS01で取得したレイアウト180に配置する1つ以上のコンポーネント190を取得する(S02)。この時点ではまだコンポーネント190には表示すべきデータなどの設定は何もされていない。
その後、ステップS190で取得した各コンポーネント190に対して、表示すべきデータとして、モデル150から取得したデータを設定する(S03)。なお、モデル150によるデータの取得は、コントローラ140を介した指示により実行される。次に、データを設定した各コンポーネント190を、ステップS01で取得したレイアウト180における適当な領域に配置されるよう位置指定する(S04)。そして、各コンポーネント190の配置位置を指定したレイアウト180をコンポーネントビュー170に渡して画面描画を指示する(S05)。
このとき、クライアント端末200のデバイスの種類に係る情報も併せてコンポーネントビュー170に渡す(もしくはコンポーネントビュー170自身がリクエストメッセージの内容から取得する)。デバイスの種類に係る情報は、例えば、クライアント端末200からのリクエストメッセージのUser-Agentヘッダから取得するなど、公知の技術により取得することができる。なお、ここでのデバイスの種類に係る情報には、機器の種別の他に、例えば、OS、Webブラウザやそのバージョン等の情報も含まれるものとする。
コンポーネントビュー170では、渡されたレイアウト180および各コンポーネント190について、それぞれ、デバイスの種類に対応したテンプレート181および191を取得して、テンプレートに規定されているデザインに従ってデータを含めた画面描画を行う。例えば、各コンポーネント190については、デバイスの種類(図6の例ではスマートフォン)に対応したテンプレート(スマホ用)191sを取得して、これに規定されているデザインに基づいてデータを含めてコンポーネント190を画面描画する(図6の例では検索結果の一覧表示)。また、レイアウト180については、テンプレート181sを取得して、これに規定されているデザインに基づいて各領域を描画するとともに、指定された領域の位置に画面描画された各コンポーネント190を配置する(図6の例では検索結果領域416に検索結果の一覧表示を配置する)。
以上に説明したように、本発明の一実施の形態であるWebサーバシステム100によれば、画面パーツをコンポーネント化するとともに、コンポーネント190が配置される1つ以上の領域からなるレイアウト180のパターンを有している。そして、各レイアウト180および各コンポーネント190は、それぞれ、デバイス毎に最適化された画面出力をするように作成されたテンプレート181、191を有しており、Webサーバシステム100は、これらのテンプレートを処理するテンプレートエンジン171を有するコンポーネントビュー170を備える。
これにより、画面のレイアウトおよびコンポーネントが部品化され、エディットビュー160のソースコードにおいてこれらを呼び出すことにより、デバイスに応じて最適化された画面表示を動的に行うことが可能となる。すなわち、画面開発者は、デバイス毎の相違を意識することなくエディットビュー160のソースコードを作成することができる。さらに、レイアウト180やコンポーネント190におけるデータの処理や振る舞いを制御する機能と、テンプレート181、191によって規定されるデザイン(HTMLやCSS(Cascading Style Sheets)など)とを分離することで、デザイナーによる開発成果物を画面パーツとして容易に取り込むことが可能となる。
以上、本発明者によってなされた発明を実施の形態に基づき具体的に説明したが、本発明は上記の実施の形態に限定されるものではなく、その要旨を逸脱しない範囲で種々変更可能であることはいうまでもない。例えば、上記の実施の形態は本発明を分かりやすく説明するために詳細に説明したものであり、必ずしも説明した全ての構成を備えるものに限定されるものではない。また、上記の実施の形態の構成の一部について、他の構成の追加・削除・置換をすることが可能である。
本発明は、マルチデバイスに対応した画面表示を行うWebアプリケーションを実行するWebサーバシステムに利用可能である。
100…Webサーバシステム、110…Webサーバプログラム、120…言語処理系、130…フレームワーク、140…コントローラ、150…モデル、160…エディットビュー、170…コンポーネントビュー、171…テンプレートエンジン、180…レイアウト、181p…テンプレート(PC用)、181s…テンプレート(スマホ用)、181t…テンプレート(タブレット用)、190…コンポーネント、191p…テンプレート(PC用)、191s…テンプレート(スマホ用)、191t…テンプレート(タブレット用)、
200…クライアント端末、
300…BLサーバ
401…ヘッダ領域、402…一覧領域、403…コンテンツ領域、404…フッタ領域、405…検索条件領域、406…検索結果領域、411、411’…ヘッダ領域、412…一覧領域、413…コンテンツ領域、414…フッタ領域、415…検索条件領域、416…検索結果領域
200…クライアント端末、
300…BLサーバ
401…ヘッダ領域、402…一覧領域、403…コンテンツ領域、404…フッタ領域、405…検索条件領域、406…検索結果領域、411、411’…ヘッダ領域、412…一覧領域、413…コンテンツ領域、414…フッタ領域、415…検索条件領域、416…検索結果領域
Claims (2)
- クライアント端末からのリクエストを受けて、ビジネスロジックを実行し、前記クライアント端末のデバイスの種類に応じた処理結果画面を応答するWebサーバシステムであって、
1つ以上の画面パーツの組み合わせからなり、前記各画面パーツが画面表示される際の外観を前記デバイスの種類毎に規定した第1のテンプレートを有するコンポーネントと、
前記処理結果画面上において前記コンポーネントが配置される1つ以上の領域の配置パターンからなり、前記各領域が画面表示される際の外観を前記デバイスの種類毎に規定した第2のテンプレートを有するレイアウトと、
前記処理結果画面に適用する前記レイアウトと、前記レイアウトに配置する前記コンポーネントを取得し、取得した前記コンポーネントに対して前記ビジネスロジックの実行により得られるデータを設定して、取得した前記レイアウトの所定の前記領域に配置されるよう位置指定するエディットビューと、
前記エディットビューにより取得された前記レイアウトおよび前記コンポーネントの内容に基づいて、前記クライアント端末の前記デバイスの種類に対応した前記第2のテンプレートおよび前記第1のテンプレートによって規定される外観により前記処理結果画面を作成するコンポーネントビューと、を有する、Webサーバシステム。 - 請求項1に記載のWebサーバシステムにおいて、
前記レイアウトには、複数の画面の遷移にわたる前記領域の配置パターンを含む、Webサーバシステム。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/JP2014/077363 WO2016059677A1 (ja) | 2014-10-14 | 2014-10-14 | Webサーバシステム |
JP2016553778A JP6318261B2 (ja) | 2014-10-14 | 2014-10-14 | Webサーバシステム |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/JP2014/077363 WO2016059677A1 (ja) | 2014-10-14 | 2014-10-14 | Webサーバシステム |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2016059677A1 true WO2016059677A1 (ja) | 2016-04-21 |
Family
ID=55746247
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2014/077363 WO2016059677A1 (ja) | 2014-10-14 | 2014-10-14 | Webサーバシステム |
Country Status (2)
Country | Link |
---|---|
JP (1) | JP6318261B2 (ja) |
WO (1) | WO2016059677A1 (ja) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2018123182A1 (ja) * | 2016-12-26 | 2018-07-05 | パナソニックIpマネジメント株式会社 | 表示システム |
JP6464408B1 (ja) * | 2017-11-02 | 2019-02-06 | 株式会社リクルート | 順番管理システム |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2002259283A (ja) * | 2001-03-01 | 2002-09-13 | Sanyo Electric Co Ltd | データ提供装置及びデータ提供方法並びにプログラム |
JP2003186794A (ja) * | 2001-12-13 | 2003-07-04 | Fujitsu Ltd | 情報提供プログラム,情報提供プログラムを記録したコンピュータ読取可能な記録媒体及び情報提供装置 |
JP2005064755A (ja) * | 2003-08-08 | 2005-03-10 | Canon Inc | リモート制御システム、リモート制御装置、リモート制御端末、被制御装置、リモート制御方法及びプログラム |
JP2012247927A (ja) * | 2011-05-26 | 2012-12-13 | Hitachi Ltd | 画面生成システム、画面生成方法、および画面生成プログラム |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4854260B2 (ja) * | 2005-10-18 | 2012-01-18 | キヤノン株式会社 | リモート操作端末装置 |
-
2014
- 2014-10-14 JP JP2016553778A patent/JP6318261B2/ja active Active
- 2014-10-14 WO PCT/JP2014/077363 patent/WO2016059677A1/ja active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2002259283A (ja) * | 2001-03-01 | 2002-09-13 | Sanyo Electric Co Ltd | データ提供装置及びデータ提供方法並びにプログラム |
JP2003186794A (ja) * | 2001-12-13 | 2003-07-04 | Fujitsu Ltd | 情報提供プログラム,情報提供プログラムを記録したコンピュータ読取可能な記録媒体及び情報提供装置 |
JP2005064755A (ja) * | 2003-08-08 | 2005-03-10 | Canon Inc | リモート制御システム、リモート制御装置、リモート制御端末、被制御装置、リモート制御方法及びプログラム |
JP2012247927A (ja) * | 2011-05-26 | 2012-12-13 | Hitachi Ltd | 画面生成システム、画面生成方法、および画面生成プログラム |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2018123182A1 (ja) * | 2016-12-26 | 2018-07-05 | パナソニックIpマネジメント株式会社 | 表示システム |
JPWO2018123182A1 (ja) * | 2016-12-26 | 2019-10-31 | パナソニックIpマネジメント株式会社 | 表示システム |
US10838593B2 (en) | 2016-12-26 | 2020-11-17 | Panasonic Intellectual Property Management Co., Ltd. | Display system |
JP6464408B1 (ja) * | 2017-11-02 | 2019-02-06 | 株式会社リクルート | 順番管理システム |
WO2019088236A1 (ja) * | 2017-11-02 | 2019-05-09 | 株式会社リクルート | 順番管理システム |
JP2019086882A (ja) * | 2017-11-02 | 2019-06-06 | 株式会社リクルート | 順番管理システム |
Also Published As
Publication number | Publication date |
---|---|
JPWO2016059677A1 (ja) | 2017-05-18 |
JP6318261B2 (ja) | 2018-04-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6263282B2 (ja) | 開発支援システム | |
US10185819B2 (en) | Extension configuration and interaction | |
US20200326914A1 (en) | Creating an app method and system | |
KR101416104B1 (ko) | 하이브리드 웹 어플리케이션의 네이티브 기능을 수행하는 자바스크립트 코드의 동적 로딩 장치와 방법 | |
US9460230B1 (en) | Method and system for visual styling of visual elements for applications | |
CN104866327A (zh) | 一种php开发方法及框架 | |
JP6750124B2 (ja) | 端末装置、ui拡張方法及びui拡張プログラム | |
CN108664242B (zh) | 生成可视化界面的方法、装置、电子设备和可读存储介质 | |
JP6318261B2 (ja) | Webサーバシステム | |
CN113778405A (zh) | 一种跨平台app构建方法、装置、系统及介质 | |
US20210271458A1 (en) | Managing an app method and system | |
JP6212657B2 (ja) | 開発支援システム | |
JP7294609B2 (ja) | ソフトウェアの操作シナリオの生成を支援するプログラム、方法およびソフトウェアの操作シナリオの生成を支援する装置 | |
KR102385381B1 (ko) | 카메라 이펙트를 위한 스크립트 생성 방법 및 시스템 | |
JP6676122B2 (ja) | 高速のローディング速度を有するコンポーネント生成方法 | |
Pham | React Concurrent Mode: mechanisms, patterns and application | |
CN117591115A (zh) | 一种用户界面生成方法、装置、设备及介质 | |
Kmjetin et al. | Scripting framework for graphical configuration tool for embedded devices | |
KR20150097201A (ko) | 애플리케이션 개발 환경 제공 시스템 | |
CN116932391A (zh) | 一种嵌入html5的第三方应用程序调试方法及系统 | |
Xu et al. | The Technique of GIS Desktop Secondary Development | |
CN110837402A (zh) | 终端屏幕编排方法和系统 | |
JP2016153997A (ja) | ソフトウェア開発システム | |
KR20150097200A (ko) | 애플리케이션 개발 환경 제공 시스템 | |
KR20150097198A (ko) | 애플리케이션 개발 환경 제공 시스템 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 14903933 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2016553778 Country of ref document: JP Kind code of ref document: A |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 14903933 Country of ref document: EP Kind code of ref document: A1 |