Book Image

Modern Web Development with ASP.NET Core 3 - Second Edition

By : Ricardo Peres
Book Image

Modern Web Development with ASP.NET Core 3 - Second Edition

By: Ricardo Peres

Overview of this book

ASP.NET has been the preferred choice of web developers for a long time. With ASP.NET Core 3, Microsoft has made internal changes to the framework along with introducing new additions that will change the way you approach web development. This second edition has been thoroughly updated to help you make the most of the latest features in the framework, right from gRPC and conventions to Blazor, which has a new chapter dedicated to it. You’ll begin with an overview of the essential topics, exploring the Model-View-Controller (MVC) pattern, various platforms, dependencies, and frameworks. Next, you’ll learn how to set up and configure the MVC environment, before delving into advanced routing options. As you advance, you’ll get to grips with controllers and actions to process requests, and later understand how to create HTML inputs for models. Moving on, you'll discover the essential aspects of syntax and processes when working with Razor. You'll also get up to speed with client-side development and explore the testing, logging, scalability, and security aspects of ASP.NET Core. Finally, you'll learn how to deploy ASP.NET Core to several environments, such as Azure, Amazon Web Services (AWS), and Docker. By the end of the book, you’ll be well versed in development in ASP.NET Core and will have a deep understanding of how to interact with the framework and work cross-platform.
Table of Contents (26 chapters)
1
Section 1: The Fundamentals of ASP.NET Core 3
7
Section 2: Improving Productivity
14
Section 3: Advanced Topics
Appendix A: The dotnet Tool

JavaScript interoperability

Since Blazor runs on the browser, there are situations where we may need to execute a browser-native functionality. For that, there is no way to avoid JavaScript! There are two ways in which JavaScript and Blazor (.NET) can interoperate, as follows:

  • .NET calls JavaScript functions.
  • JavaScript calls .NET methods.

Calling JavaScript functions from .NET

Blazor can call any JavaScript function that is present on the hosting web page. It does this through the IJSRuntime object, which is automatically made available through the DI framework when you register Blazor.

For example, on the .razor file, add this code:

@inject IJSRuntime JSRuntime;

function add(a, b) { return a + b; }

@code
{
var result = await JSRuntime.InvokeAsync<int>("add", 1, 1);
}

IJSRuntime allows you to invoke any function by its name, passing an arbitrary number of parameters and receiving a strongly...