JQuery Mobile explained

jQuery Mobile
Developer:The jQuery Team
Released:[1]
Latest Release Version:1.4.5
Latest Preview Version:1.5.0-rc1
Programming Language:JavaScript
Platform:See Mobile browser support
Genre:Mobile application framework
License:MIT[2]
Size:351 KB / 142 KB (minified) / 40 KB (minified, gzipped)

jQuery Mobile is a touch-optimized web framework (also known as a mobile framework), specifically a JavaScript library, developed by the jQuery project team. The development focuses on creating a framework compatible with many smartphones and tablet computers,[3] made necessary by the growing but heterogeneous tablet and smartphone market.[4] The jQuery Mobile framework is consistent with other mobile app frameworks[5] and platforms such as PhoneGap, Worklight,[6] etc.

As of October 7, 2021 jQuery Mobile has been deprecated.[7]

Features

(Source: from the jQuery Mobile website)

Example usage

$('div').on('tap', function(event));

$(document).ready(function);

A basic example

What follows is a basic jQuery Mobile project utilizing HTML5 semantic elements. It is important to link to the jQuery and jQuery Mobile JavaScript libraries, and stylesheet (the files can be downloaded and hosted locally, but it is recommended to link to the files hosted on the jQuery CDN).

A screen of the project is defined by a section HTML5 element, and data-role of page. Note that data-role is an example of the HTML5 data attribute, in this case being defined by jQuery Mobile. A page may have header and footer elements with data-role of header and footer, respectively. In between, there may be an article element, with a role of main and a class of ui-content. Lastly, a nav element, with data-role of navbar may be present.

One HTML document can contain more than one section element, and thus more than one screenful of content. This way it is only necessary to load one file which includes multiple pages of content. One page can link to another page within the same file by referencing the page's id attribute (e.g. href="#second").

In the example below, two other data- attributes are used. The data-theme attribute tells the browser what theme to render. The data-add-back-btn attribute adds a back button to the page if set to true.

Lastly, icons can be added to elements via the data-icon attribute. jQuery Mobile has fifty commonly-used icons built in.

A brief explanation of the Data Attributes used in this example:

data-role – Specifies the role of the element, such as header, content, footer, etc.

data-theme – Specifies which design theme to use for elements within a container. Can be set to: a or b.

data-position – Specifies whether the element should be fixed, in which case it will render at the top (for header) or bottom (for footer).

data-transition – Specifies one of ten built-in animations to use when loading new pages.

data-icon – Specifies one of fifty built-in icons that can be added to an element.

jQuery Mobile Example

Page 1 Header

Page 1 Footer

Page 2 Header

Example Page

Page 2 Footer

Theming

jQuery Mobile provides a theming framework that allows developers to customize color schemes and certain CSS aspects of UI features. Developers can use the jQuery Mobile ThemeRoller[8] application to customize these appearances and create branded experiences. After developing a theme in the ThemeRoller application, programmers can download a custom CSS file and include it in their project to use their custom theme.[9]

Each theme can contain up to 26 unique color "swatches," each of which consists of a header bar, content body, and button states. Combining different swatches allows developers to create a wider range of visual effects than they would be able to with just one swatch per theme. Switching between different swatches within a theme is as simple as adding an attribute called "data-theme" to HTML elements.

The default jQuery Mobile theme comes with two different color swatches, named "a" and "b". Here is an example of how to create a toolbar with the "b" swatch:

Page Title

(Source: from the jQuery Mobile website)

There are already a handful of open source style themes that are developed and supported by third-party organizations. One such open source style theme is the Metro style theme that was developed and released by Microsoft Open Technologies, Inc.[10] The Metro style theme is meant to mimic the UI of the Metro (design language) that Microsoft uses in its mobile operating systems.

Mobile browser support

PlatformVersionNativePhone GapOpera MobileOpera MiniFennecOzoneNet front
0.98.5, 8.659.5104.05.01.01.1*0.94.0
iOSv2.2.1
v3.1.3, v3.2
v4-7.0
Symbian S60v3.1, v3.2
v5.0
Symbian UIQv3.0, v3.1
v3.2
Symbian Platformv.3.0
BlackBerry OSv4.5
v4.6, v4.7
v5.0
v6.0
Androidv1.5, v1.6
v2.1
v2.2
Windows Mobilev6.1
v6.5.1
v7.0
webOS1.4.1
bada1.0
Maemo5.0
MeeGo1.1*

Key:

(Source: from the jQuery Mobile website)

See also

Further reading

External links

Notes and References

  1. Web site: jQuery Foundation - jquerymobile.com . jQuery Mobile Alpha 1 Released . blog.jquerymobile.com . 2010-10-16 . 2014-05-22.
  2. Web site: jQuery Foundation - jquery.org . jQuery Licensing Changes . Blog.jquery.com . 2012-09-10 . 2013-10-09.
  3. Web site: Mobile Graded Browser Support.
  4. Web site: The Global Rise of the Smartphone. 2011-04-27. 2018-06-17. https://web.archive.org/web/20180617042807/https://gigaom.com/2010/04/30/the-global-rise-of-the-smartphone/. dead.
  5. Web site: Resons why jQuery Mobile Is Suitable For Mobile Web App Development.
  6. Web site: IBM Worklight - United States . Worklight.com . 2013-10-09.
  7. Web site: jQuery maintainers continue modernization initiative with deprecation of jQuery Mobile. 6 December 2022. jQuery Blog.
  8. Web site: ThemeRoller.
  9. Web site: JQuery Mobile Theming Overview.
  10. Web site: More news from MS Open Tech: announcing the open source Metro style theme for jQuery Mobile. https://web.archive.org/web/20140816185609/http://blogs.msdn.com/b/interoperability/archive/2012/04/26/more-news-from-ms-open-tech-announcing-the-open-source-metro-style-theme.aspx . 2014-08-16 . dead.