SkillAgentSearch skills...

RazorSvelte

Template project for the .NET Razor Pages with Svelte Framework, Bootstrap, and Rollup

Install / Use

/learn @vb-consulting/RazorSvelte
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

License GitHub Stars GitHub Forks

RazorSvelte

Note:

There are several other UI Component frameworks evaluated, and finally this template is settled with Bootstrap.

To use other templates, for example, Carbon or Material UI, see installation instructions below in this file.

This is a project template and as such is being constantly updated with improvements and new components needed more modern and versatile web application.

Project template repository containing a template project with the following setup:

  • ASP.NET Razor Pages (C# and .NET8).
  • Svelte JavaScript Framework configured for use with TypeScript and SCSS preprocessor.
  • Rollup JavaScript bundler build system.
  • Bootstrap 5+ CSS framework configured for SCSS preprocessor, see https://getbootstrap.com/docs/.
  • For Bootstrap icons, see https://icons.getbootstrap.com/.
  • Sample authentication mechanism using (JWT using cookies with optional refresh tokens) and with three external login providers (Google, Linkedin, and Github).
  • Sample pages like index, privacy, login, logout, authorized sample page, unauthorized (401), not found (404), and error page.
  • Sample Single Page Application example using hashtag router component.
  • Built-in dark theme support with a theme built-in switching mechanism.
  • Sample Bootstrap components with the demo. New components are being added constantly.
  • UI components include:
    • chart - wrapper for Chart.js.
    • chart-box - chart with title and full-screen zoom buttons.
    • data-grid - data grid with the remote data source that uses bootstrap tables.
    • modal - wrapper for the bootstrap modal.
    • multiselect - multiple dropdown select with search and virtual scroll.
    • offcanvas - wrapper for the bootstrap offcanvas.
    • pager - bootstrap pager that works with data-grid.
    • placeholder - loading placeholder based on the bootstrap placeholder, mostly used by other components to manage an un-initialized state.
    • search-input - simple search input with a search icon that handles search timeouts and prevents multiple search requests.
    • etc, many more are being added regularly

To see usage examples for these components see this project.

Screenshot

Demo docker

Follow these steps to build and run the RazorSvelte demo application:

  1. Download the Dockerfile from https://raw.githubusercontent.com/vb-consulting/RazorSvelte/master/Dockerfile (or just run wget https://raw.githubusercontent.com/vb-consulting/RazorSvelte/master/Dockerfile` from the command prompt)

  2. Open a command prompt and navigate to the folder where you saved the Dockerfile

  3. Run the following commands:

docker build -t razorsvelte . docker run --rm -it -p 5000:80 --name razorsvelte razorsvelte:latest

Note:

If you try to login with an external provider you will be redirected to error page. Please edit appsettings.json with your own client provider id and client secrets and make sure that OAuth application redirects to `localhost:5000`` - to enable this feature.

Sample pages

  • /: index page - show value from external props hello world from svelte and display useful links
  • /privacy - privacy sample page, shows h1 title in a Svelte page passed from Razor Page ViewData.
  • /login - show external login buttons
  • /authorized - Sample authorized page protected with the Authorize attribute. Displays simple authorized user data passed from the Razor Page.
  • /401 - Sample unauthorized page that redirects when an unauthorized user tries to access the page with the Authorize attribute.
  • /404 - Not found page for unknown server routes.
  • /spa Example of the Single Page Application (SPA) with the hashtag client router component that displays various routes in a SPA fashion.

Important Notes:

  • There is no other NodeJS Web Server. Svelte is integrated with the Razor Pages.
  • Rollup JavaScript bundler is configured to output files into wwwroot and you can normally import them into Razor Pages (or any other pages).
  • There is no need to configure CORS since everything is served by .NET Web Server (Kestrel).

Why

  • Svelte is a radical new approach to building user interfaces.

  • Whereas traditional frameworks like React and Vue do the bulk of their work in the browser - Svelte shifts that work into a compile step that happens when you build your app. Instead of using techniques like virtual DOM diffing, Svelte writes code that surgically updates the DOM when the state of your app changes.

  • Svelte is a compiler that produces small and very optimized JavaScript output.

  • Svelte bundles your markup into compiler output as well, which is even smaller than what the normal markup would be.

  • Svelte compiler output is then cached in the browser which makes every subsequent request even faster since the browser doesn't even have to download that markup again.

  • Since Svelte produces pure vanilla JavaScript, there is no runtime overhead. This also means that you can import and bundle (with rollup) and runtime framework that you might need, perhaps to reuse the old UI components you might have. For example, legacy code with jQuery.

  • Svelte has become the most loved web framework for developers in a 2021 year, according to the StackOverflow survey.

  • Rollup is already pre-configured to run with the ASP.NET project, compile, bundle and remove unused modules, and then output into your wwwroot of your ASP.NET project.

  • You can also continue using the normal ASP.NET Razor Pages (or MVC) as you normally would.

The result is a very** optimized web**** application*** with:

  • The Backend is served by ASP.NET.
  • The front end is rendered and optimized by Svelte and Rollup.

And, you can combine server-side rendering with optimized Svelte front-end rendering.

Best of all - you can avoid tedious configuration by using this template.

Installation

From the command line:

Main template

$ npx degit vb-consulting/RazorSvelte
> cloned vb-consulting/RazorSvelte#HEAD
$ cd RazorSvelte
$ npm install
...
$ dotnet run

Carbon UI template

$ npx degit vb-consulting/RazorSvelte#carbon
> cloned vb-consulting/RazorSvelte#carbon
$ cd RazorSvelte
$ npm install
...
$ dotnet run

Material UI template

$ npx degit vb-consulting/RazorSvelte#svelte-material-ui
> cloned vb-consulting/RazorSvelte#svelte-material-ui
$ cd RazorSvelte
$ npm install
...
$ dotnet run

.NET 5 template

$ npx degit vb-consulting/RazorSvelte#net5
> cloned vb-consulting/RazorSvelte#net5
$ cd RazorSvelte
$ npm install
...
$ dotnet run

jQuery template

jQuery example only has one page that demonstrates how to bundle use jQuery with Svelte and Rollup.

$ npx degit vb-consulting/RazorSvelte#jquery
> cloned vb-consulting/RazorSvelte#jquery
$ cd RazorSvelte
$ npm install
...
$ dotnet run

Note:

  • degit just simply downloads and unzips the latest version of a git repo's contents without repository initialization (unlike git clone for example).

From the GitHub:

Just click on the big green button Use This Template.

If you want some other template rather than the main template (like jQuery or NET5 example) - change the branch first.

Structure

Razor Pages Structure

Each Razor Page has two new nested files:

  • MyPage.rollup.config.js - rollup configuration file for this page.
  • MyPage.entry.ts - entry point typescript module file for this page.

Note:

  • Those two new files are dependent on the MyPage.cshtml (via project file settings) so that IDEs like VisualStudio and JetBrains Rider would nest them visually.
  • You can nest files in Visual Studio Code by enabling file nesting and updating "File Nesting: Patterns" under the Explorer settings. Add an item with an item name of *.cshtml and a value of ${basename}.cshtml.cs, ${basename}.entry.ts, ${basename}.rollup.config.js.

Configuration file

Configuration file imports global config from Scripts/rollup.config` and sets the following values:

  • Entry module typescript file.
  • Compiler output JavaScript file. The default is wwwroot/buildplus entry module name with thejs` extension).
  • Compiler output CSS file for module scoped CSS/SCSS if any. The default is wwwroot/buildplus entry module name withcss` extension.

See sample pages in this repo.

Entry typescript module

The Entry typescript module imports a Svelte file for this page and returns the Svelte app.

In this template, all examples use document.body as app target. That means that the default layout Pages/Shared/_Layout.cshtml only contains a body.

Razor Page

Body content is rendered by the Razor Page itself and the svelte component.

Each Svelte-enabled Razor Page has also to include an output JavaScript and CSS (if any), for example, for Index page:

@section HeadSection {
    <link href="~/build/index.css" asp-append-version="true" rel="stylesheet" />
    <script defer src="~/build/inde
View on GitHub
GitHub Stars199
CategoryDevelopment
Updated5d ago
Forks20

Languages

Svelte

Security Score

100/100

Audited on Mar 29, 2026

No findings