Fluent React - Helion
ISBN: 9781098138677
stron: 336, Format: ebook
Data wydania: 2024-02-14
Księgarnia: Helion
Cena książki: 211,65 zł (poprzednio: 246,10 zł)
Oszczędzasz: 14% (-34,45 zł)
When it comes to building user interfaces on the web, React enables web developers to unlock a new world of possibilities. This practical book helps you take a deep dive into fundamental concepts of this JavaScript library, including JSX syntax and advanced patterns, the virtual DOM, React reconciliation, and advanced optimization techniques. By becoming fluent in React, you'll quickly learn how to build better web applications.
Author Tejas Kumar helps you explore the depths of React in plain English, without the typical software engineering jargon, so you can more easily understand how this JavaScript library works. You'll learn how to write intuitive React code that fully understands the nuances and layers of React, unlocking a whole new level of fluency.
You will:
- Understand how React works at a deeper level
- Write React apps while optimizing them along the way
- Build resilient React applications that work well at arbitrary scale
- Create React applications for other platforms adjacent to the web and mobile devices
- Know when to reach for different mechanisms exposed by React, such as reducers versus state versus refs
Osoby które kupowały "Fluent React", wybierały także:
- Windows Media Center. Domowe centrum rozrywki 66,67 zł, (8,00 zł -88%)
- Ruby on Rails. Ćwiczenia 18,75 zł, (3,00 zł -84%)
- Przywództwo w świecie VUCA. Jak być skutecznym liderem w niepewnym środowisku 58,64 zł, (12,90 zł -78%)
- Scrum. O zwinnym zarządzaniu projektami. Wydanie II rozszerzone 58,64 zł, (12,90 zł -78%)
- Od hierarchii do turkusu, czyli jak zarządzać w XXI wieku 58,64 zł, (12,90 zł -78%)
Spis treści
Fluent React eBook -- spis treści
- Foreword
- Preface
- Conventions Used in This Book
- OReilly Online Learning
- How to Contact Us
- Acknowledgments
- 1. The Entry-Level Stuff
- Why Is React a Thing?
- The World Before React
- jQuery
- Backbone
- The MVC pattern
- KnockoutJS
- MVVM pattern
- AngularJS
- Two-way data binding
- Modular architecture
- Dependency injection
- Comparison with Backbone.js and Knockout.js
- AngularJS trade-offs
- Enter React
- Reacts Value Proposition
- Declarative versus imperative code
- The virtual DOM
- The component model
- Immutable state
- Releasing React
- The Flux Architecture
- Benefits of the Flux Architecture
- Reacts Value Proposition
- Wrap-Up: SoWhy Is React a Thing?
- Chapter Review
- Review Questions
- Up Next
- 2. JSX
- JavaScript XML?
- Benefits of JSX
- Drawbacks of JSX
- Under the Hood
- How Does Code Work?
- Extending JavaScript Syntax with JSX
- The JSX Pragma
- Expressions
- Chapter Review
- Review Questions
- Up Next
- 3. The Virtual DOM
- An Intro to the Virtual DOM
- The Real DOM
- Pitfalls of the Real DOM
- Performance
- Cross-browser compatibility
- Document Fragments
- Pitfalls of the Real DOM
- How the Virtual DOM Works
- React Elements
- Virtual DOM Versus Real DOM
- Efficient Updates
- Unnecessary rerenders
- Chapter Review
- Review Questions
- Up Next
- 4. Inside Reconciliation
- Understanding Reconciliation
- Batching
- Prior Art
- Stack Reconciler (Legacy)
- The Fiber Reconciler
- Fiber as a Data Structure
- Double Buffering
- Fiber Reconciliation
- The render phase
- beginWork
- completeWork
- The commit phase
- The mutation phase
- The layout phase
- Effects
- Putting everything on the screen
- The render phase
- Chapter Review
- Review Questions
- Up Next
- 5. Common Questions and Powerful Patterns
- Memoization with React.memo
- Getting Fluent in React.memo
- Memoized Components That Still Rerender
- Scalars (primitive types)
- Nonscalars (reference types)
- Its a Guideline, Not a Rule
- Memoization with useMemo
- useMemo Considered Harmful
- Forget About All of This
- Lazy Loading
- Greater UI Control with Suspense
- useState Versus useReducer
- Immer and Ergonomics
- Powerful Patterns
- Presentational/Container Components
- Higher-Order Component
- Composing HOCs
- HOCs versus hooks
- Render Props
- Children as a function
- Control Props
- Prop Collections
- Prop getters
- Compound Components
- State Reducer
- Chapter Review
- Review Questions
- Up Next
- Memoization with React.memo
- 6. Server-Side React
- Limitations of Client-Side Rendering
- SEO
- Performance
- Security
- The Rise of Server Rendering
- Benefits of Server Rendering
- Hydration
- Hydration Considered Harmful
- Creating Server Rendering
- Manually Adding Server Rendering to a Client-Only React App
- Hydrating
- Server Rendering APIs in React
- renderToString
- Usage
- How it works
- Disadvantages
- renderToPipeableStream
- How it works
- Node.js streams
- Reacts renderToPipeableStream
- Features of renderToPipeableStream
- How it fits
- How it works
- renderToReadableStream
- When to Use What
- renderToString
- Dont Roll Your Own
- Chapter Review
- Review Questions
- Up Next
- Limitations of Client-Side Rendering
- 7. Concurrent React
- The Problem with Synchronous Rendering
- Revisiting Fiber
- Scheduling and Deferring Updates
- Diving Deeper
- The Scheduler
- Render Lanes
- How Render Lanes Work
- Processing Lanes
- Commit Phase
- useTransition
- Simple Example
- Advanced Example: Navigation
- Diving Deeper
- useDeferredValue
- Purpose of useDeferredValue
- When to Use useDeferredValue
- When Not to Use useDeferredValue
- Problems with Concurrent Rendering
- Tearing
- useSyncExternalStore
- Tearing
- Chapter Review
- Review Questions
- Up Next
- 8. Frameworks
- Why We Need a Framework
- Server Rendering
- Routing
- Data Fetching
- Benefits of Using a Framework
- Trade-Offs of Using a Framework
- Popular React Frameworks
- Remix
- A basic Remix application
- Server rendering
- Routing
- Data fetching
- Mutating data
- Next.js
- Server rendering
- Routing
- Data fetching
- Mutating data
- Remix
- Choosing a Framework
- Understanding Your Project Needs
- Next.js
- Remix
- Trade-Offs
- Developer Experience
- Runtime Performance
- Chapter Review
- Review Questions
- Up Next
- Why We Need a Framework
- 9. React Server Components
- Benefits
- Server Rendering
- Under the Hood
- Serialization
- Navigation
- Making Updates
- Under the hood
- Nuance
- Under the Hood
- Rules of Server Components
- Serializability Is King
- No Effectful Hooks
- State Is Not State
- Client Components Cannot Import Server Components
- Client Components Are Not Bad
- Server Actions
- Forms and Mutations
- Outside of Forms
- The Future of React Server Components
- Chapter Review
- Review Questions
- Up Next
- 10. React Alternatives
- Vue.js
- Signals
- Simplicity
- Angular
- Change Detection
- Signals
- Svelte
- Runes
- Runtime reactivity
- Signal boost
- Runes
- Solid
- Qwik
- Common Patterns
- Component-Based Architecture
- Declarative Syntax
- Updates
- Lifecycle Methods
- Ecosystem and Tooling
- React Is Not Reactive
- Example 2: Dependent Values
- The Future of React
- React Forget
- Forget versus signals
- React Forget
- Chapter Review
- Review Questions
- Up Next
- Vue.js
- 11. Conclusion
- Takeaways
- Our Timeline
- The Mechanics Behind the Magic
- Advanced Adventures
- Staying Up-to-Date
- Index