mediahelpers.html 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1">
  6. <title>jQuery Mobile Docs - Responsive Layout Helpers</title>
  7. <link rel="stylesheet" href="../../jquery.mobile-1.0.1.min.css" />
  8. <link rel="stylesheet" href="../_assets/css/jqm-docs.css"/>
  9. <script src="../../jquery.js"></script>
  10. <script src="../../experiments/themeswitcher/jquery.mobile.themeswitcher.js"></script>
  11. <script src="../_assets/js/jqm-docs.js"></script>
  12. <script src="../../jquery.mobile-1.0.1.min.js"></script>
  13. </head>
  14. <body>
  15. <div data-role="page" class="type-interior">
  16. <div data-role="header" data-theme="f">
  17. <h1>Responsive Layout Helpers</h1>
  18. <a href="../../" data-icon="home" data-iconpos="notext" data-direction="reverse" class="ui-btn-right jqm-home">Home</a>
  19. </div><!-- /header -->
  20. <div data-role="content" data-theme="c">
  21. <div class="content-primary">
  22. <h2>Media Query Helper Classes</h2>
  23. <p class="ui-bar-e ui-body"><strong>Note: This feature was deprecated in beta, and removed in 1.0rc1. We recommend using CSS3 Media Queries instead.</strong> To support older versions of Internet Explorer, check out <a href="https://github.com/scottjehl/Respond">respond.js</a>, a fast &amp; lightweight polyfill for min/max-width CSS3 Media Queries.</p>
  24. <p class="ui-bar-e ui-body">If you still need this feature, you can find the code here: <a href="https://raw.github.com/jquery/jquery-mobile/38d7ad8848f00b0921bf4ae723f3ad199eb851c1/js/jquery.mobile.media.classes.js">jquery.mobile.media.classes.js</a></p>
  25. <p>jQuery Mobile adds classes to the <code>HTML</code> element that mimic browser orientation and common min/max-width CSS media queries. These classes are updated on load, resize and orientationchange, allowing you to key off these classes in your CSS, to create <a href="http://www.alistapart.com/articles/responsive-web-design/">responsive layouts</a> - even in browsers that don't support media queries! </p>
  26. <h3>Orientation Classes </h3>
  27. <p>The HTML element will always have a class of either <code>"portrait"</code> or <code>"landscape"</code>, depending on the orientation of the browser or device. You can utilize these in your CSS like this:</p>
  28. <pre>
  29. <code>
  30. .portrait {
  31. /* portrait orientation changes go here! */
  32. }
  33. .landscape {
  34. /* landscape orientation changes go here! */
  35. }
  36. </code>
  37. </pre>
  38. <h3>Min/Max Width Breakpoint Classes</h3>
  39. <p>By default, we create min and max breakpoint classes at the following widths: <code>320</code>,<code>480</code>,<code>768</code>,<code>1024</code>. These translate to classes that look like this: <code>"min-width-320px"</code>, <code>"max-width-480px"</code>, and are meant to be used as a replacement of (or in addition to) the media query equivalents they mimic.</p>
  40. <pre>
  41. <code>
  42. .myelement {
  43. float: none;
  44. }
  45. .min-width-480px .myelement {
  46. float: left;
  47. }
  48. </code>
  49. </pre>
  50. <p>Many plugins in jQuery Mobile leverage these width breakpoints. For example, form elements float beside their labels when the browser is wider than 480 pixels. The CSS to support this behavior for form text inputs looks like this:</p>
  51. <pre>
  52. <code>
  53. label.ui-input-text {
  54. display: block;
  55. }
  56. .min-width-480px label.ui-input-text {
  57. display: inline-block;
  58. }
  59. </code>
  60. </pre>
  61. <h3>Adding Width Breakpoints</h3>
  62. <p>To utilize width breakpoints of your own, jQuery Mobile exposes the <code>$.mobile.addResolutionBreakpoints </code> function, which accepts either a single number or array of numbers that will be added to the min/max breakpoints whenever they apply.</p>
  63. <pre>
  64. <code>
  65. //add a min/max class for 1200 pixel widths
  66. $.mobile.addResolutionBreakpoints(1200);
  67. //add min/max classes for 1200, and 1440 pixel widths
  68. $.mobile.addResolutionBreakpoints([1200, 1440]);
  69. </code>
  70. </pre>
  71. <h3>Running Media Queries</h3>
  72. <p>jQuery Mobile provides a function that allows you to test whether a particular CSS Media Query applies. Simple call <code>$.mobile.media()</code> and pass a media type or query. If the browser supports that type or query, and it currently applies, the function will return true. If not, it'll return false.</p>
  73. <pre>
  74. <code>
  75. //test for screen media type
  76. $.mobile.media("screen");
  77. //test a min-width media query
  78. $.mobile.media("screen and (min-width: 480px)");
  79. //test for iOS retina display
  80. $.mobile.media("screen and (-webkit-min-device-pixel-ratio: 2)");
  81. </code>
  82. </pre>
  83. </div><!--/content-secondary -->
  84. <div class="content-secondary">
  85. <div data-role="collapsible" data-collapsed="true" data-theme="b" data-content-theme="d">
  86. <h3>More in this section</h3>
  87. <ul data-role="listview" data-theme="c" data-dividertheme="d">
  88. <li data-role="list-divider">API</li>
  89. <li><a href="../../docs/api/globalconfig.html">Configuring defaults</a></li>
  90. <li><a href="../../docs/api/events.html">Events</a></li>
  91. <li><a href="../../docs/api/methods.html">Methods &amp; Utilities</a></li>
  92. <li data-theme="a"><a href="../../docs/api/mediahelpers.html">Responsive Layout</a></li>
  93. <li><a href="../../docs/api/data-attributes.html">Data attribute reference</a></li>
  94. <li><a href="../../docs/api/themes.html">Theme framework</a></li>
  95. </ul>
  96. </div>
  97. </div>
  98. </div><!-- /content -->
  99. <div data-role="footer" class="footer-docs" data-theme="c">
  100. <p>&copy; 2011-2012 The jQuery Project</p>
  101. </div>
  102. </div><!-- /page -->
  103. </body>
  104. </html>