डार्ट प्रोग्रामिंग - एचटीएमएल डोम
हर वेबपेज एक ब्राउज़र विंडो के अंदर रहता है जिसे ऑब्जेक्ट माना जा सकता है।
ए Document objectउस विंडो में प्रदर्शित HTML दस्तावेज़ का प्रतिनिधित्व करता है। दस्तावेज़ ऑब्जेक्ट में विभिन्न गुण होते हैं जो अन्य वस्तुओं को संदर्भित करते हैं जो दस्तावेज़ सामग्री तक पहुंच और संशोधन की अनुमति देते हैं।
जिस तरह से एक दस्तावेज़ सामग्री तक पहुँचा और संशोधित किया जाता है उसे कहा जाता है Document Object Model, या DOM। वस्तुओं को एक पदानुक्रम में व्यवस्थित किया जाता है। यह पदानुक्रमित संरचना एक वेब दस्तावेज़ में वस्तुओं के संगठन पर लागू होती है।
Window- पदानुक्रम के शीर्ष। यह वस्तु पदानुक्रम का सबसे बाहरी तत्व है।
Document- प्रत्येक HTML दस्तावेज़ जो एक विंडो में लोड हो जाता है, एक दस्तावेज़ ऑब्जेक्ट बन जाता है। दस्तावेज़ में पृष्ठ की सामग्री शामिल है।
Elements- एक वेब पेज पर सामग्री का प्रतिनिधित्व करते हैं। उदाहरणों में पाठ बॉक्स, पृष्ठ शीर्षक आदि शामिल हैं।
Nodes - अक्सर तत्व होते हैं, लेकिन वे गुण, पाठ, टिप्पणियां और अन्य डोम प्रकार भी हो सकते हैं।
यहाँ कुछ महत्वपूर्ण DOM वस्तुओं का एक सरल पदानुक्रम है -
डार्ट प्रदान करता है dart:htmlडोम में वस्तुओं और तत्वों में हेरफेर करने के लिए पुस्तकालय। कंसोल-आधारित अनुप्रयोग उपयोग नहीं कर सकतेdart:htmlपुस्तकालय। वेब अनुप्रयोगों में HTML लाइब्रेरी का उपयोग करने के लिए, आयात करेंdart:html -
import 'dart:html';
आगे बढ़ते हुए, हम कुछ चर्चा करेंगे DOM Operations अगले भाग में
डोम तत्व खोजना
dart:html पुस्तकालय प्रदान करता है querySelector DOM में तत्वों की खोज करने के लिए फ़ंक्शन।
Element querySelector(String selectors);
querySelector() फ़ंक्शन पहला तत्व देता है जो चयनकर्ताओं के निर्दिष्ट समूह से मेल खाता है। "selectors नीचे दिए गए अनुसार CSS चयनकर्ता वाक्यविन्यास का उपयोग करके स्ट्रिंग होना चाहिए
var element1 = document.querySelector('.className');
var element2 = document.querySelector('#id');
उदाहरण: हेरफेर डोम
नीचे दिए गए चरणों का पालन करें, Webstorm IDE में -
Step 1 - फ़ाइल न्यूप्रोजेक्ट → स्थान में, प्रोजेक्ट का नाम प्रदान करें DemoWebApp।
Step 1 - "नमूना सामग्री उत्पन्न करें" अनुभाग में, चुनें SimpleWebApplication।
यह एक नमूना परियोजना बनाएगा, DemoWebApp। वहां एक हैpubspec.yaml निर्भरता वाली फ़ाइल जिसे डाउनलोड करने की आवश्यकता है।
name: 'DemoWebApp'
version: 0.0.1
description: An absolute bare-bones web app.
#author: Your Name <[email protected]>
#homepage: https://www.example.com
environment:
sdk: '>=1.0.0 <2.0.0'
dependencies:
browser: '>=0.10.0 <0.11.0' dart_to_js_script_rewriter: '^1.0.1'
transformers:
- dart_to_js_script_rewriter
यदि आप वेब से जुड़े हैं, तो ये स्वचालित रूप से डाउनलोड हो जाएंगे, अन्यथा आप राइट-क्लिक कर सकते हैं pubspec.yaml और निर्भरताएँ प्राप्त करें।
वेब फ़ोल्डर में, आपको तीन फाइलें मिलेंगी: Index.html, main.dart, तथा style.css
index.html
<!DOCTYPE html>
<html>
<head>
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0">
<meta name = "scaffolded-by" content = "https://github.com/google/stagehand">
<title>DemoWebApp</title>
<link rel = "stylesheet" href = "styles.css">
<script defer src = "main.dart" type = "application/dart"></script>
<script defer src = "packages/browser/dart.js"></script>
</head>
<body>
<h1>
<div id = "output"></div>
</h1>
</body>
</html>
Main.dart
import 'dart:html';
void main() {
querySelector('#output').text = 'Your Dart web dom app is running!!!.';
}
चलाएं index.htmlफ़ाइल; आप अपनी स्क्रीन पर निम्न आउटपुट देखेंगे।
घटना से निपटना
dart:html पुस्तकालय प्रदान करता है onClickDOM तत्वों के लिए ईवेंट। सिंटैक्स दिखाता है कि कोई तत्व क्लिक इवेंट की एक स्ट्रीम को कैसे संभाल सकता है।
querySelector('#Id').onClick.listen(eventHanlderFunction);
querySelector() फ़ंक्शन दिए गए DOM से तत्व देता है और onClick.listen() एक ले जाएगा eventHandlerविधि जो एक क्लिक ईवेंट उठाया जाने पर आह्वान की जाएगी। का वाक्य विन्यासeventHandler नीचे दिया गया है -
void eventHanlderFunction (MouseEvent event){ }
आइए अब हम Dart में Event हैंडलिंग की अवधारणा को समझने के लिए एक उदाहरण लेते हैं।
TestEvent.html
<!DOCTYPE html>
<html>
<head>
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0">
<meta name = "scaffolded-by" content ="https://github.com/google/stagehand">
<title>DemoWebApp</title>
<link rel = "stylesheet" href = "styles.css">
<script defer src = "TestEvent.dart" type="application/dart"></script>
<script defer src = "packages/browser/dart.js"></script>
</head>
<body>
<div id = "output"></div>
<h1>
<div>
Enter you name : <input type = "text" id = "txtName">
<input type = "button" id = "btnWish" value="Wish">
</div>
</h1>
<h2 id = "display"></h2>
</body>
</html>
TestEvent.dart
import 'dart:html';
void main() {
querySelector('#btnWish').onClick.listen(wishHandler);
}
void wishHandler(MouseEvent event){
String name = (querySelector('#txtName') as InputElement).value;
querySelector('#display').text = 'Hello Mr.'+ name;
}