The systems and methods discussed herein relate to web page navigation.
Pages in the World Wide Web (Web) are typically written in hyper text markup language (HTML). Server-side logic controlling navigation and performing data access and other server-side functionality is typically written in a procedural or object-oriented programming language to tie pages together, forming a web application. These web pages are stored on servers connected through the Internet. Each web page is associated with a uniform resource locator (URL) and a user/client can browse to a particular web page by requesting the web page from a server using the URL corresponding to the web page.
Web applications are increasingly being used to interact with users in a web-based environment. These web applications may include many different types of scenarios, such as login and logout operations, e-commerce, help wizards, and the like. To interact with users for a particular scenario, a web application typically has to include multiple web pages to present information to and receive input from the users. Web developers typically have to carefully design web pages and server-side procedural logic for a web application to manage the navigation of the pages through a scenario. Specifically, a web developer must incorporate multiple navigational controls in each web page and add server-side procedural logic to ensure that the navigational controls in all of the web pages allow a user to correctly navigate through the scenario. If web pages with dynamic content are used, the developer must also include server-side logic to accurately track and respond to the user-driven navigation flow through these dynamically changing pages. Web pages developed in this labor-intensive manner are expensive and error prone.
Thus, there is a need for an efficient web development technique for defining navigational flow in a scenario without the need to write procedural server-side navigational logic in each web page and to track the navigation flow through the web pages.
The systems and methods described herein are directed at defining web content navigation by declaring multiview objects. The disclosed technique enables the development of web content for a scenario without having to write server-side navigational logic to manage the flow through the web content in the scenario.
In one aspect, a method determines a declaration in a web page. The declaration is associated with an object. The method determines the views associated with the object where each of the views includes a user-interface. A flow for navigating through the views is determined. The views are rendered in accordance with the navigational flow.
Server 120 is configured to provide web content to client 110. As shown in
Server 120 may also be configured to interact with other computing devices, such as backend servers 130. Backend servers 130 may be configured to provide a variety of services to server 120, such as e-commerce services, user authentication services, emailing services, phone and paging services, and the like. Server 120 may subscribe to the services provided by backend servers 130 to implement the object-oriented source file determined by request handler 123.
Server 120 may communicate with backend servers 130 and client 110 through any type of network, such as wide area network (WAN), local area network (LAN), wireless network, the Internet, and the like.
Request handler 123 is configured to access source files 223. Each of the source files 223 includes program code and is associated with a web page, which may be identified by an address. Request handler 123 is configured to determine a source file corresponding to the address in a request. Each of the source files 223 includes object declarations 225, which are declarations for objects 235 used for generating views associated with the requested web page. Object declarations 225 are typically included in a source file as mark-up tags. Each tag may include an identifier associated with an object and other information related to the object, such as properties, states, and options.
Rendering engine 125 is configured to process source files 223 and to generate views 250 from the codes. To generate views 250, rendering engine 125 determines object declarations 225 in source files 223 and gains access to objects 235 associated with object declarations 225. Rendering engine 125 uses the data and procedures associated with objects 235 for rendering views 250. In addition to rendering views 250, rendering engine 125 may also perform other operations associated with objects 235, such as sending an email, authenticating a user, setting up a user account, handling a business transaction, making a phone call or a page, and the like. To perform these operations, rendering engine 125 may interact with other components, such as email handler 245, account manager 246, e-commerce manager 247, communication handler 248, and the like. Components 245-248 may be executing on server 120 shown in
As illustrated in
It is to be understood that the use of multiview objects enables a web developer to implement multiple views associated with a scenario without having to incorporate controls in each of the views or to dynamically manage navigational flow through the views. Multiview object may also encapsulate other operations and data associated with a scenario so that the web developer may incorporate an entire scenario package into a web application with a single declaration in a source file. The web developer may specify properties, states, and options to tailor the multiview object for producing the desired scenario.
Server control objects 324 define logical controls for implementing operations that are executed by the server. For example, multiview object 300 is a type of server control object. Server control objects 324 may include data and procedures for the server to execute any type of operation. The operations associated with server control objects 324 may be related to rendering view 311 or performing actions in connection with view 311.
User control objects 325 define logical controls for users that may be included in view 311. User control objects 325 may include data and procedures for implementing any type of user logical control, such as a button, a textbox, a pull-down menu, a selectable area, and the like.
Layout data 321 includes the framework for organizing the elements in view 311. For example, layout data 321 may define where to place the logical controls defined by user control objects 325 in view 311. Layout data 321 may also include text, multimedia items, and other content for including in view 311. Layout data 321 may be supplied by the view rendering server that handles multiview object 300 or other servers that are in communication with the view rendering server. These other servers may be configured to supply specialized data, such as stock quotes, maps, weather information, and the like.
Navigational logic 334 includes data and procedures for navigating among views associated with multiview object 300. Navigational logic 334 may be implemented in server control objects 324, user control objects 325, or as separate rules as part of view 311. The navigational flow included in navigational logic 334 is typically tested to ensure that the flow is consistent with a scenario associated with multiview object 300. The navigational flow may be a linear flow, a non-linear flow, a user-driven flow, an operational dependent flow, and the like. Navigational logic 334 may include instructions for moving to a previous view, a next view, or a specific view associated with multiview object 300. Navigational logic 334 may include instructions for moving to a particular view based on an input received through another view.
Operational logic 335 includes data and procedures for performing operations associated with view 311. Operational logic 335 may be implemented in server control objects 324 and user control objects 325. Operational logic 335 may also be implemented as separate operations as part of view 311. Operational logic 335 may be performed by the view rendering server that handles multiview object 300 or other servers that are in communication with the view rendering server. For example, an operation specified by operational logic 335 may be performed by a server that specializes to perform such operation. These operations may include emailing handling, user authentication, e-commerce, phone and paging services, and the like.
In addition to the above-identified objects and logic, view 311 may include other data 337 that is used to implement the view. The objects discussed above may be implemented as classes of objects. For example, multiview object 300 may be implemented as a container class that includes view object classes 311-313. A server may create instances of these objects for rendering views associated a multiview object that is declared in a source file.
Multiview server control “pwrecovery” is associated with views 410. These views enable a user to navigate through a password recovery scenario. Initial view 421 enables a user to supply a user name for which the password is to be recovered. The items in initial view 421 include text, a text box and a button. Initial view 421 also includes logic for submitting information to an account manager to identify the user with the input user name. Initial view 421 may include logic for navigating to different views based on input from the user and information from the account manager. For example, if the user name is valid, initial view 421 is configured to navigate to Q & A view 422.
Q & A view 422 includes information about a question received from the account manager to authenticate the user. Q & A view 422 is configured to receive the input from the user and to submit the input to the account manger. Q & A view 422 is also configured to navigate to confirmation view 423 if the answer submitted by the user is correct.
Confirmation view 423 is configured to inform the user that a password recovery scenario has been successfully completed. Confirmation view 423 may display information received from the account manager to the user. Confirmation view 423 may also be configured to interact with an email handler to send the recovered password to the user in an email.
At decision block 515, a determination is made whether the source file includes declarations for multiview objects. If so, process 500 moves to block 517 where the declared multiview objects are processed. The processing of multiview objects will be discussed in more detail in conjunction with
Returning to decision block 515, if the source file does not include any multiview objects, process 500 also moves to decision block 520. At decision block 520, a determination is made whether the source file includes rendering instructions. The source file may include rendering instructions in hyper text markup language (HTML), scripts, object-oriented instructions, and the like. If the source file includes rendering instructions, process 500 moves to block 525 where the web page is rendered. The process then moves to block 530.
Returning to decision block 520, if the source file does not include rendering instructions, process 500 also moves to block 530. At block 530, operations included in the source file are performed. The source file may include any type of operation. The operations in the source file may be performed based on input received from a user.
At block 625, an input associated with the currently rendered view is received. The input may be any type of data received from the view, such as input from the user, the client computer, and the like. At block 630, operations associated with the currently rendered view are performed. At block 635, a determination is made whether to navigate to another view. This determination may be made based on the navigational logic associated with the multiview object. It is to be understood that the navigational logic may include navigating back to the same view.
If the determination is made to navigate to another view, process 600 moves to block 640 where the current view is updated to the other view. The process then goes to block 645. If the determination is made to not navigate to another view, the process moves to block 645. At block 645, process 600 returns to the web page execution.
Computing device 700 can be implemented with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use include, but are not limited to, personal computers, server computers, thin clients, thick clients, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, gaming consoles, distributed computing environments that include any of the above systems or devices, and the like.
The components of computing device 700 can include, but are not limited to, processor 702 (e.g., any of microprocessors, controllers, and the like), system memory 704, input devices 706, output devices 708, and network devices 710.
Computing device 700 typically includes a variety of computer-readable media. Such media can be any available media that is accessible by computing device 700 and includes both volatile and non-volatile media, removable and non-removable media. System memory 704 includes computer-readable media in the form of volatile memory, such as random access memory (RAM), and/or non-volatile memory, such as read only memory (ROM). A basic input/output system (BIOS), containing the basic routines that help to transfer information between elements within computing device 700, such as during start-up, is stored in system memory 704. System memory 704 typically contains data and/or program modules that are immediately accessible to and/or presently operated on by processor 702.
System memory 704 can also include other removable/non-removable, volatile/non-volatile computer storage media. By way of example, a hard disk drive may be included for reading from and writing to a non-removable, non-volatile magnetic media; a magnetic disk drive may be included for reading from and writing to a removable, non-volatile magnetic disk (e.g., a “floppy disk”); and an optical disk drive may be included for reading from and/or writing to a removable, non-volatile optical disk such as a CD-ROM, DVD, or any other type of optical media.
The disk drives and their associated computer-readable media provide non-volatile storage of computer-readable instructions, data structures, program modules, and other data for computing device 700. It is to be appreciated that other types of computer-readable media which can store data that is accessible by computing device 700, such as magnetic cassettes or other magnetic storage devices, flash memory cards, CD-ROM, digital versatile disks (DVD) or other optical storage, random access memories (RAM), read only memories (ROM), electrically erasable programmable read-only memory (EEPROM), and the like, can also be utilized to implement exemplary computing device 700. Any number of program modules can be stored in system memory 704, including by way of example, an operating system 720, application programs 728, and data 732.
Computing device 700 can include a variety of computer-readable media identified as communication media. Communication media typically embodies computer-readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” refers to a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above are also included within the scope of computer-readable media.
A user can enter commands and information into computing device 700 via input devices 706 such as a keyboard and a pointing device (e.g., a “mouse”). Other input devices 706 may include a microphone, joystick, game pad, controller, satellite dish, serial port, scanner, touch screen, touch pads, key pads, and/or the like. Output devices 708 may include a CRT monitor, LCD screen, speakers, printers, and the like.
Computing device 700 may include network devices 710 for connecting to computer networks, such as local area network (LAN), wide area network (WAN), and the like.
To further illustrate how the described systems and methods can be implemented, example codes are included below.
Table 1 includes an example declaration that may be included in a source file for a web page to declare a multiview object class named “PasswordRecovery”. Table 2 illustrates the properties that are associated with the “PasswordRecovery” class.
Below is information about the properties that the “PasswordRecovery” class may include.
Below is information about the events that the “PasswordRecovery” class may include.
Below is information about the methods that the “PasswordRecovery” class may include.
Although the invention has been described in language specific to structural features and/or methodological steps, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or steps described. Rather, the specific features and steps are disclosed as preferred forms of implementing the claimed invention.
Number | Name | Date | Kind |
---|---|---|---|
3937925 | Boothroyd | Feb 1976 | A |
3956615 | Anderson et al. | May 1976 | A |
4186871 | Anderson et al. | Feb 1980 | A |
4807154 | Scully et al. | Feb 1989 | A |
4847785 | Stephens | Jul 1989 | A |
4949300 | Christenson et al. | Aug 1990 | A |
4979148 | Bush et al. | Dec 1990 | A |
5299315 | Chin et al. | Mar 1994 | A |
5349657 | Lee | Sep 1994 | A |
5388156 | Blackledge, Jr. et al. | Feb 1995 | A |
5465332 | Deloye et al. | Nov 1995 | A |
5471318 | Ahuja et al. | Nov 1995 | A |
5517655 | Collins et al. | May 1996 | A |
5548340 | Bertram | Aug 1996 | A |
5550560 | Kanada et al. | Aug 1996 | A |
5604908 | Mortson | Feb 1997 | A |
5638176 | Hobbs et al. | Jun 1997 | A |
5640449 | Worley et al. | Jun 1997 | A |
5664228 | Mital | Sep 1997 | A |
5675520 | Pitt, III et al. | Oct 1997 | A |
5706505 | Fraley et al. | Jan 1998 | A |
5732256 | Smith | Mar 1998 | A |
5732267 | Smith | Mar 1998 | A |
5745103 | Smith | Apr 1998 | A |
5748890 | Goldberg et al. | May 1998 | A |
5764873 | Magid et al. | Jun 1998 | A |
5774670 | Montulli | Jun 1998 | A |
5793982 | Shrader et al. | Aug 1998 | A |
5812996 | Rubin et al. | Sep 1998 | A |
5835724 | Smith | Nov 1998 | A |
5855020 | Kirsch | Dec 1998 | A |
5878141 | Daly et al. | Mar 1999 | A |
5878282 | Mital | Mar 1999 | A |
5897622 | Blinn et al. | Apr 1999 | A |
5911068 | Zimmerman et al. | Jun 1999 | A |
5918007 | Blackledge, Jr. et al. | Jun 1999 | A |
5940075 | Mutschler, III et al. | Aug 1999 | A |
5940847 | Fein et al. | Aug 1999 | A |
5953524 | Meng et al. | Sep 1999 | A |
5956489 | San Andres et al. | Sep 1999 | A |
5961601 | Iyengar | Oct 1999 | A |
5963952 | Smith | Oct 1999 | A |
5983227 | Nazem et al. | Nov 1999 | A |
5991802 | Allard et al. | Nov 1999 | A |
6006230 | Ludwig et al. | Dec 1999 | A |
6014637 | Fell et al. | Jan 2000 | A |
6014666 | Helland et al. | Jan 2000 | A |
6032207 | Wilson | Feb 2000 | A |
6038551 | Barlow et al. | Mar 2000 | A |
6067578 | Zimmerman et al. | May 2000 | A |
6072664 | Aoyagi et al. | Jun 2000 | A |
6076108 | Courts et al. | Jun 2000 | A |
6101607 | Bachand et al. | Aug 2000 | A |
6108717 | Kimura et al. | Aug 2000 | A |
6115744 | Robins | Sep 2000 | A |
6121968 | Arcuri et al. | Sep 2000 | A |
6138150 | Nichols et al. | Oct 2000 | A |
6167524 | Goodnow et al. | Dec 2000 | A |
6178461 | Chan et al. | Jan 2001 | B1 |
6185608 | Hon et al. | Feb 2001 | B1 |
6203220 | Takenoshita et al. | Mar 2001 | B1 |
6205480 | Broadhurst et al. | Mar 2001 | B1 |
6212192 | Mirashrafi et al. | Apr 2001 | B1 |
6218958 | Eichstaedt et al. | Apr 2001 | B1 |
6230160 | Chan et al. | May 2001 | B1 |
6246422 | Emberling et al. | Jun 2001 | B1 |
6247044 | Gosling et al. | Jun 2001 | B1 |
6253228 | Ferris et al. | Jun 2001 | B1 |
6253234 | Hunt et al. | Jun 2001 | B1 |
6279151 | Breslau et al. | Aug 2001 | B1 |
6286133 | Hopkins | Sep 2001 | B1 |
6297819 | Furst | Oct 2001 | B1 |
6326957 | Nathan et al. | Dec 2001 | B1 |
6334157 | Oppermann et al. | Dec 2001 | B1 |
6343148 | Nagy | Jan 2002 | B2 |
6351767 | Batchelder et al. | Feb 2002 | B1 |
6353447 | Truluck et al. | Mar 2002 | B1 |
6354477 | Trummer | Mar 2002 | B1 |
6363352 | Dailey et al. | Mar 2002 | B1 |
6370561 | Allard et al. | Apr 2002 | B1 |
6373841 | Goh et al. | Apr 2002 | B1 |
6397253 | Quinlan et al. | May 2002 | B1 |
6401099 | Koppolu et al. | Jun 2002 | B1 |
6405241 | Gosling et al. | Jun 2002 | B2 |
6412008 | Fields et al. | Jun 2002 | B1 |
6430575 | Dourish et al. | Aug 2002 | B1 |
6460071 | Hoffman | Oct 2002 | B1 |
6460141 | Olden | Oct 2002 | B1 |
6463442 | Bent et al. | Oct 2002 | B1 |
6480894 | Courts et al. | Nov 2002 | B1 |
6487665 | Andrews et al. | Nov 2002 | B1 |
6505238 | Tran | Jan 2003 | B1 |
6539421 | Appelman et al. | Mar 2003 | B1 |
6546516 | Wright et al. | Apr 2003 | B1 |
6557038 | Becker et al. | Apr 2003 | B1 |
6560598 | Delo et al. | May 2003 | B2 |
6560618 | Ims | May 2003 | B1 |
6564251 | Katariya et al. | May 2003 | B2 |
6591272 | Williams | Jul 2003 | B1 |
6606418 | Mitchell et al. | Aug 2003 | B2 |
6622168 | Datta | Sep 2003 | B1 |
6633416 | Benson | Oct 2003 | B1 |
6725219 | Nelson et al. | Apr 2004 | B2 |
6728421 | Kokemohr | Apr 2004 | B2 |
6789105 | Ludwig et al. | Sep 2004 | B2 |
20010054020 | Barth et al. | Dec 2001 | A1 |
20020004815 | Muhlestein et al. | Jan 2002 | A1 |
20020008703 | Merrill et al. | Jan 2002 | A1 |
20020083171 | Hoogenboom et al. | Jun 2002 | A1 |
20020108102 | Muhlestein et al. | Aug 2002 | A1 |
20020188890 | Shupps et al. | Dec 2002 | A1 |
20030009476 | Fomenko et al. | Jan 2003 | A1 |
20030009519 | Gosling et al. | Jan 2003 | A1 |
20030009567 | Farouk | Jan 2003 | A1 |
20030018827 | Guthrie et al. | Jan 2003 | A1 |
20030025728 | Ebbo et al. | Feb 2003 | A1 |
20030028565 | Landsman et al. | Feb 2003 | A1 |
20030028892 | Gewickey et al. | Feb 2003 | A1 |
20030074634 | Emmelmann | Apr 2003 | A1 |
20030097639 | Niyogi et al. | May 2003 | A1 |
20040003112 | Alles et al. | Jan 2004 | A1 |
20040003139 | Cottrille et al. | Jan 2004 | A1 |
20040003248 | Arkhipov | Jan 2004 | A1 |
20040073873 | Croney et al. | Apr 2004 | A1 |
20040218045 | Bodnar et al. | Nov 2004 | A1 |
20050138560 | Lee et al. | Jun 2005 | A1 |
20050166230 | Gaydou et al. | Jul 2005 | A1 |
20060112336 | Gewickey et al. | May 2006 | A1 |
20070005795 | Gonzalez | Jan 2007 | A1 |
20070033533 | Sull | Feb 2007 | A1 |
Number | Date | Country |
---|---|---|
1156415 | Nov 2001 | EP |
1156427 | Nov 2001 | EP |
1156428 | Nov 2001 | EP |
1164473 | Dec 2001 | EP |
01111680.3-2201 | Apr 2002 | EP |
01111681.1-2201 | Apr 2002 | EP |
WO 9821651 | May 1998 | WO |
WO 9844695 | Oct 1998 | WO |
WO 9934288 | Jul 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20050257138 A1 | Nov 2005 | US |