ASP.NET Core MVC / Razor Pages UI

Introduction

ABP Framework provides a convenient and comfortable way of creating web applications using the ASP.NET Core MVC / Razor Pages as the User Interface framework.

ABP doesn't offer a new/custom way of UI development. You can continue to use your current skills to create the UI. However, it offers a lot of features to make your development easier and have a more maintainable code base.

MVC vs Razor Pages

ASP.NET Core provides two models for UI development:

  • MVC (Model-View-Controller) is the classic way that exists from the version 1.0. This model can be used to create UI pages/components and HTTP APIs.
  • Razor Pages was introduced with the ASP.NET Core 2.0 as a new way to create web pages.

ABP Framework supports both of the MVC and the Razor Pages models. However, it is suggested to create the UI pages with Razor Pages approach and use the MVC model to build HTTP APIs. So, all the pre-build modules, samples and the documentation is based on the Razor Pages for the UI development, while you can always apply the MVC pattern to create your own pages.

Modularity

Modularity is one of the key goals of the ABP Framework. It is not different for the UI; It is possible to develop modular applications and reusable application modules with isolated and reusable UI pages and components.

The application startup template comes with some application modules pre-installed. These modules have their own UI pages embedded into their own NuGet packages. You don't see their code in your solution, but they work as expected on runtime.

Theme System

ABP Framework provides a complete Theming system with the following goals:

  • Reusable application modules are developed theme-independent, so they can work with any UI theme.
  • UI theme is decided by the final application.
  • The theme is distributed via NuGet/NPM packages, so it is easily upgradable.
  • The final application can customize the selected theme.

Current Themes

Currently, two themes are officially provided:

  • The Basic Theme is the minimalist theme with the plain Bootstrap style. It is open source and free.
  • The Lepton Theme is a commercial theme developed by the core ABP team and is a part of the ABP Commercial license.

There are also some community-driven themes for the ABP Framework (you can search on the web).

Base Libraries

There are a set of standard JavaScript/CSS libraries that comes pre-installed and supported by all the themes:

You can use these libraries directly in your applications, without needing to manually import your page.

Layouts

The themes provide the standard layouts. So, you have responsive layouts with the standard features already implemented. The screenshot below has taken from the Application Layout of the Basic Theme:

basic-theme-application-layout

See the Theming document for more layout options and other details.

Layout Parts

A typical layout consists of multiple parts. The Theming system provides menus, toolbars, layout hooks and more to dynamically control the layout by your application and the modules you are using.

Features

This section highlights some of the features provided by the ABP Framework for the ASP.NET Core MVC / Razor Pages UI.

Dynamic JavaScript API Client Proxies

Dynamic JavaScript API Client Proxy system allows you to consume your server side HTTP APIs from your JavaScript client code, just like calling local functions.

Example: Get a list of authors from the server

acme.bookStore.authors.author.getList({
  maxResultCount: 10
}).then(function(result){
  console.log(result.items);
});

acme.bookStore.authors.author.getList is an auto-generated function that internally makes an AJAX call to the server.

See the Dynamic JavaScript API Client Proxies document for more.

Bootstrap Tag Helpers

ABP makes it easier & type safe to write Bootstrap HTML.

Example: Render a Bootstrap modal

<abp-modal>
    <abp-modal-header title="Modal title" />
    <abp-modal-body>
        Woohoo, you're reading this text in a modal!
    </abp-modal-body>
    <abp-modal-footer buttons="@(AbpModalButtons.Save|AbpModalButtons.Close)"></abp-modal-footer>
</abp-modal>

See the Tag Helpers document for more.

Forms & Validation

ABP provides abp-dynamic-form and abp-input tag helpers to dramatically simplify to create a fully functional form that automates localization, validation and AJAX submission.

Example: Use abp-dynamic-form to create a complete form based on a model

<abp-dynamic-form abp-model="Movie" submit-button="true" />

See the Forms & Validation document for details.

Bundling & Minification / Client Side Libraries

ABP provides a flexible and modular Bundling & Minification system to create bundles and minify style/script files on runtime.

<abp-style-bundle>
    <abp-style src="/libs/bootstrap/css/bootstrap.css" />
    <abp-style src="/libs/font-awesome/css/font-awesome.css" />
    <abp-style src="/libs/toastr/toastr.css" />
    <abp-style src="/styles/my-global-style.css" />
</abp-style-bundle>

Also, Client Side Package Management system offers a modular and consistent way of managing 3rd-party library dependencies.

See the Bundling & Minification and Client Side Package Management documents.

JavaScript APIs

JavaScript APIs provides a strong abstractions to the server side localization, settings, permissions, features... etc. They also provide a simple way to show messages and notifications to the user.

Modals, Alerts, Widgets and More

ABP Framework provides a lot of built-in solutions to common application requirements;

  • Widget System can be used to create reusable widgets & create dashboards.
  • Page Alerts makes it easy to show alerts to the user.
  • Modal Manager provides a simple way to build and use modals.
  • Data Tables integration makes straightforward to create data grids.

Customization

There are a lot of ways to customize the theme and the UIs of the pre-built modules. You can override components, pages, static resources, bundles and more. See the User Interface Customization Guide.

Contributors


Last updated: November 09, 2020 Edit this page on GitHub

Was this page helpful?

Please make a selection.

To help us improve, please share your reason for the negative feedback in the field below.

Please enter a note.

Thank you for your valuable feedback!

Please note that although we cannot respond to feedback, our team will use your comments to improve the experience.

In this document
Community Talks

Layered vs Modular vs Microservices... Which one is best for you?

09 Jan, 17:00
Online
Watch the Event
Mastering ABP Framework Book
Mastering ABP Framework

This book will help you gain a complete understanding of the framework and modern web application development techniques.

Learn More