「React 系列 Workshop 01」之 Atomic Design with React
nodeppt start -w
by ksky521/nodePPT
[slide]
Atomic Design with React
Total Time: 2 hours
via JimmyLv
[slide]
0. 💻 Env Setup
- reminder/reading material in invitation mail
- join wechat group to share info easily
git clone git@github.com:JimmyLv/atomic-design-react-workshop.git
cd atomic-design-react-workshop
yarn install && yarn start
[slide]
🐵 唠嗑唠嗑
- 不讲什么:Webpack/ES6/Styling/Linter
- 脚手架:
create-react-app
&react-app-stencil
- 观念在先,实战为王 🔨
- Pair Programming 👬
- Parking Lot 🅿️
[slide]
⏲️ Agenda
- Atomic Design (15 mins)
- React Basic: FP、JSX、V-DOM (25 mins)
- Component-Driven Development (20 mins)
- Component’s State & Lifecycle (20 mins)
- Refactoring to ES6+ (remaining times…)
[slide]
1. 🏗️ Atomic Design (15 mins)
[slide]
What’s Atomic Design?
data:image/s3,"s3://crabby-images/d6c1d/d6c1d6735575c9e277b63d27b007bb431abf216b" alt=""
demo: [Pattern Lab | Build Atomic Design Systems](http://patternlab.io/) |
[slide]
🔨 Practice 01
[slide]
🌲 Components Tree
data:image/s3,"s3://crabby-images/41a81/41a81c015b209670233792881695b6a1807b3449" alt=""
[slide]
💡 Rethink?
- Presentational components
- Container components
- Transactional components
- Micro Front-Ends
[slide]
data:image/s3,"s3://crabby-images/56a0d/56a0dc668e30cb553483d608adf5b369277faae3" alt=""
[slide]
2. 📖 React Basic (25 mins)
- JSX
- VirtualDOM
- Functional/Stateless Components
[slide]
data:image/s3,"s3://crabby-images/a91dc/a91dc6daaad076787a185a7f0b5780a5a962ebc0" alt=""
[slide]
🌲 DOM Tree -> Functions
function warn(msg) {
alert(msg)
}
function App(data) {
;(function Header(menu) {
;(function Menu(menu, func) {
;(function Text(text) {
return <li>{text}</li>
})(menu[0])(function Text(text) {
return <li onClick={() => func(text)}>{text}</li>
})(menu[1])
})(menu, warn)
})(data.menu)(function Content(content) {
return <section>{content}</section>
})(data.content)(function Footer() {
return <footer>I am footer!</footer>
})()
}
[slide]
JSX (XML in JavaScript)
In
function Profile(props) {
return (
<div>
<img src="avatar.png" className="profile" />
<h3>{props.title}</h3>
</div>
)
}
Out
function Profile(props) {
return React.createElement(
'div',
null,
React.createElement('img', { src: 'avatar.png', className: 'profile' }),
React.createElement('h3', null, props.title),
)
}
[slide]
Virtual DOM
function DeleteAccount() {
return ({
type: 'div',
props: {
children: [{
type: 'p',
props: {
children: 'Are you sure?'
}
}, {
type: Button,
props: {
type: 'danger',
children: 'Yep'
}
}, {
type: Button,
props: {
color: 'blue',
children: 'Cancel'
}
}]
})
}
[slide]
data:image/s3,"s3://crabby-images/20de7/20de7c8123365d49eec16d763c96c69925b9bd9f" alt=""
[slide]
data:image/s3,"s3://crabby-images/a4ef7/a4ef759aa8516151fb744351587d5298f11a11a8" alt=""
[slide]
() => Virtual DOM Objects
function DeleteAccount() {
return ({
type: 'div',
props: {
children: [{
type: 'p',
props: {
children: 'Are you sure?'
}
}, {
type: Button,
props: {
type: 'danger',
children: 'Yep'
}
}, {
type: Button,
props: {
color: 'blue',
children: 'Cancel'
}
}]
})
}
[slide]
Functional/Stateless Components
const DeleteAccount = (props) => (
<div>
<p>Are you sure?</p>
<Button type="danger">Yep</Button>
<Button color="blue">Cancel</Button>
</div>
)
[slide]
3. 🏃 CDD (20 mins)
“Visual TDD”: Component-Driven Development
[slide]
Component-Driven Development
data:image/s3,"s3://crabby-images/9bc62/9bc62efc2f32044ffc3abf99d235052aa6b47cf9" alt=""
- Focus development {:&.moveIn}
- Increase UI coverage
- Target feedback
- Build a component library
- Parallelize development
- Test visually
[slide]
data:image/s3,"s3://crabby-images/46c13/46c1354d1ce765ce5b3226ca0f29757ca7e03b4e" alt=""
[note]tdd components,即 data 如何对应到 view; tdd business logic,即 event 如何对应到 state[/note]
[slide]
Storybook
data:image/s3,"s3://crabby-images/6fea9/6fea97200a3e295786f5e935ec9a2a57c702934f" alt=""
[slide]
🔨 Practice 02
data:image/s3,"s3://crabby-images/b42e5/b42e596da9e45438c46af439e223dc1e8c06a7d4" alt=""
- type:
primary
default
danger
dashed
- color:
blue
,white
,red
,border
- onClick:
console.info()
,alert()
[slide]
data:image/s3,"s3://crabby-images/3f78f/3f78f6dcf2dce6284789a2ae380bc5468ec55fe3" alt=""
[slide]
4. 🐒 State & Lifecycle (20 mins)
[slide]
React.Component
class Contacts extends React.Component {
constructor(props) {
super(props)
this.state = {}
}
handleClick(e) {
console.log(this) // React Component instance
}
render() {
return <button onClick={(e) => this.handleClick(e)}></button>
}
}
export default Contacts
[slide]
Lifecycle
data:image/s3,"s3://crabby-images/3d0e0/3d0e002bf51ecaa2d2265d82ef7ec9700708b792" alt=""
[slide]
🔨 Practice 03
Clock component: new Date().toLocaleTimeString(locales,options)
with timeZone
[slide]
State vs Props
data:image/s3,"s3://crabby-images/1b72a/1b72a555a34976f339fc7e740d31671dc15cfeb9" alt=""
[slide]
5. Refactoring to ES6+ (remaining times…)
[slide]
📑 Homework
data:image/s3,"s3://crabby-images/8cfcb/8cfcb35c99a108c6246d3356423121303ae90662" alt=""
[slide]