KEMBAR78
Core & ReactJS | PDF | Java Script | Software Engineering
0% found this document useful (0 votes)
336 views33 pages

Core & ReactJS

The document provides an overview of building Single Page Applications (SPAs) using ASP.NET Core and ReactJS, discussing the evolution of web development and the challenges faced before SPAs. It highlights the benefits of using ReactJS as a component-oriented library for creating user interfaces and outlines the integration of ASP.NET Core with JavaScriptServices for enhanced development. The presentation concludes with suggestions for further exploration, including advanced routing and server-side rendering.

Uploaded by

Muvvala Prudhvi
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
336 views33 pages

Core & ReactJS

The document provides an overview of building Single Page Applications (SPAs) using ASP.NET Core and ReactJS, discussing the evolution of web development and the challenges faced before SPAs. It highlights the benefits of using ReactJS as a component-oriented library for creating user interfaces and outlines the integration of ASP.NET Core with JavaScriptServices for enhanced development. The presentation concludes with suggestions for further exploration, including advanced routing and server-side rendering.

Uploaded by

Muvvala Prudhvi
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 33

1

ASP.NET Core & ReactJS


Toni Petrina
@to_pe
Synergy Sports Technology, GigPin, Microsoft MVP
2

Agenda
• SPA introduction
• ASP.NET Core, React, Typescript
• Conclusion
3

Time before SPA


• http://host/path
• Handle URL (routing)
• Go to database
• Generate HTML/CSS/JS and send to client
• Follow URL http://host/path/action
• Handle URL (routing)
• Go to database
• Generate HTML/CSS/JS and send to client
•…
4

2004 first SPA – GMail & AJAX


• How to generate HTML?
• How to handle styles?
• No module system for frontend
• CSS has similar issues – scoping, vars, etc…
5

Time before SPA


• http://host/path
• Fetch entire client side app

• Go to http://host/api/path
• Generate HTML/CSS/JS and send to client send JSON/XML/ProtoBuff
• Render result on client
• Follow URL http://host/path/action in client only! go to API endpoint
• Generate HTML/CSS/JS and send to client send JSON/XML/ProtoBuff
• …
6

Problems in modern web development


• Templating and DOM manipulation
• UI & logic decoupling (architectural patterns)
• Code organization (no modules in JS)
• Styles organization and preview
Templating…jQuery style 7

var root = $('#page-list-view-container');


root.empty();

app.pages.map(function (page) {
$("<a>")
.attr('href', "#")
.addClass(page.isDraft ? 'draft-page-litem' : 'published-page-litem')
.addClass('page-level-' + page.level)
.addClass(page.isDraft ? (page.isNew ? 'page-new' : 'page-draft') : 'page-published')
.attr('data-pageId', page.id)
.append($('<li>')
.text(page.name)
.prepend($('<span>')
.addClass('fa')
.addClass(page.level == 0 ? 'fa-home' : 'fa-file')
)
Mustache templating 8

var view = {
title: "Joe",
calc: function () {
return 2 + 4;
}
};

var output = Mustache.render("{{title}} spends {{calc}}", view);


DOM manipulation 9

// add class selected on click


$("#page-list-view-container [data-pageid=" + selectedPageId + "]")
.find("li")
.addClass('selected')
Event handling? 10

var addClickHandlerToSelectPages = function () {


draftPageItem = document.getElementsByClassName('draft-page-litem'),
publishedPageItem = document.getElementsByClassName('published-page-litem');

$(draftPageItem).add($(publishedPageItem)).on('click', function (e) {


e.preventDefault();

selectedPageId = this.getAttribute('data-pageid');

history.pushState({ selectedPage: selectedPageId }, 'page ' + selectedPageId, '?selectedPage=' + selectedPageId)

selectPage(selectedPageId)
});
}
UI updates? 11

var addClickHandlerToSelectPages = function () {


draftPageItem = document.getElementsByClassName('draft-page-litem'),
publishedPageItem = document.getElementsByClassName('published-page-litem');

$(draftPageItem).add($(publishedPageItem)).on('click', function (e) {


e.preventDefault();

selectedPageId = this.getAttribute('data-pageid');

history.pushState({ selectedPage: selectedPageId }, 'page ' + selectedPageId, '?selectedPage=' + selectedPageId)

selectPage(selectedPageId)
});
}
12
13

What is ReactJS?
• A JAVASCRIPT LIBRARY FOR BUILDING USER INTERFACES

• SPA Framework
• Declarative
• Functional
• Component oriented
• "Just a view layer"
14

• Klasa: React.Component

<div>
<span>{this.props.text}</span>
<button onClick={this.props.handleClick}>
Click me</button>
</div>
React component 15

import * as React from 'react';

export default class Header extends React.Component<any, any> {


render() {
return <h1>Title goes here</h2>
}
}
16

HTML inside JavaScripta ECMAScript?


17
18
19

SPA means SPA


• Single page – 1 or one view index.html
• Routing is client-side
• Server side routing can be used for heavy lifting
• Server side rendering is an option
20

Glossary
• .NET Core – platform
• ASP.NET Core – framework
• ReactJS – SPA library
• JavaScriptServices – handles SPA inside ASP.NET Core/replaces Razor

• Tools: npm, webpack, nuget, dotnet CLI


• Concepts: Single Page App, client-side routing
21

JavaScriptServices
• node.js se running under ASP.NET Core
• webpack used for bundling
• Hot Module Reload (HMR)
• Typescript – optional types for JavaScript

• https://github.com/aspnet/javascriptservices
22

Client side
23

Good start
• dotnet new react
• npm install
• dotnet run

• $env:ASPNETCORE_ENVIRONMENT="Development"
Dotnet watch 24

<DotNetCliToolReference
Include="Microsoft.DotNet.Watcher.Tools" Version="2.0.0" />

dotnet watch run


API Controller 25

[Route("api/[Controller]")]
public class ListController : Controller
{
public IActionResult Get()
{
return Ok(new[]
{
new {id=1, name="john"}
});
}
}
26

componentDidMount() {
fetch("/api/list")
.then(r => r.json() as Promise<Item[]>)
.then(items => this.setState({ items: items }))
}
27

async componentDidMount() {
let response = await fetch("/api/list")
let data = await response.json()
this.setState({ items: data })
}
Swashbuckle 28

dotnet add package Swashbuckle.AspNetCore


Routing! react-router 29

export default <Route component={Layout}>


<Route path='/' components={{ body: Home }} />
<Route path='/counter' components={{ body: Counter }} />
<Route path='/fetchdata' components={{ body: FetchData }}>
<Route path='(:startDateIndex)' /> {
/* Optional route segment that does not affect NavMenu highlighting */
}
</Route>
<Route path='/sample' components={{ body: Sample }} />
<Route path='/sampleredux' components={{ body: SampleRedux }} />
</Route>;
30

app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
// here you can see we make sure it doesn't start with /api, if it does, it'll 404 within .NET if it can't be found
app.MapWhen(x => !x.Request.Path.Value.StartsWith("/api"), builder =>
{
builder.UseMvc(routes =>
{
routes.MapSpaFallbackRoute(
name: "spa-fallback",
defaults: new { controller = "Home", action = "Index" });
});
});
EntityFrameworkCore 31

dotnet add package


Microsoft.EntityFrameworkCore.SqlServer
32

What next?
• Code splitting & Tree shaking
• Using external libraries
• Advanced routing
• Advanced state management
• Server Side Rendering
33
https://tpetrina.gitbooks.io/react-aspnetcore-training/content/

You might also like