Description
In this talk, I will explore the underlying principles of style. I will introduce the different approaches used by different frameworks. Then I'll create an abstraction that manages to takes advantage of the rules we've learned before. This means that applying styles can be turned into a concern for the application and not the individual component. If we handle styles with this approach we do not need to treat them as a special dependency on our projects anymore.
Outline
1. Why is style a dependency?
I will give some examples of how styles are shipped today. This will be used to show how small decisions by library authors can turn into big burdens of application developers. I will then look at what the approaches have in common, where they differ, and how we can use that to our advantage.
2. How can we turn that around?
Given what we've learned in the beginning I'm going to sketch an API that can be used by components. We'll learn about some quirks and what we need to do in order to build a declarative API that matches the React paradigms.
3. Real-world example through substyle
In the last part, we're going to look at a real-world implementation - substyle
.
Based on an example application I'm going to change the styling approach for the page profoundly while maintaining a consistent look and feel.
This is intended to prove that the method can work and should encourage people to challenge how they think about styles after the talk.