SlideShare a Scribd company logo
jQuery for Drupal
What is jQuery?
What is jQuery?




 • http://jquery.com
What is jQuery?




 • http://jquery.com
 • “write less, do more”
Why is it so fun?
Why is it so fun?
• Removes cross-browser pain
Why is it so fun?
• Removes cross-browser pain
• Leverages your existing CSS
  knowledge
Why is it so fun?
• Removes cross-browser pain
• Leverages your existing CSS
  knowledge

• Animates elements on the page
Why is it so fun?
• Removes cross-browser pain
• Leverages your existing CSS
  knowledge

• Animates elements on the page
• Compact code
What’s it best at?
What’s it best at?
• Adding/Removing elements to/from
  the page
What’s it best at?
• Adding/Removing elements to/from
  the page
• Hiding/Showing elements
What’s it best at?
• Adding/Removing elements to/from
  the page
• Hiding/Showing elements
• Animating CSS transitions
What’s it best at?
• Adding/Removing elements to/from
  the page
• Hiding/Showing elements
• Animating CSS transitions
• Responding to clicks, hovers, focus
  events
What’s it best at?
• Adding/Removing elements to/from
  the page
• Hiding/Showing elements
• Animating CSS transitions
• Responding to clicks, hovers, focus
  events

• Selecting from and traversing the DOM
Core Drupal
  jQuery
Core Drupal
       jQuery
• Drupal adopted jQuery into core
  starting with Drupal 5
Core Drupal
       jQuery
• Drupal adopted jQuery into core
  starting with Drupal 5

• In /misc: drag-and-drop ordering,
  expandable textareas, collapsible
  fieldsets, autocomplete, persistent
  table headers etc.
Syntax
http://docs.jquery.com/Types#jQuery
Syntax
http://docs.jquery.com/Types#jQuery

• $(‘#page’).hide( );
Syntax
http://docs.jquery.com/Types#jQuery

• $(‘#page’).hide( );
• $(‘a’).addClass(‘test’);
Syntax
http://docs.jquery.com/Types#jQuery

• $(‘#page’).hide( );
• $(‘a’).addClass(‘test’);
• $(‘#page p’).click(function() {
    $(this).hide(‘slow’);
  });
Adding jQuery to
    a theme
Adding jQuery to
    a theme
• drupal_add_js(drupal_get_path(‘theme’,
  ‘MYTHEME’) . ‘/js/myfile.js’);
Adding jQuery to
    a theme
• drupal_add_js(drupal_get_path(‘theme’,
  ‘MYTHEME’) . ‘/js/myfile.js’);

• Add this to the top of template.php
  or in a specific theme function
Drupal behaviors
Sending settings
   to jQuery
Sending settings
   to jQuery
• Add setting from PHP
Sending settings
   to jQuery
• Add setting from PHP
Sending settings
   to jQuery
• Add setting from PHP

• Access Drupal.settings.myModule
  from within jQuery
jQuery Release
    Cycle
jQuery Release
      Cycle
• Drupal 7 has jQuery 1.4.4
jQuery Release
      Cycle
• Drupal 7 has jQuery 1.4.4
• Latest jQuery is 1.6.2
jQuery Release
      Cycle
• Drupal 7 has jQuery 1.4.4
• Latest jQuery is 1.6.2
• jQuery Update
Overriding JS
Overriding JS
• Override JS functions by redeclaring
  afterwards
Overriding JS
• Override JS functions by redeclaring
  afterwards

• ‘theme’ JS loads after ‘core’ and
  ‘module’ JS
Progressive
Enhancement
Progressive
    Enhancement
• Build the page without relying on
  jQuery
Progressive
    Enhancement
• Build the page without relying on
  jQuery

• Fancify for additional coolness
Progressive
    Enhancement
• Build the page without relying on
  jQuery

• Fancify for additional coolness
• Never use js to make changes that
  should be done in markup, styles,
  or PHP
AJAX
Form API
 #states
Common Use
   Cases
Common Use
       Cases
• Show more content on a page with
  hide/show, tabs, accordions,
  rotators, modals
Common Use
       Cases
• Show more content on a page with
  hide/show, tabs, accordions,
  rotators, modals

• Search bar with disappearing
  default value
Common Use
       Cases
• Show more content on a page with
  hide/show, tabs, accordions,
  rotators, modals

• Search bar with disappearing
  default value

• Slicker functionality with AJAX and
  AHAH
Popular Modules
Popular Modules
• Colorbox
Popular Modules
• Colorbox
• Quick Tabs
Popular Modules
• Colorbox
• Quick Tabs
• Views Slideshow
Popular Modules
• Colorbox
• Quick Tabs
• Views Slideshow
• Beauty Tips
Popular Modules
• Colorbox
• Quick Tabs
• Views Slideshow
• Beauty Tips
• Hierarchical
  Select
Popular Modules
• Colorbox        • Views UI
• Quick Tabs
• Views Slideshow
• Beauty Tips
• Hierarchical
 Select
Popular Modules
• Colorbox        • Views UI
• Quick Tabs      • FullCalendar
• Views Slideshow
• Beauty Tips
• Hierarchical
  Select
Popular Modules
• Colorbox        • Views UI
• Quick Tabs      • FullCalendar
• Views Slideshow • Views
                    Accordion
• Beauty Tips
• Hierarchical
  Select
Popular Modules
• Colorbox          • Views UI
• Quick Tabs        • FullCalendar
• Views Slideshow   • Views
                      Accordion
• Beauty Tips
• Hierarchical      • Feedback
  Select
jQuery UI
jQuery UI
jQuery UI

• Used to be jquery_ui module
jQuery UI

• Used to be jquery_ui module
• In Drupal 7 core!
Resources & Tools
Resources & Tools
• http://api.jquery.com
Resources & Tools
• http://api.jquery.com
• Firebug for Firefox
Resources & Tools
• http://api.jquery.com
• Firebug for Firefox
• http://drupal.org/node/171213
Demo
Demo
• Let’s do this.

More Related Content

PPT
PDF
Be nice to your designers
PPTX
Bootstrap: the full overview
PPTX
WordPress Blogs 101
PPTX
Wp nhcc portfolio
PPTX
Bootstrap for Extension Developers JWC 2012
KEY
WAI-ARIA is More Than Accessibility
PDF
Future-proof styling in Drupal (8)
Be nice to your designers
Bootstrap: the full overview
WordPress Blogs 101
Wp nhcc portfolio
Bootstrap for Extension Developers JWC 2012
WAI-ARIA is More Than Accessibility
Future-proof styling in Drupal (8)

What's hot (20)

PDF
Real World Web components
PDF
WAI-ARIA
PPTX
Website Review with Screen Reader vs. SiteImprove
PDF
Best SEO Training Institute in North Delhi
PDF
WAI-ARIA - an introduction to accessible rich internet applications (1 day wo...
PDF
jQTouch and Titanium
PDF
Styling Components with JavaScript: MelbCSS Edition
KEY
Sizzle jQCon San Francisco 2012
PPTX
jQuery Conference Austin Sept 2013
PDF
Learn about Eclipse e4 from Lars Vogel at SF-JUG
PPTX
2011 - SharePoint + jQuery
PDF
Styling components with JavaScript
PPTX
Wheel.js
PPTX
WP 101 - Custom Fields & Post Types
PDF
CSS架構如何加速功能開發
PDF
HTML5: Introduction
PPTX
WP101 - Themes and Plugins
PPTX
WP 101 - WordPress Basics
PDF
Dangerous CSS
KEY
Becoming a more productive Rails Developer
Real World Web components
WAI-ARIA
Website Review with Screen Reader vs. SiteImprove
Best SEO Training Institute in North Delhi
WAI-ARIA - an introduction to accessible rich internet applications (1 day wo...
jQTouch and Titanium
Styling Components with JavaScript: MelbCSS Edition
Sizzle jQCon San Francisco 2012
jQuery Conference Austin Sept 2013
Learn about Eclipse e4 from Lars Vogel at SF-JUG
2011 - SharePoint + jQuery
Styling components with JavaScript
Wheel.js
WP 101 - Custom Fields & Post Types
CSS架構如何加速功能開發
HTML5: Introduction
WP101 - Themes and Plugins
WP 101 - WordPress Basics
Dangerous CSS
Becoming a more productive Rails Developer
Ad

Viewers also liked (6)

KEY
LEMON - On Drupal diseases and cures
KEY
Custom Field Formatters
KEY
jQuery for Drupal
KEY
Semantic Site Building (Drupal 7)
PPT
Enas Fares
PPT
Rays Of Light Final Kim Drynan
LEMON - On Drupal diseases and cures
Custom Field Formatters
jQuery for Drupal
Semantic Site Building (Drupal 7)
Enas Fares
Rays Of Light Final Kim Drynan
Ad

Similar to Intro to jQuery for Drupal (20)

KEY
jQuery for Drupal
PDF
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
PPTX
SharePoint & jQuery Guide - SPSNashville 2014
PDF
Javascript Libraries
PDF
Write Less Do More
PPTX
SPSHawaii: Navigation: A Step Towards Success in SharePoint
PDF
jQuery Loves Developers - Oredev 2009
DOCX
Web designing course content
PPTX
UF HTML Template Presentation
PDF
Lotusphere 2012 Speedgeeking - jQuery & Domino, a RAD Combination
PPTX
SharePoint and jQuery Essentials
KEY
Progressively Enhancing WordPress Themes
PDF
jQuery for beginners
KEY
Windycityrails page performance
PPTX
SPSDenver - SharePoint & jQuery - What I wish I would have known
PPTX
SPSNH 2014 - The SharePoint & jQueryGuide
PPT
J query presentation
PPT
J query presentation
PPTX
Rich and Beautiful: Making Attractive Apps in HTML5 [Wpg 2013]
PDF
JQuery UI
jQuery for Drupal
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
SharePoint & jQuery Guide - SPSNashville 2014
Javascript Libraries
Write Less Do More
SPSHawaii: Navigation: A Step Towards Success in SharePoint
jQuery Loves Developers - Oredev 2009
Web designing course content
UF HTML Template Presentation
Lotusphere 2012 Speedgeeking - jQuery & Domino, a RAD Combination
SharePoint and jQuery Essentials
Progressively Enhancing WordPress Themes
jQuery for beginners
Windycityrails page performance
SPSDenver - SharePoint & jQuery - What I wish I would have known
SPSNH 2014 - The SharePoint & jQueryGuide
J query presentation
J query presentation
Rich and Beautiful: Making Attractive Apps in HTML5 [Wpg 2013]
JQuery UI

Recently uploaded (20)

PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
cuic standard and advanced reporting.pdf
PPTX
Big Data Technologies - Introduction.pptx
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Unlocking AI with Model Context Protocol (MCP)
PPT
Teaching material agriculture food technology
PDF
Modernizing your data center with Dell and AMD
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
A Presentation on Artificial Intelligence
DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
Encapsulation theory and applications.pdf
PDF
Review of recent advances in non-invasive hemoglobin estimation
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
Per capita expenditure prediction using model stacking based on satellite ima...
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
MYSQL Presentation for SQL database connectivity
Dropbox Q2 2025 Financial Results & Investor Presentation
Encapsulation_ Review paper, used for researhc scholars
NewMind AI Weekly Chronicles - August'25 Week I
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
cuic standard and advanced reporting.pdf
Big Data Technologies - Introduction.pptx
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Unlocking AI with Model Context Protocol (MCP)
Teaching material agriculture food technology
Modernizing your data center with Dell and AMD
Chapter 3 Spatial Domain Image Processing.pdf
A Presentation on Artificial Intelligence
The AUB Centre for AI in Media Proposal.docx
Encapsulation theory and applications.pdf
Review of recent advances in non-invasive hemoglobin estimation

Intro to jQuery for Drupal

Editor's Notes