JavaScript and TypeScript Tasks with React, Angular, or Vue in Visible Studio 2022 with or with out .NET

JavaScript and TypeScript Tasks with React, Angular, or Vue in Visible Studio 2022 with or with out .NET



I used to be studying Gabby’s weblog put up concerning the new TypeScript/JavaScript challenge expertise in Visible Studio 2022. You must learn the docs on JavaScript and TypeScript in Visible Studio 2022.

For those who’re used to ASP.NET apps when you consider apps which might be JavaScript heavy, “entrance finish apps” or TypeScript targeted, it may be complicated as to “the place does .NET slot in?”

It’s essential to take into account the obligations of your varied initiatives or subsystems and the a number of completely legitimate methods you possibly can construct a web page or net app. Let’s take into account just some:

  1. An ASP.NET Net app that renders HTML on the server however makes use of TS/JS
    • This will likely have a Net API, Razor Pages, with or with out the MVC sample.
    • You possibly have simply added JavaScript by way of <script> tags
    • Perhaps you added a script minimizer/minifier job
    • May be complicated as a result of it may possibly really feel like your app must ‘construct each the consumer and the server’ from one challenge
  2. A largely JavaScript/TypeScript frontend app the place the HTML might be served from any net server (node, kestrel, static net apps, nginx, and so forth)
    • This app might use Vue or React or Angular however it’s not an “ASP.NET app”
    • It calls backend Net APIs which may be served by ASP.NET, Azure Capabilities, third social gathering REST APIs, or the entire above
    • This state of affairs has generally been complicated for ASP.NET builders who might get confused about accountability. Who builds what, the place do issues find yourself, how do I construct and deploy this?

VS2022 brings JavaScript and TypeScript help into VS with a full JavaScript Language Service primarily based on TS. It offers a TypeScript NuGet Package deal so you possibly can construct your complete app with MSBuild and VS will do the fitting factor.

NEW: Beginning in Visible Studio 2022, there’s a new JavaScript/TypeScript challenge sort (.esproj) that permits you to create standalone Angular, React, and Vue initiatives in Visible Studio.

The .esproj idea is nice for folk aware of Visible Studio as we all know {that a} Resolution incorporates a number of Tasks. Visible Studio manages recordsdata for a single utility in a Mission. The challenge contains supply code, sources, and configuration recordsdata. On this case we are able to have a .csproj for a backend Net API and an .esproj that makes use of a consumer aspect template like Angular, React, or Vue.

Factor is, traditionally when Visible Studio supported Angular, React, or Vue, it is templates have been outdated and never up to date sufficient. VS2022 makes use of the native CLIs for these entrance ends, fixing that drawback with Angular CLI, Create React App, and Vue CLI.

If I’m in VS and go “File New Mission” there are Standalone templates that resolve Instance 2 above. I am going to choose JavaScript React.

Standalone JavaScript Templates in VS2022

Then I am going to click on “Add integration for Empty ASP.NET Net API. This can give me a frontend with javascript able to name a ASP.NET Net API backend. I am going to observe alongside right here.

Standalone JavaScript React Template

It then makes use of the React CLI to make the entrance finish, which once more, is cool because it’s no matter model I would like it to be.

React Create CLI

Then I am going to add my ASP.NET Net API backend to the identical resolution, so now I’ve an esproj and a csproj like this

frontend and backend

Now I’ve a pleasant clear two challenge system – on this case extra JavaScript targeted than .NET targeted. This one makes use of npm to startup the challenge utilizing their net growth server and proxyMiddleware to proxy localhost:3000 calls over to the ASP.NET Net API challenge.

Here’s a React app served by npm calling over to the Climate service served from Kestrel on ASP.NET.

npm app running in VS 2022 against an ASP.NET Web API

That is inverted than most ASP.NET Of us are used to, and that is OK. This reveals me that Visible Studio 2022 can help both growth model, use the CLI that’s put in for no matter Frontend Framework, and permit me to decide on what net server and net browser (by way of Launch.json) I would like.

If you wish to flip it, and put ASP.NET Core as the first after which usher in some TypeScript/JavaScript, observe this tutorial as a result of that is additionally doable!


Sponsor: Make login Auth0’s drawback. Not yours. Present the handy login options your prospects need, like social login, multi-factor authentication, single sign-on, passwordless, and extra. Get began without cost.




About Scott

Scott Hanselman is a former professor, former Chief Architect in finance, now speaker, guide, father, diabetic, and Microsoft worker. He’s a failed stand-up comedian, a cornrower, and a e-book writer.

facebook
bluesky
subscribe
About   Publication

Internet hosting By
Hosted on Linux using .NET in an Azure App Service








author avatar
roosho Senior Engineer (Technical Services)
I am Rakib Raihan RooSho, Jack of all IT Trades. You got it right. Good for nothing. I try a lot of things and fail more than that. That's how I learn. Whenever I succeed, I note that in my cookbook. Eventually, that became my blog. 
rooshohttps://www.roosho.com
I am Rakib Raihan RooSho, Jack of all IT Trades. You got it right. Good for nothing. I try a lot of things and fail more than that. That's how I learn. Whenever I succeed, I note that in my cookbook. Eventually, that became my blog. 

Related Articles

LEAVE A REPLY

Please enter your comment!
Please enter your name here


Latest Articles

author avatar
roosho Senior Engineer (Technical Services)
I am Rakib Raihan RooSho, Jack of all IT Trades. You got it right. Good for nothing. I try a lot of things and fail more than that. That's how I learn. Whenever I succeed, I note that in my cookbook. Eventually, that became my blog.