Searching...
فارسی
EnglishEnglish
EspañolSpanish
简体中文Chinese
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
Developing Backbone.js Applications

Developing Backbone.js Applications

Building Better JavaScript Applications
توسط Addy Osmani 2012 371 صفحات
3.69
100+ امتیازها
گوش دادن
Try Full Access for 7 Days
Unlock listening & more!
Continue

نکات کلیدی

1. Backbone.js ساختاری برای برنامه‌های پیچیده جاوااسکریپت فراهم می‌کند

Backbone.js یک کتابخانه سبک جاوااسکریپت است که به کد سمت کاربر شما ساختار می‌بخشد.

سازماندهی و قابلیت نگهداری. Backbone.js راه‌حلی برای چالش ساخت برنامه‌های پیچیده جاوااسکریپت با ارائه یک چارچوب ساختاری فراهم می‌کند. این کتابخانه مفهوم مدل‌ها، نماها و مجموعه‌ها را معرفی می‌کند که به جداسازی نگرانی‌ها و سازماندهی منطقی کد کمک می‌کند. این ساختار مدیریت و نگهداری برنامه‌های بزرگ‌مقیاس را آسان‌تر می‌کند و احتمال ایجاد "کد اسپاگتی" که با گذشت زمان دشوار برای اشکال‌زدایی و گسترش می‌شود را کاهش می‌دهد.

انعطاف‌پذیری و مینیمالیسم. برخلاف چارچوب‌های بیشتر نظرگرا، Backbone.js مجموعه‌ای حداقلی از ابزارها و قراردادها را ارائه می‌دهد و به توسعه‌دهندگان آزادی می‌دهد تا معماری خود را بر روی پایه آن پیاده‌سازی کنند. این انعطاف‌پذیری Backbone را برای طیف گسترده‌ای از پروژه‌ها، از برنامه‌های کوچک تک‌صفحه‌ای تا سیستم‌های بزرگ سازمانی مناسب می‌سازد. اندازه کوچک کتابخانه (حدود 7.6 کیلوبایت فشرده و gzipped) به این معنی است که بار اضافی قابل توجهی به پروژه شما اضافه نمی‌کند و آن را به گزینه‌ای جذاب برای توسعه‌دهندگان حساس به عملکرد تبدیل می‌کند.

2. مدل‌ها، نماها و مجموعه‌ها هسته برنامه‌های Backbone را تشکیل می‌دهند

مدل‌ها قلب هر برنامه جاوااسکریپت هستند و داده‌های تعاملی و بخش بزرگی از منطق پیرامون آن‌ها را شامل می‌شوند: تبدیل‌ها، اعتبارسنجی‌ها، ویژگی‌های محاسبه‌شده و کنترل دسترسی.

مدیریت داده با مدل‌ها. مدل‌های Backbone داده و منطق کسب‌وکار را در بر می‌گیرند و یک رابط تمیز برای دستکاری و اعتبارسنجی داده‌ها فراهم می‌کنند. آن‌ها می‌توانند به صورت مستقل از رابط کاربری ایجاد، بازیابی، به‌روزرسانی و حذف شوند (عملیات CRUD). مدل‌ها هنگام تغییر داده‌هایشان رویدادهایی را منتشر می‌کنند که به نماها اجازه می‌دهد به‌طور خودکار به‌روزرسانی شوند.

رابط کاربری با نماها. نماها در Backbone مسئول رندر کردن رابط کاربری و مدیریت تعاملات کاربر هستند. آن‌ها به رویدادهای مدل گوش می‌دهند و هنگام تغییر داده‌های زیرین خود را مجدداً رندر می‌کنند. این جداسازی نگرانی‌ها بین داده‌ها (مدل‌ها) و ارائه (نماها) به کدی قابل نگهداری و تست‌پذیرتر منجر می‌شود.

مجموعه‌های داده. مجموعه‌ها در Backbone مجموعه‌های مرتب‌شده‌ای از مدل‌ها هستند که یک API غنی برای کار با آرایه‌های داده فراهم می‌کنند. آن‌ها اجازه می‌دهند:

  • مرتب‌سازی و فیلتر کردن داده‌ها
  • تجمیع داده‌ها در چندین مدل
  • همگام‌سازی داده‌ها با سرور
  • انتشار رویدادها هنگام تغییر مجموعه

3. مسیریابی امکان عملکرد برنامه تک‌صفحه‌ای را در Backbone فراهم می‌کند

Backbone.Router روش‌هایی برای مسیریابی صفحات سمت کاربر و اتصال آن‌ها به اقدامات و رویدادها فراهم می‌کند.

ناوبری سمت کاربر. مسیریاب Backbone به توسعه‌دهندگان اجازه می‌دهد تا برنامه‌های تک‌صفحه‌ای (SPAs) را با نگاشت URLها به توابع ایجاد کنند. این امکان را به کاربران می‌دهد تا بدون بارگذاری کامل صفحات در یک برنامه حرکت کنند و تجربه کاربری روان‌تر و پاسخگوتر را فراهم می‌کند.

لینک‌دهی عمیق و نشانه‌گذاری. با استفاده از مسیریاب، توسعه‌دهندگان می‌توانند URLهای نشانه‌گذاری‌شدنی برای حالت‌های مختلف برنامه ایجاد کنند. این امکان را به کاربران می‌دهد تا نماهای خاصی را به اشتراک بگذارند یا به راحتی به حالت‌های قبلی بازگردند و قابلیت استفاده کلی برنامه را بهبود می‌بخشد.

مدیریت تاریخچه. مسیریاب Backbone با API تاریخچه مرورگر یکپارچه می‌شود و به کاربران اجازه می‌دهد تا از دکمه‌های بازگشت و جلو به همان شکلی که در یک برنامه چندصفحه‌ای سنتی استفاده می‌کنند، استفاده کنند. این رفتار مرور مورد انتظار را حفظ می‌کند و در عین حال از مزایای عملکردی SPAs بهره‌مند می‌شود.

4. سیستم رویدادها ارتباط غیرمستقیم بین اجزا را ممکن می‌سازد

Backbone.Events یک ماژول است که می‌تواند به هر شیء اضافه شود و به شیء امکان می‌دهد رویدادهای نام‌گذاری‌شده سفارشی را متصل و فعال کند.

اتصال شل. سیستم رویدادها در Backbone به بخش‌های مختلف یک برنامه اجازه می‌دهد بدون وابستگی مستقیم به یکدیگر ارتباط برقرار کنند. این امر مدولاریت را ترویج می‌کند و تغییر یا گسترش عملکرد را بدون تأثیر بر کل سیستم آسان‌تر می‌کند.

قابلیت گسترش. با استفاده از رویدادهای سفارشی، توسعه‌دهندگان می‌توانند به راحتی ویژگی‌ها یا رفتارهای جدیدی به اجزای موجود اضافه کنند بدون اینکه منطق اصلی آن‌ها را تغییر دهند. این امر برنامه‌های Backbone را بسیار قابل گسترش و سازگار با نیازهای متغیر می‌سازد.

برنامه‌نویسی واکنشی. سیستم رویدادها سبک برنامه‌نویسی واکنشی را تسهیل می‌کند، جایی که تغییرات در یک بخش از برنامه به‌طور خودکار به‌روزرسانی‌ها را در بخش‌های دیگر فعال می‌کند. این می‌تواند به رابط‌های کاربری پویا و پاسخگوتر منجر شود و همچنین کدی ساده‌تر که نیازی به مدیریت دستی تغییرات حالت در سراسر برنامه ندارد.

5. توسعه مدولار با RequireJS قابلیت نگهداری را بهبود می‌بخشد

RequireJS مشخصات AMD را پیاده‌سازی می‌کند که روشی برای نوشتن کد مدولار و مدیریت وابستگی‌ها تعریف می‌کند.

مدیریت وابستگی. RequireJS به توسعه‌دهندگان اجازه می‌دهد تا وابستگی‌ها بین بخش‌های مختلف برنامه خود را تعریف و مدیریت کنند. این امر به جلوگیری از آلودگی فضای نام جهانی کمک می‌کند و درک و نگهداری روابط بین ماژول‌های مختلف را آسان‌تر می‌کند.

سازماندهی کد. با استفاده از RequireJS، توسعه‌دهندگان می‌توانند برنامه‌های Backbone خود را به فایل‌های کوچک‌تر و قابل مدیریت‌تر سازماندهی کنند. این امر خوانایی کد را بهبود می‌بخشد و کار تیم‌ها بر روی بخش‌های مختلف برنامه به‌طور همزمان را آسان‌تر می‌کند.

بهینه‌سازی برای تولید. RequireJS شامل یک ابزار بهینه‌سازی (r.js) است که می‌تواند ماژول‌ها را برای استقرار تولید ترکیب و فشرده کند. این امر به زمان بارگذاری سریع‌تر و عملکرد بهبود یافته برای کاربران نهایی منجر می‌شود.

6. یکپارچه‌سازی jQuery Mobile Backbone را به پلتفرم‌های موبایل گسترش می‌دهد

jQuery Mobile اصول بهبود تدریجی و طراحی وب پاسخگو را با استفاده از تعاریف و پیکربندی‌های مبتنی بر HTML5 دنبال می‌کند.

توسعه چندپلتفرمی. یکپارچه‌سازی jQuery Mobile با Backbone به توسعه‌دهندگان اجازه می‌دهد تا برنامه‌های سازگار با موبایل را با استفاده از مجموعه ابزارهای آشنا ایجاد کنند. این امر امکان توسعه برنامه‌هایی را فراهم می‌کند که در طیف گسترده‌ای از دستگاه‌ها و اندازه‌های صفحه نمایش کار می‌کنند.

بهبود تدریجی. رویکرد jQuery Mobile به بهبود تدریجی تضمین می‌کند که برنامه‌ها بر روی دستگاه‌های قدیمی‌تر نیز کارایی داشته باشند و در عین حال تجربه‌های بهبود یافته‌ای را بر روی پلتفرم‌های توانمندتر ارائه دهند. این امر با طبیعت انعطاف‌پذیر Backbone همخوانی دارد و به توسعه‌دهندگان اجازه می‌دهد تا برنامه‌هایی ایجاد کنند که به‌طور زیبا به محیط‌های مختلف سازگار شوند.

اجزای رابط کاربری مخصوص موبایل. jQuery Mobile مجموعه‌ای از اجزای رابط کاربری بهینه‌سازی‌شده برای لمس را فراهم می‌کند که به راحتی می‌توان آن‌ها را در نماهای Backbone یکپارچه کرد. این امر توسعه برنامه‌های موبایل را سرعت می‌بخشد و تجربه‌ای سازگار و شبیه به بومی را در پلتفرم‌های مختلف موبایل تضمین می‌کند.

7. تست برنامه‌های Backbone اطمینان از قابلیت اطمینان و تسهیل نگهداری را فراهم می‌کند

تست واحد فرآیند گرفتن کوچک‌ترین قطعه کد قابل تست در یک برنامه، جداسازی آن از بقیه کدبیس و تعیین اینکه آیا دقیقاً همان‌طور که انتظار می‌رود رفتار می‌کند، است.

بهبود کیفیت کد. نوشتن تست‌ها برای برنامه‌های Backbone به شناسایی اشکالات در اوایل فرآیند توسعه کمک می‌کند و اطمینان می‌دهد که اجزای فردی همان‌طور که انتظار می‌رود کار می‌کنند. این امر به برنامه‌های قابل اطمینان‌تر و پایدارتر منجر می‌شود.

اعتماد به نفس در بازسازی. یک مجموعه تست جامع به توسعه‌دهندگان اعتماد به نفس می‌دهد تا کد خود را بازسازی و بهبود دهند بدون ترس از معرفی بازگشت‌ها. این امر به‌ویژه در برنامه‌های Backbone مهم است، جایی که تغییرات در مدل‌ها یا مجموعه‌ها می‌تواند تأثیرات گسترده‌ای داشته باشد.

مستندسازی از طریق تست‌ها. تست‌های خوب نوشته‌شده به عنوان مستنداتی برای نحوه رفتار بخش‌های مختلف یک برنامه Backbone عمل می‌کنند. این امر می‌تواند برای ورود اعضای جدید تیم یا درک تعاملات پیچیده درون سیستم بسیار ارزشمند باشد.

چارچوب‌ها و ابزارهای تست برای برنامه‌های Backbone شامل موارد زیر است:

  • Jasmine: یک چارچوب توسعه مبتنی بر رفتار برای تست کد جاوااسکریپت
  • QUnit: یک مجموعه تست قدرتمند جاوااسکریپت که اغلب با Backbone استفاده می‌شود
  • SinonJS: یک کتابخانه برای ایجاد جاسوس‌ها، استاب‌ها و ماک‌ها در تست‌های جاوااسکریپت

آخرین به‌روزرسانی::

FAQ

1. What is "Developing Backbone.js Applications" by Addy Osmani about?

  • Comprehensive Backbone.js guide: The book offers an in-depth introduction to Backbone.js, a lightweight JavaScript framework for structuring client-side web applications.
  • Core concepts covered: It explains models, views, collections, routers, and how to build maintainable, modular single-page applications (SPAs).
  • Hands-on learning: Readers are guided through practical projects like a Todo app and a Book Library app, with step-by-step exercises and real-world examples.
  • Advanced topics included: The book also explores modular development, RESTful integration, testing, optimization, and popular Backbone extensions.

2. Why should I read "Developing Backbone.js Applications" by Addy Osmani?

  • Improve client-side architecture: The book demonstrates how Backbone.js helps organize complex JavaScript-heavy applications, making code more maintainable and scalable.
  • Practical, real-world skills: Through detailed examples and exercises, readers learn to build, test, and optimize real applications using Backbone and related tools.
  • Covers advanced and common challenges: It addresses issues like modularization, memory management, and integration with other libraries, providing solutions for common Backbone.js pitfalls.
  • Open and community-driven resource: Released under a Creative Commons license, the book encourages community contributions and is accessible to novice and intermediate developers.

3. What are the key takeaways from "Developing Backbone.js Applications" by Addy Osmani?

  • Minimalist, flexible architecture: Backbone.js provides just enough structure—models, collections, views, and routers—without enforcing rigid patterns, allowing developers to adapt it to their needs.
  • Event-driven and RESTful: The framework’s event system keeps data and UI in sync, and it integrates easily with RESTful APIs for server communication.
  • Modular and scalable development: The book emphasizes modular code organization using AMD and RequireJS, making large applications maintainable and efficient.
  • Testing and optimization: Readers learn best practices for testing with Jasmine and QUnit, and for optimizing production builds with tools like r.js.

4. What are the best quotes from "Developing Backbone.js Applications" and what do they mean?

  • Minimal set of primitives: “The essential premise at the heart of Backbone has always been to try and discover the minimal set of data-structuring (Models and Collections) and user interface (Views and URLs) primitives that are useful when building web applications with JavaScript.” This highlights Backbone’s philosophy of simplicity and sufficiency.
  • Embracing new perspectives: “One’s destination is never a place, but a new way of seeing things.” — Henry Miller. This quote encourages developers to adopt new approaches, like Backbone, to improve their craft.
  • Importance of namespacing: “Without strong namespacing conventions, it is also fairly easy to pollute the global namespace with your own custom objects.” This underscores the need for modularity and clean code organization in JavaScript.

5. How does "Developing Backbone.js Applications" by Addy Osmani explain the MVC pattern and Backbone’s MV* approach?

  • MVC basics explained: The book describes MVC as separating concerns into Models (data), Views (UI), and Controllers (input handling), with clear communication between components.
  • Backbone’s MV variation:* Backbone merges controller responsibilities into views and uses routers for navigation, making it an MV* rather than strict MVC framework.
  • Event-driven updates: Models and views communicate via an event system, keeping data and UI synchronized without direct coupling.
  • Templating and routing: Views render templates (like Underscore or Handlebars), and routers manage application state and navigation for SPAs.

6. How do Backbone.js models, views, collections, and routers work according to Addy Osmani’s book?

  • Models: Hold data attributes, support defaults and validation, and can persist data to a server using RESTful methods like save(), fetch(), and destroy().
  • Views: Manage UI logic, render templates, and handle DOM events declaratively, listening to model changes to update the interface.
  • Collections: Ordered sets of models with utility methods for adding, removing, filtering, and sorting, and can fetch data from servers.
  • Routers: Map URL fragments to functions, enabling bookmarkable states and navigation in single-page applications.

7. What are the key features and benefits of Backbone.js highlighted in "Developing Backbone.js Applications"?

  • Lightweight and flexible: Backbone provides minimal structure, allowing developers to build applications in their preferred style.
  • Event-driven and RESTful: Rich event handling between models and views, and seamless integration with RESTful APIs for data persistence.
  • Modular and scalable: Scales from small widgets to large applications, and works well with other libraries and frameworks.
  • Readable and efficient: The source code is small and accessible, making it easy for developers to understand and extend.

8. How does Addy Osmani’s book guide building a Todo application with Backbone.js?

  • Step-by-step architecture: The book walks through creating Todo models, collections, and views, demonstrating CRUD operations and UI binding.
  • Templates and events: Uses Underscore.js templates for rendering and declarative event handling for user interactions like adding, editing, and deleting todos.
  • Persistence with localStorage: Shows how to use Backbone.localStorage to persist data in the browser without a server.
  • Routing and filtering: Implements URL-based filtering (all, active, completed) using Backbone.Router for bookmarkable app states.

9. How does "Developing Backbone.js Applications" by Addy Osmani recommend integrating Backbone.js with a RESTful backend?

  • Separation of concerns: The frontend Backbone app communicates with a Node.js/Express REST API backend, modeling real-world client-server interaction.
  • Model and collection setup: Models and collections are configured with URLs pointing to the REST API, enabling fetch(), save(), and destroy() to sync with the server.
  • Handling nested data: The book addresses challenges like date formatting and nested attributes, showing how to parse and serialize data correctly.
  • Server-side implementation: Guides setting up a MongoDB-backed REST API with CRUD routes, connecting Backbone apps to persistent storage.

10. What are MarionetteJS and Thorax, and how do they extend Backbone.js as described in Addy Osmani’s book?

  • MarionetteJS: A composite application library that reduces boilerplate, manages memory and view lifecycles, and provides specialized view types and regions for layout management.
  • Boilerplate reduction: Automates rendering logic and view cleanup, preventing memory leaks and zombie views.
  • Thorax: An opinionated framework built on Backbone, using Handlebars templating and offering conventions for app organization and embedding child views.
  • Flexibility and modularity: Both extensions allow developers to scale Backbone apps with better structure and maintainability, integrating seamlessly with existing code.

11. How does "Developing Backbone.js Applications" by Addy Osmani recommend modularizing applications using RequireJS and AMD?

  • Asynchronous module loading: RequireJS loads JavaScript files asynchronously, improving performance and enabling dynamic module loading.
  • AMD module definition: Modules are defined with define(), specifying dependencies and a factory function for clean dependency management.
  • External templates and shimming: Uses RequireJS’s text.js plug-in for external templates and configures shims for non-AMD libraries like Backbone and Underscore.
  • Organizing code: Encourages separating models, views, collections, and routers into folders, wrapping components as AMD modules for maintainability.

12. How does Addy Osmani’s book approach testing Backbone.js applications with Jasmine, QUnit, and SinonJS?

  • Jasmine for BDD: Introduces Jasmine as a behavior-driven development framework for writing readable, automated unit tests with suites, specs, and spies.
  • Testing models, collections, and views: Provides examples for testing defaults, validation, filtering, rendering, and DOM integration, using jasmine-jquery for fixtures.
  • Asynchronous and spy support: Shows how to mock AJAX requests and write asynchronous tests, ensuring thorough client-server interaction testing.
  • Comparison with QUnit and SinonJS: Explains QUnit’s straightforward assertions and modules, and how SinonJS adds spies, stubs, and mocks for detailed function call inspection.

نقد و بررسی

3.69 از 5
میانگین از 100+ امتیازات از Goodreads و Amazon.

کتاب توسعه‌ی برنامه‌های Backbone.js نظرات متفاوتی دریافت کرده است و به‌طور میانگین امتیاز 3.69 از 5 را کسب کرده است. خوانندگان از پوشش جامع این کتاب در زمینه‌ی Backbone.js و فناوری‌های مرتبط قدردانی می‌کنند و به جریان منطقی و مثال‌های خوب آن اشاره می‌کنند. با این حال، برخی معتقدند که این کتاب بیشتر برای کاربران متوسط تا پیشرفته مناسب است تا مبتدیان. منتقدان به محتوای قدیمی، مثال‌های کد ناقص و کمبود توضیحات عمیق اشاره می‌کنند. با وجود این نقاط ضعف، بسیاری همچنان آن را منبعی ارزشمند برای یادگیری Backbone.js می‌دانند، به‌ویژه زمانی که با تمرین عملی و مستندات اضافی ترکیب شود.

Your rating:
4.23
36 امتیازها

درباره نویسنده

ادی عثمانی مدیر ارشد مهندسی در گوگل کروم است که تیم‌هایی را در جهت بهبود کارایی و عملکرد توسعه وب هدایت می‌کند. او نویسنده‌ی چندین کتاب است و به‌طور مکرر در کنفرانس‌های بین‌المللی سخنرانی می‌کند. تخصص عثمانی در سریع‌تر و دسترس‌پذیرتر کردن توسعه وب برای توسعه‌دهندگان است. کار او در گوگل کروم شامل ساده‌سازی فرآیند توسعه وب و ارتقاء قابلیت‌های این پلتفرم می‌شود. با تجربه‌ی گسترده و مشارکت‌هایش در این حوزه، عثمانی به عنوان یک چهره‌ی محترم در جامعه‌ی توسعه وب شناخته شده است و به خاطر دیدگاه‌ها و رویکردهای عملی‌اش به فناوری‌های مدرن وب معروف است.

Listen
0:00
-0:00
1x
Dan
Andrew
Michelle
Lauren
Select Speed
1.0×
+
200 words per minute
Home
Library
Get App
Create a free account to unlock:
Requests: Request new book summaries
Bookmarks: Save your favorite books
History: Revisit books later
Recommendations: Personalized for you
Ratings: Rate books & see your ratings
100,000+ readers
Try Full Access for 7 Days
Listen, bookmark, and more
Compare Features Free Pro
📖 Read Summaries
All summaries are free to read in 40 languages
🎧 Listen to Summaries
Listen to unlimited summaries in 40 languages
❤️ Unlimited Bookmarks
Free users are limited to 4
📜 Unlimited History
Free users are limited to 4
📥 Unlimited Downloads
Free users are limited to 1
Risk-Free Timeline
Today: Get Instant Access
Listen to full summaries of 73,530 books. That's 12,000+ hours of audio!
Day 4: Trial Reminder
We'll send you a notification that your trial is ending soon.
Day 7: Your subscription begins
You'll be charged on Jun 8,
cancel anytime before.
Consume 2.8x More Books
2.8x more books Listening Reading
Our users love us
100,000+ readers
"...I can 10x the number of books I can read..."
"...exceptionally accurate, engaging, and beautifully presented..."
"...better than any amazon review when I'm making a book-buying decision..."
Save 62%
Yearly
$119.88 $44.99/year
$3.75/mo
Monthly
$9.99/mo
Try Free & Unlock
7 days free, then $44.99/year. Cancel anytime.
Scanner
Find a barcode to scan

Settings
General
Widget
Loading...