Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/frontaid/natural-selection
CSS Boilerplate / Starter Kit: Collection of best-practice CSS selectors
https://github.com/frontaid/natural-selection
boilerplate css css-framework css-library framework selector
Last synced: 3 months ago
JSON representation
CSS Boilerplate / Starter Kit: Collection of best-practice CSS selectors
- Host: GitHub
- URL: https://github.com/frontaid/natural-selection
- Owner: frontaid
- License: mit
- Created: 2021-01-09T09:59:05.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2023-04-16T09:49:13.000Z (almost 2 years ago)
- Last Synced: 2024-08-02T09:27:39.948Z (6 months ago)
- Topics: boilerplate, css, css-framework, css-library, framework, selector
- Language: CSS
- Homepage:
- Size: 35.2 KB
- Stars: 186
- Watchers: 6
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- Awesome-CSS-Resources - Natural Selection: - practice CSS selectors. (Frameworks / Resources / N)
- fucking-awesome-css-frameworks - **Natural Selection** - Collection of best-practice CSS selectors. (Base / Reset / Normalize)
- awesome-css-frameworks - **Natural Selection** - Collection of best-practice CSS selectors. (Base / Reset / Normalize)
README
# Natural Selection
Natural Selection is a CSS framework without any styling at all.
It is just a collection of *selectors* that can be used to define *global* styles.
Natural Selection aims to provide a best-practice **CSS boilerplate** that can be used to start projects.
It tries to encourage semantic HTML and the handling of accessibility concerns.Natural Selection almost exclusively uses generic element, attribute, and pseudo-class selectors.
But there are also very few *opinionated* selectors that rely on classes.
See the comments in the CSS file for more information.
The selector grouping is loosely based on MDN's
[HTML elements reference](https://developer.mozilla.org/en-US/docs/Web/HTML/Element).
Ordering is roughly based on how common certain elements or element groups are.## Instructions
1. Download the [raw CSS](https://raw.githubusercontent.com/frontaid/natural-selection/main/boilerplate.css)
1. Move it into your code base
1. Evolve it according to your needs## Browser Compatibility
All modern browsers and almost all browsers still in use today should be more than capable of handling Natural Selection.
Natural Selection is mostly based on element, attribute, and pseudo-class selectors.
All of them have been in the CSS specifications for ages.
Though, there are some selectors that might not yet be widely supported.
In that case, Natural Selection provides ways to detect and/or overcome lacking browser support.## Contribute
Please create an issue when you have a suggestion.
Note that the goal of this project is to provide a useful and minimal boilerplate for global CSS styling.
It is *not* the goal to add every single element or every possible element/attribute/pseudo-class combination.## Questions and Answers
**Why is this called "Natural Selection"?**
This is a collection of CSS *selectors*.
And given the limited number of HTML elements and attributes, the list came about quite *naturally*.**What is element `X` used for?**
Please read MDN's
[HTML elements reference](https://developer.mozilla.org/en-US/docs/Web/HTML/Element).**What element(s) are matched by the selector `X`?**
Please read MDN's
[CSS selectors reference](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors).## Notable Omissions
### `div`, `span`
Both `div` and `span` are very generic. It does not really make sense to apply any *global* styling
to them. If it does make sense in your specific use case, just add them yourself.### Reset Buttons
[MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/reset):
"You should usually avoid including reset buttons in your forms. They're rarely useful, and are instead more likely to frustrate users who click them by mistake [...]."
Also refer to [WebAIM](https://webaim.org/techniques/forms/controls#button) or [Nielsen Norman Group](https://www.nngroup.com/articles/reset-and-cancel-buttons/).