COURSES
MBAData Science & AnalyticsDoctorate Software & Tech AI | ML MarketingManagement
Professional Certificate Programme in HR Management and AnalyticsPost Graduate Certificate in Product ManagementExecutive Post Graduate Program in Healthcare ManagementExecutive PG Programme in Human Resource ManagementMBA in International Finance (integrated with ACCA, UK)Global Master Certificate in Integrated Supply Chain ManagementAdvanced General Management ProgramManagement EssentialsLeadership and Management in New Age BusinessProduct Management Online Certificate ProgramStrategic Human Resources Leadership Cornell Certificate ProgramHuman Resources Management Certificate Program for Indian ExecutivesGlobal Professional Certificate in Effective Leadership and ManagementCSM® Certification TrainingCSPO® Certification TrainingLeading SAFe® 5.1 Training (SAFe® Agilist Certification)SAFe® 5.1 POPM CertificationSAFe® 5.1 Scrum Master Certification (SSM)Implementing SAFe® 5.1 with SPC CertificationSAFe® 5 Release Train Engineer (RTE) CertificationPMP® Certification TrainingPRINCE2® Foundation and Practitioner Certification
Law
Job Linked
Bootcamps
Study Abroad
MS in Data AnalyticsMS in Project ManagementMS in Information TechnologyMasters Degree in Data Analytics and VisualizationMasters Degree in Artificial IntelligenceMBS in Entrepreneurship and MarketingMSc in Data AnalyticsMS in Data AnalyticsMS in Computer ScienceMaster of Science in Business AnalyticsMaster of Business Administration MS in Data ScienceMS in Information TechnologyMaster of Business AdministrationMS in Applied Data ScienceMaster of Business Administration | STEMMS in Data AnalyticsM.Sc. Data Science (60 ECTS)Master of Business AdministrationMS in Information Technology and Administrative Management MS in Computer Science Master of Business Administration Master of Business Administration-90 ECTSMSc International Business ManagementMS Data Science Master of Business Administration MSc Business Intelligence and Data ScienceMS Data Analytics MS in Management Information SystemsMSc International Business and ManagementMS Engineering ManagementMS in Machine Learning EngineeringMS in Engineering ManagementMSc Data EngineeringMSc Artificial Intelligence EngineeringMPS in InformaticsMPS in Applied Machine IntelligenceMS in Project ManagementMPS in AnalyticsMS in Project ManagementMS in Organizational LeadershipMPS in Analytics - NEU CanadaMBA with specializationMPS in Informatics - NEU Canada Master in Business AdministrationMS in Digital Marketing and MediaMSc Sustainable Tourism and Event ManagementMSc in Circular Economy and Sustainable InnovationMSc in Impact Finance and Fintech ManagementMS Computer ScienceMBA in Technology, Innovation and EntrepreneurshipMSc Data Science with Work PlacementMSc Global Business Management with Work Placement MBA with Work PlacementMS in Robotics and Autonomous SystemsMS in Civil EngineeringMS in Internet of ThingsMSc International Logistics and Supply Chain ManagementMBA- Business InformaticsMSc International ManagementMBA in Strategic Data Driven ManagementMSc Digital MarketingMBA Business and MarketingMSc in Sustainable Global Supply Chain ManagementMSc Digital Business Analytics MSc in International HospitalityMSc Luxury and Innovation ManagementMaster of Business Administration-International Business ManagementMS in Computer EngineeringMS in Industrial and Systems EngineeringMaster in ManagementMSc MarketingMSc Global Supply Chain ManagementMS in Information Systems and Technology with Business Intelligence and Analytics ConcentrationMSc Corporate FinanceMSc Data Analytics for BusinessMaster of Business AdministrationMaster of Business AdministrationMaster of Business AdministrationMSc in International FinanceMSc in International Management and Global LeadershipMaster of Business AdministrationBachelor of BusinessMaster of Business Administration 60 ECTSMaster of Business Administration 90 ECTSMaster of Business Administration 90 ECTSBachelor of Business AnalyticsBachelor of Information TechnologyMaster of Business AdministrationMBA Business AnalyticsMSc in Marketing Analytics and Data IntelligenceMS Biotechnology Management and EntrepreneurshipMSc in Luxury and Fashion ManagementMaster of Business Administration (90 ECTS)Bachelor of Business Administration (180 ECTS)B.Sc. Computer Science (180 ECTS) MSc in International Corporate Finance MSc in Sustainable Luxury and Creative IndustriesMSc Digital MarketingMSc Global Supply Chain Management (PGMP)MSc Marketing (PGMP)MSc Corporate Finance (PGMP)MSc Data Analytics for Business (PGMP)MS Business AnalyticsMaster of Business AdministrationMS Quantitative FinanceMS Fintech Management
For College Students

Understanding Javascript Callbacks with an Example

$$/$$

Now is the time to look at callbacks in detail. Follow along with Srishti in the next video.

$$/$$

In the last video, you looked at an example where you are getting the name of a user from the server and after getting the name, you want to greet the user. Now, you know that getting data from the server will actually take some time. In order to mock the functionality of getting the name from the server, you use a setTimeout() method and assume that the server will respond with the name from the database after 2 seconds. Following is the code, which you looked and represents this scenario:

 

Code Snippet:

let name;

const getName = () => {
   // get data from database
   setTimeout(() => {
       name = "Srishti";
   }, 2000); 
}

const greet = () => {
   console.log(`Hello ${name}`);
}

getName();
greet();

 

Output:

Hello undefined

 

You also looked at the problem where the greet() function is called before the getName() function is able to assign a value to the name variable, thus printing the value of name variable as undefined.
 

You looked at one of the solutions to this problem as making the greet() function an anonymous function but this is not what really happens in practice.

 

Look at the next video to learn from Srishti how this problem can be solved using a callback.

$$/$$

In the last video, you learned how a callback can be used to solve the above problem with asynchronous programming. You also learned that callback is not a keyword but just the name given to a parameter to hold a function. You can name it whatever you like, but just keep it meaningful.

Following is the code utilizing callbacks which you looked at in the last video:

Code Snippet:

let name;

let getName = (cb) => {
	// get name from DB
	setTimeout(() => {
		name = "Srishti";
		cb();
	}, 2000);
}

let greet = () => {
	console.log(`Hello ${name}`);
}

getName(greet);


Output:

Hello Srishti

 

If you are still not sure how the solution worked using callbacks, watch the next video where Srishti explains again in detail the flow in which the solution code works.

$$/$$

Hope that the solution using a callback to the above problem is clear to you!

 

Till now, you have seen just a normal callback without accepting any argument. In the next video, you’ll look at how an argument can be passed to a callback and how it can handle it.

$$/$$

Following is the code snippet, which you looked at in the last video:

Code Snippet:

let getName = (cb) => {
	let name;
	// get name from DB
	setTimeout(() => {
		name = "Srishti";
		cb(name);
	}, 2000);
}

let greet = (nameVal) => {
	console.log(`Hello ${nameVal}`);
}

getName(greet);


Output:

Hello Srishti

 

$$/$$