Version | 1.0 |
Revision | 1 |
Status | External Draft |
Date | 26-June-2006 |
Editors | Ronan Cremin |
Jo Rabin |
This document has the status "External Draft". This means that its mandatory provisions are not in force. The document will be updated to "Current" status at which point its mandatory provisions will be enforced. The lifecycle of the dotMobi Switch On! Guide is discussed in [Lifecycle]
There are no time limits associated with compliance to this document.
This is the first public draft of version 1.0 this document. A statement of policy regarding updates to this document can be found at http://mtld.mobi/
The latest version of this document is available at http://mtld.mobi/
This version can be found at http://mtld.mobi/
Parts of this document are derived from W3C Mobile Web Best Practices, W3C Working Draft, [MWBP], © 2005 World Wide Web Consortium, (Massachusetts Institute of Technology, European Research Consortium for Informatics and Mathematics, Keio University). All Rights Reserved.
This document contains information proprietary to Mobile Top Level Domain Limited ("mTLD" or "dotMobi"). You may not modify, copy, reproduce, republish, upload, post, transmit, or distribute in any way any material from this document including code and software without the express, written consent of mTLD.
This document as a whole is copyrighted as a collective work, and individual works appearing on or accessible through this document are likewise subject to copyright protection. You agree to honor the copyrights in this document (including the selection, coordination and arrangement of the contents of this document) and in the works available on or through this document. In addition, trademarks and tradedress belonging to us or to third parties appear on this site or are accessible through this site. The fact that we have permitted you access to this site does not constitute authorization to reproduce such trademarks for any other purpose.
Copyright © 2005–2006 Mobile Top Level Domain Limited
DotMobi Switch On! Guides are a set of guides governing certain technical protocols and services in the ".mobi" (dotMobi) domain. These guides are a combination of mandatory rules and best practices that, when applied to content and services associated with the domain, ensure a good user experience for users interacting with the domain and its services via a mobile device. The rules mentioned in Switch On! Guide documents are specifically designed to be:
DotMobi Switch On! Guides are primarily oriented at domain registrants, since registrants are the owner of content and services hosted at any domain, but are also useful for tool vendors and solution providers whose products and services may be involved with dotMobi.
DotMobi domain name registrants agree to implement the mandatory registrant rules listed in this document whenever they publish a web site linked to a dotMobi name on the internet. It is strongly recommended that registrants also ensure that their applications also comply with Best Practices to improve the end-user experience.
mTLD will audit all dotMobi domains for compliance to the mandatory rules. mTLD will audit these domains in whatever way or frequency decided by mTLD to be practical and reasonable. When a web site using a dotMobi name is not compliant with the mandatory rules, an exception report for the dotMobi name will be created by mTLD.
DotMobi names not in compliance with mandatory rules will have 60 days to become compliant. mTLD shall send two notices to the registrant's registrar asking the registrar to contact the offending registrant with the exception report. The registrar will be required to provide a 60 day and then a 45 day notice of this non-compliance. If a name is not in compliance with 30 days left to go, then mTLD may chose to contact the registrant directly after making best efforts to make contact through their registrar. A formal policy will be available on the mTLD web site in the near future.
DotMobi names that are not brought back into compliance shall be place into a hold status which will prevent their resolution on the internet. The dotMobi names shall not be deleted from the registration system, but their name will be placed on hold until they are in compliance with the mandatory rules.
Registrars are obliged to make registrants aware of all Switch On! Guides associated with the dotMobi domain in advance of any registration taking place. Registrars must either make a copy of these documents available to the registrant or point them to the authoritative versions on the mtld.mobi web site.
The dotMobi domain is intended as a sign to users that web sites within the domain are especially suitable for use on mobile devices. Registrants are expected to make sure that their dotMobi web site works well with mobile devices. Following the guidelines in this document will assist them in doing this.
This document is the authoritative source of rules governing web content served from a dotMobi domain. It also acts as a guide for web site developers and solution providers whose tools and services are used in this the dotMobi domain, or to produce content for a site in this domain. These rules are designed to ensure a good user experience for users browsing these web sites from mobile devices.
The Switch On! Web Developer Guide covers the use case of browsing a dotMobi application/web site from a mobile phone, PDA or other hand-held device. This guide specifically does not cover use cases involving desktop PCs or other device types, nor does it cover other Internet-based applications such as email or instant messaging.
The best practice recommendations in this document are primarily based upon the W3C Mobile Web Best Practices [MWBP]. In addition a number of dotMobi specific rules and best practices are introduced.
Developers should also refer to the Domain Name Guidelines document that is published in the same location as this document.
DotMobi-specific best practices are identified as follows:
[dotMobi] The text of a dotMobi rule or best practice
W3C-derived best practice statements are identified as follows:
[W3C EXAMPLE] The text of a W3C Best Practice
For each W3C statement a link is provided to the corresponding W3C best practice statement. Readers can follow these links for further discussion on the meaning of the statement and how to test compliance.
The rules and best practices are classified into the following sections:
[dotMobi] When a dotmobi web site is accessed using a URI that consists only of a second-level domain name (e.g. example.mobi) or consists only of the 'www' third-level domain name (e.g. www.example.mobi), the page delivered as a response must be encoded in XHTML-MP 1.0 [XHTMLMP] unless the device is known to support an alternative choice of markup.
If the site provides its home page by redirection then all intermediate pages that are delivered in the course of the redirection must comply with this rule.
It is not the intention to restrict the uses that dotMobi registrants put their site to. However, in order to contribute to the overall usability and premium user experience of the dotMobi domain it is important that visitors to sites have the best possible experience of them, even if their devices do not support the formats that registrants wish to support. Consequently, at a minimum, visitors to dotMobi sites must receive a message that is displayable by their browser, directing them to a portion of the site that is accessible to them, or identifying the type of device that is necessary to experience the site properly.
Some web sites will adapt their content dynamically to accommodate the type of browser and formats supported by that browser. In this case the site should generate a page formatted in valid XHTML-MP 1.0 if, following consultation of its list of device types or formats, it cannot find a match for the device in question. The user in this case stands a very good chance of receiving a page that their device can display. The content of the page is at the site owner's discretion, and may be a message allowing the user to select a particular type of experience, or may be a message detailing the types of device required to access the service. Site owners are encouraged to support the widest possible range of devices.
In cases where the site infrastructure does not provide the ability to detect the browser type or formats that are acceptable there must be a page at the domain root that is delivered in XHTML-MP 1.0. This does not mean that the rest of the site has to be formatted in XHTML-MP 1.0. Sites that cater specifically for some other format may have their entry point identified by a path e.g. a site that is specifically targeted at WML devices only could have its home page at example.mobi/wml.
The preferred method of redirection is by using HTTP 3XX codes (see below).
[dotMobi] Domains that operate a site at www.example.mobi must also implement a site at example.mobi.
Research has shown that typing in URLs on a mobile phone is a significant barrier to entry for users using mobile devices. Pointing the second-level domain (domain.mobi) at the same site as the third-level domain (www.domain.mobi) makes it easier for users to get to your site.
[dotMobi] Do not use frames (standard or inline) unless the target client is known to support them. See also [W3C NO_FRAMES].
[W3C THEMATIC_CONSISTENCY] Ensure that content provided by accessing a URI yields a thematically coherent experience when accessed from different devices.
[W3C CAPABILITIES] Exploit device capabilities. Do not take a least common denominator approach.
[W3C DEFICIENCIES] Take reasonable steps to work around deficient implementations.
[W3C TESTING] Carry out testing on actual devices as well as emulators.
[W3C URIS] Keep the URIs of site entry points short.
[W3C NAVBAR] Provide only minimal navigation at the top of the page.
[W3C BALANCE] Take into account the trade-off between having too many links on a page and asking the user to follow too many links to reach what they are looking for.
[W3C NAVIGATION] Provide consistent navigation mechanisms.
[W3C ACCESS_KEYS] Assign access keys to links in navigational menus and frequently accessed functionality.
[W3C LINK_TARGET_ID] Clearly identify the target of each link.
[W3C LINK_TARGET_FORMAT] Note the target file's format unless you know the device supports it.
[W3C IMAGE_MAPS] Do not use image maps unless you know the target client supports them effectively.
[W3C POP_UPS] Do not cause pop-ups or other windows to appear and do not change the current window without informing the user.
[W3C AUTO_REFRESH] Do not create periodically auto-refreshing pages, unless you have informed the user and provided a means of stopping it.
[W3C REDIRECTION] Do not use markup to redirect pages automatically. Instead, configure the server to perform redirects by means of HTTP 3xx codes.
[W3C EXTERNAL_RESOURCES] Keep the number of externally linked resources to a minimum.
[W3C SUITABLE] Ensure that content is suitable for use in a mobile context.
[W3C CLARITY] Use clear and simple language.
[W3C LIMITED] Limit content to what the user has requested.
[W3C PAGE_SIZE_USABLE] Divide pages into usable but limited size portions.
[W3C PAGE_SIZE_LIMIT] Ensure that the overall size of page is appropriate to the memory limitations of the device.
[W3C SCROLLING] Limit scrolling to one direction, unless secondary scrolling cannot be avoided.
[W3C CENTRAL_MEANING] Ensure that material that is central to the meaning of the page precedes material that is not.
[W3C GRAPHICS_FOR_SPACING] Do not use graphics for spacing.
[W3C LARGE_GRAPHICS] Do not use images that cannot be rendered by the device. Avoid large or high resolution images except where critical information would otherwise be lost.
[W3C USE_OF_COLOR] Ensure that information conveyed with color is also available without color.
[W3C COLOR_CONTRAST] Ensure that foreground and background color combinations provide sufficient contrast.
[W3C BACKGROUND_IMAGE_READABILITY] When using background images make sure that content remains readable on the device.
[W3C PAGE_TITLE] Provide a short but descriptive page title.
[W3C STRUCTURE] Use features of the markup language to indicate logical document structure.
[W3C TABLES_SUPPORT] Do not use tables unless the client is known to support them.
[W3C TABLES_NESTED] Do not use nested tables.
[W3C TABLES_LAYOUT] Do not use tables for layout.
[W3C TABLES_ALTERNATIVES] Where possible, use an alternative to tabular presentation.
[W3C NON-TEXT_ALTERNATIVES] Provide a text equivalent for every non-text element.
[W3C OBJECTS_OR_SCRIPT] Do not rely on embedded objects or script.
[W3C IMAGES_SPECIFY_SIZE] Specify the size of images in markup, if they have an intrinsic size.
[W3C IMAGES_RESIZING] Resize images at the server, if they have an intrinsic size.
[W3C VALID_MARKUP] Create documents that validate to published formal grammars.
[W3C MEASURES] Do not use pixel measures and do not use absolute units in markup language attribute values and style sheet property values.
[W3C STYLE_SHEETS_USE] Use style sheets to control layout and presentation, unless the device is known not to support them.
[W3C STYLE_SHEETS_SUPPORT] Organize documents so that they may be read without style sheets.
[W3C STYLE_SHEETS_SIZE] Keep style sheets small.
[W3C MINIMIZE] Use terse, efficient markup.
[W3C CONTENT_FORMAT_SUPPORT] Send content in a format that is known to be supported by the device.
[W3C CONTENT_FORMAT_PREFERRED] Where possible, send content in a preferred format.
[W3C CHARACTER_ENCODING_SUPPORT] Ensure that content is encoded using a character encoding that is known to be supported by the target device.
[W3C CHARACTER_ENCODING_USE] Indicate in the response the character encoding being used.
[W3C ERROR_MESSAGES] Provide informative error messages and a means of navigating away from an error message back to useful information.
[W3C COOKIES] Do not rely on cookies being available.
[W3C CACHING] Provide caching information in HTTP responses.
[W3C FONTS] Do not rely on support of font related styling.
[W3C MINIMIZE_KEYSTROKES] Keep the number of keystrokes to a minimum.
[W3C AVOID_FREE_TEXT] Avoid free text entry where possible.
[W3C PROVIDE_DEFAULTS] Provide pre-selected default values where possible.
[W3C DEFAULT_INPUT_MODE] Specify a default text entry mode, language and/or input format, if the target device is known to support it.
[W3C TAB_ORDER] Create a logical order through links, form controls and objects.
[W3C CONTROL_LABELLING] Label all controls appropriately and explicitly associate labels with controls.
[W3C CONTROL_POSITION] Position labels so they lay out properly in relation to the controls they refer to.