A Complete Beginner's-Friendly guide to Understand JavaScript - Online learning v/s offline learning : The pros & cons
Hello and welcome to my comprehensive guide to learning JavaScript! If you're looking to take your web development skills to the next level, mastering JavaScript is a must.
In this post, I'll be covering everything you need to know to get started with JavaScript, including the basics of variables, data types, and operators, as well as more advanced topics like closures and prototypal inheritance.
I'll also be sharing pro tips for mastering JavaScript, as well as the advantages of learning this powerful programming language.
Whether you're a beginner or an experienced developer, this post has something for everyone. So, let's dive in and get started with JavaScript!
{tocify} $title={Table of Contents}
What is JavaScript?
JavaScript is a high-level, dynamic, and interpreted programming language that is used to create interactive websites and web applications. It was initially developed by Brendan Eich at Netscape in 1995 and has since become one of the most popular programming languages in use today.
JavaScript is a client-side language, meaning it runs in a user's web browser and can be used to create dynamic effects like animations, form validation, and interactive user interfaces.
It is also increasingly used on the server-side through technologies like Node.js. JavaScript is known for its versatility, allowing developers to create a wide range of web-based applications and tools.
Explanation: why learning JavaScript is important
Learning JavaScript is important for several reasons, especially if you are interested in web development or building web applications.
Here are some of the key reasons why JavaScript is such a valuable programming language to learn:
- Enhances interactivity and user experience: JavaScript enables developers to create dynamic and interactive web applications that can respond to user actions in real-time. This helps to create a more engaging and user-friendly experience for website visitors.
- Widely used: JavaScript is one of the most popular programming languages in use today, with a massive community of developers and a wide range of tools and frameworks available. This makes it a valuable skill to have for anyone interested in web development.
- Enables creation of web applications: JavaScript is a critical component in building modern web applications, allowing developers to create everything from simple form validation to complex, multi-page applications.
- High demand in the job market: Given its widespread use, there is a high demand for skilled JavaScript developers in the job market. Learning JavaScript can increase your career prospects and earning potential.
- Transferable skills: Many of the concepts and techniques used in JavaScript can be applied to other programming languages, making it a valuable skill to have even if you end up working with other languages in the future.
Overall, learning JavaScript can be a valuable investment for anyone interested in web development or building web-based applications. It is a versatile and powerful language that can help you create engaging and dynamic user experiences while also opening up a range of job opportunities in the tech industry.
The basics of JavaScript, including variables, data types, and operators
Here are some of the basics of JavaScript, including variables, data types, and operators:
- 1. Variables: Variables are used to store data values in JavaScript. They are declared using the “var”, “let”, or “const” keywords.
For example, to create a variable called “myNumber” that stores the value 5, you would write:
var myNumber = 5;{codeBox}
- 2. Data types: JavaScript supports several data types, including numbers, strings, booleans, objects, arrays, and null values.
For example, you could create a string variable by writing:
var myString = "Hello, world!";{codeBox}
- 3. Operators: JavaScript supports a range of operators for performing mathematical and logical operations on data values. Some common operators include:
1. Arithmetic operators, such as + (addition), - (subtraction), * (multiplication), and / (division)
2. Comparison operators, such as == (equal to), != (not equal to), > (greater than), and < (less than)
3. Logical operators, such as && (and), || (or), and ! (not)
For example, you could use operators to perform mathematical operations on variables:
var x = 10;var y = 5;var z = x + y; // z now equals 15{codeBox}
These are just a few of the basics of JavaScript, but they form the foundation of many more advanced programming concepts. By mastering these fundamentals, you'll be well on your way to becoming a skilled JavaScript developer.
Introduction to JavaScript syntax and Explanation on how to write a basic script
JavaScript syntax refers to the set of rules and conventions that dictate how JavaScript code should be written. Here are some of the key aspects of JavaScript syntax and how to write a basic script:
- 1. Statements: JavaScript code is made up of statements, which are individual instructions that tell the browser what to do. Statements are typically terminated with a semicolon (;).
For example, the following code contains two statements:
var x = 5;console.log(x);{codeBox}
- 2. Comments: JavaScript also supports comments, which allow you to add notes and explanations to your code without affecting how it is executed. Comments can be either single-line (using //) or multi-line (using /* ... */).
For example:
// This is a single-line comment/*This is amulti-line comment*/{codeBox}
- 3. Variables: As mentioned earlier, variables are used to store data values in JavaScript. To create a variable, you can use the var, let, or const keywords followed by the variable name and an optional initial value.
For example:
var x = 5;let y = "Hello";const z = true;{codeBox}
- 4. Functions: Functions are reusable blocks of code that perform a specific task. They are declared using the function keyword, followed by the function name, optional parameters, and the code block enclosed in curly braces.
For example:
function sayHello(name) {console.log("Hello, " + name);}sayHello("John"); // prints "Hello, John"{codeBox}
To write a basic JavaScript script, you can create a new file with a .js extension, and add your code using any text editor or integrated development environment (IDE).
For example, you could create a script that prompts the user to enter their name and then displays a personalized greeting:
var name = prompt("What is your name?");console.log("Hello, " + name + "!");{codeBox}
When you run this script in your browser or Node.js environment, it will prompt the user to enter their name and then print a greeting to the console.
Explanation: How functions work in JavaScript and how to define and call them
Functions are a fundamental concept in JavaScript and allow you to group a set of related instructions together into a single reusable block of code.
Functions can be called and executed multiple times in your code, making them a powerful tool for organizing and simplifying your code.
In JavaScript, a function is defined using the function keyword followed by the name of the function, a set of parentheses, and a set of curly braces that contain the function's code.
Here's an example of a simple function that takes two arguments and returns their sum:
function addNumbers(num1, num2) {return num1 + num2;}{codeBox}
In this example, the function is named “addNumbers” and takes two parameters (“num1” and “num2”). The body of the function contains a single statement that adds the two numbers together and returns the result.
To call the function and use its result, you can simply use its name followed by a set of parentheses containing the arguments you want to pass to the function.
For example:
let result = addNumbers(5, 7);console.log(result); // Output: 12{codeBox}
In this example, we're calling the “addNumbers” function with the arguments 5 and 7, which returns 12. We then store the result in a variable named result and print it to the console using the “console.log” function.
Functions in JavaScript can also be defined as function expressions, which allows you to define a function as a variable and pass it around as a value.
For example:
const multiplyNumbers = function(num1, num2) {return num1 * num2;};let result = multiplyNumbers(5, 7);console.log(result); // Output: 35{codeBox}
In this example, we're defining a function expression named “multiplyNumbers” and assigning it to a variable using the “const” keyword. We then call the function with the arguments 5 and 7, which returns 35.
Functions in JavaScript can also be defined with default parameters, rest parameters, and arrow functions, which provide additional flexibility and functionality.
In summary, functions are an essential concept in JavaScript that allow you to group a set of related instructions together into a single reusable block of code.
You can define functions using the function keyword or as function expressions, and call them using their name followed by a set of parentheses containing the arguments you want to pass to the function.
Introduction to the concept of objects in JavaScript and how to create and use them
In JavaScript, an object is a collection of related data and functions that represent a single entity. Objects are a fundamental concept in JavaScript and are used extensively in web development to represent things like web pages, user interfaces, and data models.
Objects in JavaScript are defined using curly braces {} and consist of one or more key-value pairs, where the key is a string or symbol that represents a property name, and the value is any JavaScript value, including other objects.
Here's an example of a simple object that represents a person:
const person = {firstName: "John",lastName: "Doe",age: 30,hobbies: ["reading", "coding", "traveling"],address: {street: "123 Main St",city: "Anytown",state: "CA",zipCode: "12345"},sayHello: function() {console.log(`Hello, my name is ${this.firstName} ${this.lastName}.`);}};{codeBox}
In this example, the “person” object has several properties, including firstName, lastName, age, hobbies, and address. The hobbies property is an array of strings, and the address property is another object that contains several sub-properties. Finally, the person object also has a sayHello method, which is a function that prints a greeting to the console using the console.log function.
To access the properties of an object, you can use dot notation or bracket notation.
For example:
console.log(person.firstName); // Output: "John"console.log(person["lastName"]); // Output: "Doe"console.log(person.hobbies[1]); // Output: "coding"console.log(person.address.city); // Output: "Anytown"{codeBox}
In this example, we're using dot notation to access the firstName and hobbies properties, and bracket notation to access the lastName and address.city properties.
To call a method of an object, you can use dot notation followed by a set of parentheses.
For example:
person.sayHello(); // Output: "Hello, my name is John Doe."{codeBox}
In this example, we're calling the sayHello method of the “person” object, which prints a greeting to the console.
In summary, objects are a fundamental concept in JavaScript that allow you to group related data and functions together into a single entity.
Objects are defined using curly braces {} and consist of one or more key-value pairs. You can access the properties of an object using dot notation or bracket notation, and call methods of an object using dot notation followed by a set of parentheses.
Examples: How functions and objects can be used together to build complex applications
Functions and objects are two of the most powerful features in JavaScript, and they can be used together to build complex applications.
Here are a few examples of how functions and objects can be used together:
1. Object-oriented programming (OOP)
In OOP, you define classes that represent objects and encapsulate their properties and methods. You can then create instances of these classes and use them to perform specific tasks.
Here's an example of a simple class that represents a car:
class Car {constructor(make, model, year) {this.make = make;this.model = model;this.year = year;}start() {console.log(`Starting the ${this.make} ${this.model}...`);}stop() {console.log(`Stopping the ${this.make} ${this.model}...`);}}const myCar = new Car("Honda", "Civic", 2021);myCar.start(); // Output: "Starting the Honda Civic..."myCar.stop(); // Output: "Stopping the Honda Civic..."{codeBox}
In this example, we're using a class to represent a car object. The class has three properties (make, model, and year) and two methods (start and stop).
We can create a new instance of the Car class using the “new” keyword and then call the “start” and “stop” methods on the instance.
2. Modular programming
In modular programming, you break your application down into smaller, reusable modules that each perform a specific task. You can then combine these modules to create more complex applications.
Here's an example of a simple module that provides a function for calculating the area of a rectangle:
const rectangle = {width: 5,height: 10,area() {return this.width * this.height;}};console.log(rectangle.area()); // Output: 50{codeBox}
In this example, we're using an object (rectangle) to represent a rectangle. The object has two properties (width and height) and one method (area).
We can call the “area” method on the “rectangle” object to calculate its area.
3. Event handling
In web development, you often need to handle user events, such as clicks, keystrokes, and form submissions. You can use functions and objects together to handle these events and update the user interface accordingly.
Here's an example of a simple function that handles a button click event:
const button = document.querySelector("button");function handleClick() {console.log("Button clicked!");}button.addEventListener("click", handleClick);{codeBox}
In this example, we're using the “querySelector” method to select a button element on the web page. We're then defining a function (handleClick) that logs a message to the console when the button is clicked. Finally, we're using the “addEventListener” method to register the “handleClick” function as the event handler for the button's click event.
These are just a few examples of how functions and objects can be used together to build complex applications. With JavaScript's powerful features and flexible syntax, the possibilities are virtually endless.
More advanced topics in JavaScript, such as closures, prototypal inheritance, and the event loop
JavaScript is a powerful language with many advanced topics that can help you write more efficient and effective code.
Here are some of the most important advanced topics to know:
1. Closures
A closure is a function that has access to the variables in its parent scope, even after the parent function has returned. This can be useful for creating private variables or for creating functions that “remember” certain values.
Here's an example of a closure:
function makeCounter() {let count = 0;return function() {count++;console.log(count);}}const counter = makeCounter();counter(); // Output: 1counter(); // Output: 2counter(); // Output: 3{codeBox}
In this example, makeCounter is a function that returns another function. The returned function has access to the “count” variable in its parent scope, and can increment it each time it's called.
2. Prototypal inheritance
In JavaScript, objects can inherit properties and methods from other objects. This is known as prototypal inheritance.
Here's an example of using prototypal inheritance to create a new object:
const person = {name: "John",age: 30,greet() {console.log(`Hello, my name is ${this.name} and I'm ${this.age} years old.`);}};const employee = Object.create(person);employee.jobTitle = "Software Engineer";console.log(employee.name); // Output: "John"console.log(employee.age); // Output: 30employee.greet(); // Output: "Hello, my name is John and I'm 30 years old."{codeBox}
In this example, we're using the Object.create method to create a new object (employee) that inherits from an existing object (person).
The employee object has its own property (jobTitle) and can also access the properties and methods of the person object.
3. The event loop
The event loop is a key concept in JavaScript that allows the language to be asynchronous. When a long-running task (such as an HTTP request) is executed, the JavaScript engine will continue to execute other tasks in the meantime, rather than waiting for the long-running task to complete.
Here's an example of using the event loop to make an asynchronous HTTP request:
function getData(url) {return new Promise((resolve, reject) => {const xhr = new XMLHttpRequest();xhr.open("GET", url);xhr.onload = () => {if (xhr.status === 200) {resolve(xhr.response);} else {reject(new Error(`Failed to load data. Status: ${xhr.status}`));}};xhr.send();});}getData("https://jsonplaceholder.typicode.com/posts").then((data) => console.log(data)).catch((error) => console.error(error));{codeBox}
In this example, we're using the XMLHttpRequest object to make an HTTP request to a remote server. We're wrapping this request in a Promise object, which allows us to handle the response asynchronously.
We can then use the then and catch methods to handle the response or any errors that occur.
By understanding these advanced topics, you can write more efficient and effective code in JavaScript, and take advantage of its powerful features.
Tips and tricks for mastering JavaScript
Here are some tips and tricks for mastering JavaScript:
- Practice coding challenges: There are many websites and platforms that offer coding challenges and exercises to help you improve your JavaScript skills. Some popular examples include HackerRank, Codewars, and LeetCode. These platforms allow you to practice solving problems, learn new techniques, and improve your coding speed.
- Participate in coding communities: Join online coding communities and forums, such as Stack Overflow or Reddit's r/learnjavascript, to ask questions, share ideas, and learn from others. Participating in these communities can help you stay motivated, get feedback on your code, and learn new techniques and best practices.
- Build real-world applications: Building real-world applications is one of the best ways to master JavaScript. Choose a project that interests you and start building. This will help you apply your knowledge, learn new concepts, and gain valuable experience.
- Read books and articles: There are many great books and articles on JavaScript that can help you deepen your understanding of the language. Some popular titles include “JavaScript: The Definitive Guide” by David Flanagan, “Eloquent JavaScript” by Marijn Haverbeke, and “You Don't Know JS” by Kyle Simpson.
- Attend workshops and conferences: Attending workshops and conferences is a great way to learn from experts, network with other developers, and stay up-to-date with the latest trends and technologies in JavaScript.
- Practice debugging: Debugging is a critical skill for any programmer. Practice debugging your code and learn how to use tools such as the browser console and debugging tools like Visual Studio Code's debugger.
- Stay up-to-date: JavaScript is constantly evolving, with new features and best practices emerging regularly. Stay up-to-date with the latest trends and updates by reading blogs, following experts on social media, and attending webinars or conferences.
By following these tips and tricks, you can master JavaScript and become a skilled and confident developer.
Common mistakes to avoid when learning and working with JavaScript
Here are some common mistakes to avoid when learning and working with JavaScript:
- Using undeclared variables: Always declare your variables with the var, let, or const keyword before using them in your code. Failing to declare your variables can lead to unexpected behavior and errors in your code.
- Not using semicolons: JavaScript does not require semicolons at the end of statements, but it's good practice to include them to prevent potential issues with automatic semicolon insertion.
- Not handling errors properly: Always handle errors in your code by using try-catch blocks or other error handling techniques. Failing to handle errors can lead to unexpected behavior and crashes in your application.
- Not understanding the scope of variables: JavaScript has function-level scoping, which means that variables declared within a function are not accessible outside of that function. Be mindful of the scope of your variables to avoid unexpected behavior.
- Misusing ‘==’ and ‘===’ operators: The == operator compares values without checking their data types, while the === operator compares both values and data types. Misusing these operators can lead to unexpected results and bugs in your code.
- Not optimizing code for performance: JavaScript can be a performance-intensive language, and inefficient code can lead to slow-running applications. Always optimize your code for performance by avoiding unnecessary loops, minimizing DOM manipulation, and using caching techniques.
- Not testing code thoroughly: Always test your code thoroughly to ensure that it functions as expected and that there are no bugs or issues. Use automated testing frameworks like Jest or Mocha, and manually test your code in different environments and scenarios.
By avoiding these common mistakes, you can write clean, efficient, and bug-free JavaScript code.
The advantages of learning JavaScript
There are many advantages to learning JavaScript, including:
- Building interactive web applications: JavaScript is a powerful language for creating interactive and dynamic web applications. By learning JavaScript, you can build everything from simple dropdown menus and image sliders to complex web applications with features like real-time updates, data visualization, and user authentication.
- Increasing job opportunities: JavaScript is one of the most in-demand programming languages in the tech industry, and proficiency in JavaScript can open up a wide range of job opportunities. Many web development positions require knowledge of JavaScript, and there are also many specialized roles, such as front-end developer, full-stack developer, and JavaScript engineer, that focus specifically on JavaScript development.
- Enhancing problem-solving skills: Learning JavaScript requires critical thinking and problem-solving skills. You'll need to be able to break down problems into smaller parts, use logic to solve them, and test your solutions. These skills can be applied to other areas of your life and can help you become a more effective problem solver overall.
- Building a portfolio: Learning JavaScript provides a great opportunity to build a portfolio of web applications that you can showcase to potential employers or clients. By building a diverse portfolio of projects, you can demonstrate your skills and creativity as a developer and increase your chances of landing a job or project.
- Collaborating with other developers: JavaScript is a popular language with a large community of developers, and there are many opportunities to collaborate with other developers on open-source projects, code challenges, and online communities. By working with others, you can learn new techniques, get feedback on your code, and build relationships with other developers in the industry.
Overall, learning JavaScript can provide many benefits, both personally and professionally. Whether you're interested in building web applications, pursuing a career in tech, or simply enhancing your problem-solving skills, JavaScript is a valuable language to learn.
World best companies or industries that rely heavily on JavaScript
JavaScript is an essential language for modern web development, and many of the world's top companies rely heavily on it.
Here are some examples:
- Google: Google is one of the largest technology companies in the world, and they use JavaScript extensively across many of their products, including Google Search, Google Maps, and Gmail.
- Facebook: Facebook is one of the world's largest social media companies, and they use JavaScript extensively to build their web applications, including Facebook.com, Instagram, and WhatsApp.
- Amazon: Amazon is one of the largest e-commerce companies in the world, and they use JavaScript to build their web applications, including Amazon.com and the Amazon Web Services (AWS) console.
- Netflix: Netflix is a leading streaming service, and they use JavaScript to build their web applications, including the Netflix website and the Netflix app.
- Airbnb: Airbnb is a popular travel and hospitality company, and they use JavaScript to build their web applications, including the Airbnb website and mobile app.
- Uber: Uber is a leading ride-sharing company, and they use JavaScript to build their web applications, including the Uber website and mobile app.
- LinkedIn: LinkedIn is a professional networking site, and they use JavaScript to build their web applications, including the LinkedIn website and mobile app.
These are just a few examples of the many companies and industries that rely heavily on JavaScript for their web development needs.
Online resources for learning JavaScript:
There are many online resources available for learning JavaScript, including interactive tutorials, video courses, and reference websites.
Here are some of the most popular options:
- Codecademy:
Codecademy is an interactive learning platform that offers a range of courses on web development topics, including JavaScript.
The JavaScript course on Codecademy covers the basics of the language, including variables, data types, and functions, as well as more advanced concepts like object-oriented programming and the Document Object Model (DOM).
The course is divided into several modules, each with interactive lessons and coding challenges to reinforce your understanding. Additionally, Codecademy offers a Pro version with access to additional features and projects.
- W3Schools:
W3Schools is a web development reference site that offers a range of tutorials, examples, and reference materials on various web development technologies, including JavaScript.
The JavaScript tutorial on W3Schools covers the basics of the language, including variables, data types, operators, and control structures.
It also covers more advanced concepts like functions, objects, and the DOM. The tutorial includes examples and interactive exercises to help you apply what you've learned.
- FreeCodeCamp:
FreeCodeCamp is a non-profit organization that offers a free full-stack web development curriculum, including a JavaScript course.
The JavaScript course on FreeCodeCamp covers the basics of the language, including variables, data types, and functions, as well as more advanced concepts like recursion and higher-order functions.
The course includes interactive lessons and coding challenges, as well as projects to build real-world applications.
- Udemy:
Udemy is an online learning platform that offers a range of courses on various topics, including JavaScript.
The JavaScript courses on Udemy cover a wide range of topics, from the basics of the language to more advanced topics like frameworks and libraries.
The courses are taught by experienced instructors and typically include video lectures, coding exercises, and quizzes to test your knowledge.
Overall, these online resources provide a great starting point for learning JavaScript, whether you're a beginner or an experienced developer looking to expand your skills.
Each resource has its own strengths and weaknesses, so it's worth exploring several options to find the one that works best for your learning style and goals.
OFF-line resources for learning JavaScript:
While online resources are convenient and accessible, some people prefer to learn using offline resources. Here are some options for learning JavaScript offline:
- Books:
There are many books available that cover JavaScript in-depth. Some popular titles include:
“JavaScript: The Definitive Guide” by David Flanagan,
“Eloquent JavaScript” by Marijn Haverbeke, and
“JavaScript and JQuery: Interactive Front-End Web Development” by Jon Duckett.
These books provide a comprehensive overview of the language and its features, as well as practical examples and exercises to help you apply what you've learned.
- Courses:
While online courses are popular, there are also many in-person courses available for learning JavaScript.
These can be found through local universities, community colleges, or training centers. In-person courses offer the opportunity to interact with instructors and peers, receive immediate feedback, and ask questions in real-time.
- Meetups:
Meetups are gatherings of people with similar interests who come together to network, share ideas, and learn from each other. There are many JavaScript-related meetups held in cities around the world.
Attending meetups can be a great way to connect with other developers, learn new techniques, and get feedback on your work.
- Workshops and Conferences:
Workshops and conferences are intensive events where participants can learn from expert speakers and instructors. There are many workshops and conferences dedicated to JavaScript, such as JavaScript Conferences, NodeConf, and JSConf.
These events often offer hands-on training, code reviews, and opportunities to network with other developers.
Overall, offline resources for learning JavaScript can provide a more focused and immersive learning experience. Whether you choose to read books, attend in-person courses or events, or participate in meetups, there are many options available to help you build your skills in JavaScript.
Tips for staying motivated while learning javascript offline
Learning JavaScript offline can be a great way to master the language, but it can also be challenging to stay motivated and engaged without the structure and support of an online course or community.
Here are some tips for staying motivated while learning JavaScript offline:
- Set clear goals: Before you start learning, define your goals and objectives. This can help you stay focused and motivated, and ensure that you're making progress towards what you want to achieve.
- Create a schedule: Set aside a specific time each day or week to focus on learning JavaScript. Treat this time as you would any other appointment or commitment, and make it a priority.
- Break it down: Learning JavaScript can be overwhelming, especially when you're working offline. Break it down into smaller, manageable tasks, and tackle one at a time. This can help you feel accomplished and motivated as you complete each task.
- Take breaks: Learning for long periods without a break can lead to burnout and fatigue. Take regular breaks to recharge your brain and maintain your focus.
- Practice regularly: Practice is key to learning JavaScript, especially offline. Write code on paper or in a text editor, and try to solve problems or create applications without relying on online resources.
- Find a study partner: Learning with someone else can help keep you motivated and engaged. Find a study partner or join a local study group to share ideas and get feedback.
- Celebrate your progress: Celebrate your achievements, no matter how small. Recognize your progress and use it as motivation to continue learning.
By implementing these tips, you can stay motivated and engaged while learning JavaScript offline, and achieve your goals more effectively.
Conclusion:
In conclusion, JavaScript is a crucial programming language for modern web development, and learning it can lead to many benefits, including building interactive web applications, increasing job opportunities, and enhancing problem-solving skills.
We covered the basics of JavaScript, including variables, data types, operators, syntax, functions, and objects. We also discussed advanced topics such as closures, prototypal inheritance, and the event loop.
We provided a list of online and offline resources for learning JavaScript, including Codecademy, W3Schools, and books. Additionally, we gave tips for staying motivated while learning and mastering JavaScript, including practicing coding challenges, participating in coding communities, and building real-world applications.
Lastly, we provided examples of common mistakes to avoid and showcased the top companies and industries that rely heavily on JavaScript, including Google, Facebook, Amazon, Netflix, Airbnb, Uber, and LinkedIn.
Overall, mastering JavaScript is essential for anyone interested in web development and can lead to a fulfilling career in tech.
small note:
Friends, according to my expertise, I have written complete information to help you with “Tips and tricks for mastering JavaScript” If this post is favourable for you or not, please tell me by commenting.
If you liked this post, do not forget to share it with your friends so they can get information about it.
You can ask us through comments if you still have questions or doubts, I will answer all your questions, and you can contact us for more information.
Please tell us through the comment section if you think we miss anything.