Icard/angular-clarity-master(work.../node_modules/get-css-data/README.md

386 lines
12 KiB
Markdown

# get-css-data
[![NPM](https://img.shields.io/npm/v/get-css-data.svg?style=flat-square)](https://www.npmjs.com/package/get-css-data)
[![GitHub Workflow Status (master)](https://img.shields.io/github/actions/workflow/status/jhildenbiddle/get-css-data/test.yml?branch=master&label=checks&style=flat-square)](https://github.com/jhildenbiddle/get-css-data/actions?query=branch%3Amaster+)
[![Codacy code quality](https://img.shields.io/codacy/grade/ec8f2d2595804ab38ad138b762a640e6/master?style=flat-square)](https://app.codacy.com/gh/jhildenbiddle/get-css-data/dashboard?branch=master)
[![Codacy branch coverage](https://img.shields.io/codacy/coverage/ec8f2d2595804ab38ad138b762a640e6/master?style=flat-square)](https://app.codacy.com/gh/jhildenbiddle/get-css-data/dashboard?branch=master)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg?style=flat-square)](https://github.com/jhildenbiddle/get-css-data/blob/master/LICENSE)
[![Sponsor this project](https://img.shields.io/static/v1?style=flat-square&label=Sponsor&message=%E2%9D%A4&logo=GitHub&color=%23fe8e86)](https://github.com/sponsors/jhildenbiddle)
A micro-library for collecting stylesheet data from link and style nodes.
## Features
- Collects CSS data from `<link>` and `<style>` nodes
- Collects static [Node.textContent](https://developer.mozilla.org/en-US/docs/Web/API/Node/textContent) or live [CSS Object Model (CSSOM)](https://developer.mozilla.org/en-US/docs/Web/API/CSS_Object_Model) data
- Returns CSS data as a concatenated string and a DOM-ordered array of strings
- Allows document, iframe, and [shadow DOM](https://developer.mozilla.org/en-US/docs/Web/Web_Components/Using_shadow_DOM) traversal
- Handles `@import` rules
- Handles absolute and relative URLs
- Inspect, modify and/or filter CSS data from each node
- Modify XHR object before each request
- UMD and ES6 modules available
- Compatible with modern and legacy browsers (IE9+)
- Lightweight (less than 1.5k min+gzip) and dependency-free
## Installation
NPM:
```shell
npm install get-css-data --save
```
```javascript
// file.js
import getCssData from 'get-css-data';
getCssData({
onComplete: function(cssText, cssArray, nodeArray) {
// Do stuff...
}
});
```
Git:
```bash
git clone https://github.com/jhildenbiddle/get-css-data.git
```
CDN ([jsdelivr.com](https://www.jsdelivr.com/) shown, also on [unpkg.com](https://unpkg.com/)):
```html
<!-- ES5 (latest v2.x.x) -->
<script src="https://cdn.jsdelivr.net/npm/get-css-data@2"></script>
<script>
getCssData({
onComplete: function(cssText, cssArray, nodeArray) {
// Do stuff...
}
});
</script>
```
```html
<!-- ES6 module (latest v2.x.x) -->
<script type="module">
import getCssData from 'https://cdn.jsdelivr.net/npm/get-css-data@2/dist/get-css-data.esm.min.js';
getCssData({
onComplete(cssText, cssArray, nodeArray) {
// Do stuff...
}
});
</script>
```
## Example
HTML:
```html
<!-- file.html -->
<head>
<link rel="stylesheet" href="style1.css">
<style>
@import "style2.css";
p { color: blue; }
</style>
</head>
```
CSS:
```css
/* style1.css */
p { color: red; }
```
```css
/* style2.css */
p { color: green; }
```
JavaScript (see [Options](#options) for details)
```javascript
getCssData({
onComplete: function(cssText, cssArray, nodeArray) {
console.log(cssText); // 1
console.log(cssArray); // 2
console.log(nodeArray); // 3
}
});
// 1 => 'p { color: red; } p { color: green; } p { color: blue; }'
// 2 => ['p { color: red; }', 'p { color: green; } p { color: blue; }']
// 3 => [<linkElement>, <styleElement>]
```
## Options
<!-- no toc -->
- [rootElement](#optionsrootelement)
- [include](#optionsinclude)
- [exclude](#optionsexclude)
- [filter](#optionsfilter)
- [skipDisabled](#optionsskipdisabled)
- [useCSSOM](#optionsusecssom)
- [onBeforeSend](#optionsonbeforesend)
- [onSuccess](#optionsonsuccess)
- [onError](#optionsonerror)
- [onComplete](#optionsoncomplete)
**Example**
```javascript
// Default values shown
getCssData({
rootElement : document,
include : 'link[rel=stylesheet],style',
exclude : '',
filter : '',
skipDisabled: true,
useCSSOM : false,
onBeforeSend: function(xhr, node, url) {
// ...
},
onSuccess: function(cssText, node, url) {
// ...
},
onError: function(xhr, node, url) {
// ...
},
onComplete: function(cssText, cssArray, nodeArray) {
// ...
}
});
```
### options.rootElement
- Type: `object`
- Default: `document`
Root element to traverse for `<link>` and `<style>` nodes.
**Examples**
```javascript
// Document
getCssData({
rootElement: document // default
});
// Iframe (must be same domain with content loaded)
getCssData({
rootElement: (myIframe.contentDocument || myIframe.contentWindow.document)
});
// Shadow DOM
getCssData({
rootElement: myElement.shadowRoot
});
```
### options.include
- Type: `string`
- Default: `"link[rel=stylesheet],style"`
CSS selector matching `<link>` and `<style>` nodes to collect data from. The default value includes all style and link nodes.
**Example**
```javascript
getCssData({
// Include only <link rel="stylesheet"> nodes
// with an href that does not contains "bootstrap"
include: 'link[rel=stylesheet]:not([href*=bootstrap])',
});
```
### options.exclude
- Type: `string`
CSS selector matching `<link>` and `<style>` nodes to exclude from those matched by [options.include](#optionsinclude).
**Example**
```javascript
getCssData({
// Of matched `include` nodes, exclude any node
// with an href that contains "bootstrap"
exclude: '[href*=bootstrap]',
});
```
### options.filter
- Type: `object`
Regular expression used to filter node CSS data. Each block of CSS data is tested against the filter, and only matching data is processed.
**Example**
```javascript
getCssData({
// Test each block of CSS for the existence
// of ".myclass". If found, process the CSS.
// If not, ignore the CSS.
filter: /\.myclass/,
});
```
### options.skipDisabled
- Type: `boolean`
- Default: `true`
Determines if disabled stylesheets will be skipped while collecting CSS data.
**Example**
```javascript
getCssData({
skipDisabled: true // default
});
```
### options.useCSSOM
- Type: `boolean`
- Default: `false`
Determines how CSS data will be collected from `<style>` nodes.
When `false`, static CSS data is collected by reading each node's [textContent](https://developer.mozilla.org/en-US/docs/Web/API/Node/textContent) value. This method is fast, but the data collected will not reflect changes made using the [`deleteRule()`](https://developer.mozilla.org/en-US/docs/Web/API/CSSStyleSheet/deleteRule) or [`insertRule()`](https://developer.mozilla.org/en-US/docs/Web/API/CSSStyleSheet/insertRule) methods. When `true`, live CSS data is collected by iterating over each node's [`CSSRuleList`](https://developer.mozilla.org/en-US/docs/Web/API/CSSRuleList) and concatenating all [`CSSRule.cssText`](https://developer.mozilla.org/en-US/docs/Web/API/CSSRule/cssText) values into a single string. This method is slower, but the data collected accurately reflects all changes made to the stylesheet.
Keep in mind that browsers often drop unrecognized selectors, properties, and values when parsing static CSS. For example, Chrome/Safari will drop declarations with Mozilla's `-moz-` prefix, while Firefox will drop declarations with Chrome/Safari's `-webkit` prefix . This means that data collected when this options is set to `true` will likely vary between browsers and differ from the static CSS collected when it is set to `false`.
**Example**
```javascript
getCssData({
useCSSOM: false // default
});
```
### options.onBeforeSend
- Type: `function`
- Arguments:
1. **xhr**: The XHR `object` containing details of the request
2. **node**: The source node `object` reference
3. **url**: The source URL `string` (`<link>` href or `@import` url)
Callback before each [XMLHttpRequest](https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest) (XHR) is sent. Allows modifying the XML object by setting properties, calling methods, or adding event handlers.
**Example**
```javascript
getCssData({
onBeforeSend: function(xhr, node, url) {
// Domain-specific XHR settings
if (/some-domain.com/.test(url)) {
xhr.withCredentials = true;
xhr.setRequestHeader("foo", "1");
xhr.setRequestHeader("bar", "2");
}
}
});
```
### options.onSuccess
- Type: `function`
- Arguments:
1. **cssText**: A `string` of CSS text from `node` and `url`
1. **node**: The source node `object` reference
1. **url**: The source URL `string` (`<link>` href, `@import` url, or page url for `<style>` data)
Callback after CSS data has been collected from each node. Allows modifying the CSS data before it is added to the final output by returning any `string` value or skipping the CSS data by returning `false` or an empty string (`""`).
Note that the order in which `<link>` and `@import` CSS data is "successfully" collected (thereby triggering this callback) is not guaranteed as these requests are asynchronous. To access CSS data in DOM order, use the `cssArray` argument passed to the [options.oncomplete](#optionsoncomplete) callback.
**Example**
```javascript
getCssData({
onSuccess: function(cssText, node, url) {
// Replace all instances of "color: red" with "color: blue"
const newCssText = cssText.replace(/color:\s*red\s;/g, 'color: blue;');
return newCssText;
}
});
```
### options.onError
- Type: `function`
- Arguments:
1. **xhr**: The XHR `object` containing details of the request
2. **node**: The source node `object` reference
3. **url**: The source URL `string` (`<link>` href or `@import` url)
Callback after `<link>` or `@import` request has failed or when
`xhr.responseText` appears to be HTML instead of CSS.
**Example**
```javascript
getCssData({
onError: function(xhr, node, url) {
console.log(xhr.status); // 1
console.log(xhr.statusText); // 2
}
});
// 1 => '404'
// 2 => 'Not Found'
```
### options.onComplete
- Type: `function`
- Arguments:
1. **cssText**: A `string` of concatenated CSS text from all nodes in DOM order.
1. **cssArray**: An `array` of per-node CSS text in DOM order. The node containing each CSS text block is available at the same **nodeArray** index.
1. **nodeArray**: An `array` of processed `<style>` and `<link>` nodes in DOM order. The CSS text for each node is available at the same **cssArray** index.
Callback after CSS data has been collected from all nodes.
**Example**
```javascript
getCssData({
onComplete: function(cssText, cssArray, nodeArray) {
// ...
}
});
```
## Sponsorship
A [sponsorship](https://github.com/sponsors/jhildenbiddle) is more than just a way to show appreciation for the open-source authors and projects we rely on; it can be the spark that ignites the next big idea, the inspiration to create something new, and the motivation to share so that others may benefit.
If you benefit from this project, please consider lending your support and encouraging future efforts by [becoming a sponsor](https://github.com/sponsors/jhildenbiddle).
Thank you! 🙏🏻
## Contact & Support
- Follow 👨🏻‍💻 **@jhildenbiddle** on [Twitter](https://twitter.com/jhildenbiddle) and [GitHub](https://github.com/jhildenbiddle) for announcements
- Create a 💬 [GitHub issue](https://github.com/jhildenbiddle/get-css-data/issues) for bug reports, feature requests, or questions
- Add a ⭐️ [star on GitHub](https://github.com/jhildenbiddle/get-css-data) and 🐦 [tweet](https://twitter.com/intent/tweet?url=https%3A%2F%2Fgithub.com%2Fjhildenbiddle%2Fget-css-data&hashtags=css,developers,frontend,javascript) to promote the project
- Become a 💖 [sponsor](https://github.com/sponsors/jhildenbiddle) to support the project and future efforts
## License
This project is licensed under the MIT License. See the [LICENSE](https://github.com/jhildenbiddle/get-css-data/blob/master/LICENSE) for details.
Copyright (c) John Hildenbiddle ([@jhildenbiddle](https://twitter.com/jhildenbiddle))