What is Unobtrusive JavaScript?
Unobtrusive JavaScript embodies a methodology wherein the JavaScript language is skillfully partitioned between Document Content and Script Content. This distinction serves to delineate these elements clearly and effectively. Just as we adhere to the practice of segregating structural and presentational aspects through the segregation of CSS into a distinct file and the avoidance of inline style attributes, a similar separation is recommended between HTML structure and JavaScript behavior. The rationale underlying this principle remains consistent: it compartmentalizes concerns, develops code hygiene, and facilitates the manipulation of JavaScript code independently of both HTML and CSS. In essence, it entails the isolation of JavaScript behavior from HTML presentation. This paradigm bears numerous advantages, imbuing our code with enhanced reliability, facilitating updates, and streamlining debugging processes.
The fundamental principle of unobtrusive programming entails utilizing JavaScript as an augmentative element for our web pages rather than an obligatory component. This approach advocates for the selective use of JavaScript based on necessity; if JavaScript is unnecessary, static content functions seamlessly with pure HTML and CSS. Unfortunately, numerous developers prematurely integrate code libraries without assessing their actual requirements. Notably, jQuery has often been overused, overshadowing the potential of achieving fundamental objectives through CSS and native JavaScript. Unobtrusive JavaScript introduces a paradigm shift, counteracting the conventional notion of exclusively JavaScript-driven dynamic web pages. Instead, it encourages a reversal: prioritize 100% standard, static web pages and subsequently introduce an additional stratum of JavaScript, almost as an afterthought, for supplementary enhancement.
That is not unobstrusive javascript because behaviour and presentation are mixed. The onclick shouldn't be there in html and should be part of javascript itself not html.
With above example, you can go unobstrusive like this:
Conclusion
Unobtrusive JavaScript is a development philosophy that advocates using JavaScript to enhance web pages rather than making it a mandatory requirement. It encourages selectively applying JavaScript where needed, allowing static content to function effectively with HTML and CSS alone. This approach promotes cleaner, more accessible code and avoids overreliance on JavaScript libraries, aligning with a paradigm that prioritizes degradation.
- JavaScript Interview Questions (Part2)
- JavaScript Interview Questions (Part3)
- Is JavaScript a true OOP language?
- Advantages and Disadvantages of JavaScript
- Difference Between JavaScript and ECMAScript?
- What is noscript tag?
- Escaping Special Characters in JavaScript
- What is undefined x 1 in JavaScript?
- Logical operators in JavaScript
- Difference between '=', '==' and '===' operators in JS
- How to loop through objects in JavaScript?
- How to write html code dynamically using JavaScript?
- How to add html elements dynamically with JavaScript?
- How to load another html page from javascript?
- What Is The Disadvantages Using InnerHTML In JavaScript?
- What is Browser Object Model
- How to detect the OS on the client machine in JavaScript?
- Difference between window, document, and screen in Javascript?
- Difference between the substr() and substring() in JavaScript?
- How to replace all occurrences of a string in JavaScript?
- Test a string as a literal and as an object in JavaScript
- What is Associative Array in JavaScript
- What is an anonymous function in JavaScript?
- What is the use of 'bind' method in JavaScript?
- Pure functions Vs. Impure functions in javascript
- Is Javascript a Functional Programming Language?
- What's the Difference Between Class and Prototypal Inheritance?
- Javascript, Pass by Value or Pass by Reference?
- How to prevent modification of an object in Javascript?
- What is 'this' keyword in JavaScript?
- How Does Function Hoisting Work in JavaScript?
- What do mean by NULL in Javascript?
- What does the delete operator do in JavaScript?
- What is the Infinity property used for in Javascript?
- Event bubbling and Event Capturing in JavScript?
- What is "strict mode" and how is it used in JavaScript?
- What is the difference between call and apply in JavaScript
- Entire content of a JavaScript source file in a function block?
- What is an immediately-invoked function expression?
- What is escape & unescape String functions in JavaScript?
- Instanceof operator in JavaScript
- What Are RESTful (REpresentational State Transfer)Web Services?
- What Does JavaScript Void(0) Mean?
- What are JavaScript Cookies?
- Difference between Client side JavaScript and Server side JavaScript
- TypeError: document.getelementbyid(...) is null
- Uncaught TypeError: Cannot read property of undefined In JavaScript
- Null and Undefined in JavaScript