You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

README.md 7.5 KiB

4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. require-css
  2. ===========
  3. RequireJS CSS requiring and optimization, with almond support.
  4. Useful for writing modular CSS dependencies alongside scripts.
  5. For LESS inclusion, use [require-less](https://github.com/guybedford/require-less), which behaves and builds the css exactly like this module apart from the preprocessing step.
  6. <a href="https://www.gittip.com/guybedford/"><img src="http://img.shields.io/gittip/guybedford.svg" /></a>
  7. Overview
  8. --------
  9. Allows the construction of scripts that can require CSS, using the simple RequireJS syntax:
  10. ```javascript
  11. define(['css!styles/main'], function() {
  12. //code that requires the stylesheet: styles/main.css
  13. });
  14. ```
  15. Fully compatible in IE 6+, Chrome 3+, Firefox 3.5+, Opera 10+, iOS.
  16. * **CSS builds** When run as part of a build with the RequireJS optimizer, `css!` dependencies are automatically inlined into the built layer within the JavaScript, fully compatible with layering. CSS injection is performed as soon as the layer is loaded.
  17. * **Option to build separate layer CSS files** A `separateCSS` build parameter allows for built layers to output their css files separately, instead of inline with the JavaScript, for manual inclusion.
  18. * **CSS compression** CSS redundancy compression is supported through the external library, [csso](https://github.com/css/csso).
  19. Installation and Setup
  20. ----------------------
  21. Download the require-css folder manually or use Bower:
  22. ```bash
  23. bower install require-css
  24. ```
  25. To allow the direct `css!` usage, add the following [map configuration](http://requirejs.org/docs/api.html#config-map) in RequireJS:
  26. ```javascript
  27. map: {
  28. '*': {
  29. 'css': 'require-css/css' // or whatever the path to require-css is
  30. }
  31. }
  32. ```
  33. Use Cases and Benefits
  34. ----------------------
  35. ### Motivation
  36. The use case for RequireCSS came out of a need to manage templates and their CSS together.
  37. The idea being that a CSS require can be a dependency of the code that dynamically renders a template.
  38. When writing a large dynamic application, with templates being rendered on the client-side, it can be beneficial to inject the CSS as templates are required instead
  39. of dumping all the CSS together separately. The added benefit of this is then being able to build the CSS naturally with the RequireJS optimizer,
  40. which also supports [separate build layers](http://requirejs.org/docs/1.0/docs/faq-optimization.html#priority) as needed.
  41. ### Script-inlined CSS Benefits
  42. By default, during the build CSS is compressed and inlined as a string within the layer that injects the CSS when run.
  43. If the layer is included as a `<script>` tag, only one browser request is needed instead of many separate CSS requests with `<link>` tags.
  44. Even better than including a layer as a `<script>` tag is to include the layer dynamically with a non-blocking require.
  45. Then the page can be displayed while the layer is still loading asynchronously in the background.
  46. In this case, the CSS that goes with a template being dynamically rendered is loaded with that same script asynchronously.
  47. No longer does it need to sit in a `<link>` tag that blocks the page display unnecessarily.
  48. Modular CSS
  49. -----------
  50. RequireCSS implies a CSS modularisation where styles can be scoped directly to the render code that they are bundled with.
  51. Just like JS requires, the order of CSS injection can't be guaranteed. The idea here is that whenever there are style overrides, they should
  52. be based on using a more specific selector with an extra id or class at the base, and not assuming a CSS load order. Reset and global styles are a repeated dependency of all
  53. modular styles that build on top of them.
  54. Optimizer Configuration
  55. -----------------------
  56. ### Basic Usage
  57. Optimizer configuration:
  58. ```javascript
  59. {
  60. modules: [
  61. {
  62. name: 'mymodule',
  63. exclude: ['css/normalize']
  64. }
  65. ]
  66. }
  67. ```
  68. If the contents of 'mymodule' are:
  69. ```javascript
  70. define(['css!style', 'css!page'], function(css) {
  71. //...
  72. });
  73. ```
  74. Then the optimizer output would be:
  75. -mymodule.js containing:
  76. style.css and page.css which will be dynamically injected
  77. The `css/normalize` exclude is needed due to [r.js issue #289](https://github.com/jrburke/r.js/issues/289)
  78. ### Separate File Output
  79. To output the CSS to a separate file, use the configuration:
  80. ```javascript
  81. {
  82. separateCSS: true,
  83. modules: [
  84. {
  85. name: 'mymodule'
  86. }
  87. ]
  88. }
  89. ```
  90. This will then output all the css to the file `mymodule.css`. This configuration can also be placed on the module object itself for layer-specific settings.
  91. Optimization is fully compatible with exclude and include.
  92. ### IE8 and 9 Selector Limit
  93. In IE9 and below, there is a maximum limit of 4095 selectors per stylesheet.
  94. In order to avoid this limit, CSS concatenation can be disabled entirely with the `IESelectorLimit` option.
  95. ```javascript
  96. {
  97. IESelectorLimit: true,
  98. modules: [
  99. {
  100. name: 'mymodule'
  101. }
  102. ]
  103. }
  104. ```
  105. Ideally build layers would avoid this limit entirely by naturally being designed to not reach it. This option is really only as a fix when nothing else
  106. is possible as it will degrade injection performance.
  107. This option is also not compatible with the `separateCSS` option.
  108. ### Excluding the CSS Module in Production
  109. When dynamic CSS requires are not going to be made in production, a minimal version of RequireCSS can be written by setting a pragma for the build:
  110. ```javascript
  111. {
  112. pragmasOnSave: {
  113. excludeRequireCss: true
  114. }
  115. }
  116. ```
  117. ### siteRoot Configuration
  118. When building the CSS, all URIs are renormalized relative to the site root.
  119. It assumed that the siteRoot matches the build directory in this case.
  120. If this is different, then specify the server path of the siteRoot relative to the baseURL in the configuration.
  121. For example, if the site root is `www` and we are building the directory `www/lib`, we would use the configuration:
  122. ```javascript
  123. {
  124. appDir: 'lib',
  125. dir: 'lib-built',
  126. siteRoot: '../',
  127. modules: [
  128. {
  129. name: 'mymodule'
  130. }
  131. ]
  132. }
  133. ```
  134. ### Almond Configuration
  135. Almond doesn't support the `packages` configuration option. When using Almond, rather configuration RequireCSS with map configuration instead, by including the following configuration in the production app:
  136. ```javascript
  137. requirejs.config({
  138. map: {
  139. '*': {
  140. css: 'require-css/css'
  141. }
  142. }
  143. });
  144. ```
  145. ### Disabling the Build
  146. To disable any CSS build entirely, use the configuration option `buildCSS`:
  147. ```javascript
  148. {
  149. buildCSS: false,
  150. modules: [
  151. {
  152. name: 'mymodule'
  153. }
  154. ]
  155. }
  156. ```
  157. CSS requires will then be left in the source "as is". This shouldn't be used with `stubModules`.
  158. CSS Compression
  159. ---------------
  160. CSS compression is supported with [csso](https://github.com/css/csso).
  161. To enable the CSS compression, install csso with npm:
  162. ```
  163. npm install csso -g
  164. ```
  165. The build log will display the compression results.
  166. When running the r.js optimizer through NodeJS, sometimes the global module isn't found. In this case install csso as a local node module so it can be found.
  167. Injection methods
  168. -----------------
  169. When loading a CSS file or external CSS file, a `<link>` tag is used. Cross-browser support comes through a number of careful browser conditions for this.
  170. If CSS resources such as images are important to be loaded first, these can be added to the require through a loader plugin that can act as a preloader such as [image](https://github.com/millermedeiros/requirejs-plugins) or [font](https://github.com/millermedeiros/requirejs-plugins). Then a require can be written of the form:
  171. ```javascript
  172. require(['css!my-css', 'image!preload-background-image.jpg', 'font!google,families:[Tangerine]']);
  173. ```
  174. License
  175. ---
  176. MIT