Getting started for ASP.NET Core + Vue project

Here we describe how to add EasyQuery widgets to your ASP.NET Core + Vue.js project.


  1. You have an ASP.NET Core (version 2.1+) project with Vue.js (version 2.5.0 or higher) on the client-side.
  2. Your application uses Entity Framework Core to work with the database. (NB: it's possible to use EasyQuery without EF Core as well but for the sake of simplicity we will not consider other cases here).

Server-side changes

First, we are going to add EasyQuery to your ASP.NET Core backend project.

1: Add EasyQuery packages to your project

Since we have a standard ASP.NET Core project with EntityFramework Core for working with the database - then we will need the following 2 EasyQuery packages be added to your .csproj file:

    <PackageReference Include="Korzh.EasyQuery.AspNetCore" Version="5.1.1" />
    <PackageReference Include="Korzh.EasyQuery.EntityFrameworkCore.Relational" Version="5.1.1" />

2: Add EasyQuery services and middleware

On this step we will setup EasyQuery services and middleware.

First of all you need to register EasyQuery services in DI container. Here is the code you will need to add to your Startup class:

public void ConfigureServices(IServiceCollection services)
    .    .    .    .   .   .

In addition to registering EasyQuery services in DI we have set the default EasyQuery manager (the main "engine" which will process all client-side requests). Currently there are two possible options: EasyQueryManagerSql and EasyQueryManagerLinq.

Then we need to setup the middleware which will handle HTTP requests from the client-side, pass them to manager, take the result and prepare it for sending back to the client. To avoid any conflicts with MVC or SPA handlers we put EasyQuery middleware before them:

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    .   .   .   .   .   .

    app.UseEasyQuery(options => {
        options.Endpoint = "/api/easyquery";

    app.UseMvc(routes => {
	     .    .    .    .

    app.UseSpa(spa => {
        .   .   .   .

The code above defines the following main settings:

  1. The endpoint is set to /api/easyquery. This means that all requests from EasyQuery widgets will be started with this path (like /api/easyquery/models/{modelId} to load the model). Please note that this is the default value so you can omit this setting in your app.
  2. We will use the DbContext class specified in UseDbContext call to get the model or to execute the generated queries. It's the fasteset way to specify the model load and the connection to your DB. Otherwise you will need to set them separately via UseModelLoader or UseDbConnection extension functions.
  3. The last UsePaging call turns on the paging and set the page size.

So, server-side setup is finished. Now we need to setup the client-side part.

Add EasyQuery view to your Vue app

Now it's time to configure the client-side scripts and styles. Here we suppose that your Vue application is placed in ClientApp subfolder of your main project's folder.

1. Adding JQuery and EasyQuery styles

Currently, EasyQuery still uses JQuery and JQuery UI for rendering some widgets (we will remove this dependence in future updates). So, we need to add those libraries to our project and the simplest way to do it - is to include necessary scripts right to your index.html file.

Additionally, it's necessary to include EasyQuery CSS files which defines the basic styles for our widgets and views. They also should be placed into index.html:

    .    .    .    .    .    .
	<!-- EasyQuery CSS -->
    <link rel="stylesheet" href="">
    <link rel="stylesheet" href="">

    <!-- JQuery scripts -->
    <script src=""></script>
    <script src=""></script>

2. Adding EasyQuery NPM packages

To install EasyQuery packages just open the console in your ClientApp folder and run the following command :

npm install "@easyquery/core" "@easyquery/broker-eqs" "@easyquery/ui" "@easyquery/ui-jquery"

3. Adding EasyQuery view

Here we are goint to add a new view (page) that will contain the EasyQuery "advanced search" functionality.

To do it - simply create an empty .vue file in ClientApp/src/views folder (let it be EasyQuery.vue). The template part for this new view should contain several "slots" for EasyQuery widgets - some div elements with special IDs. Here are those IDs:

  • QueryPanel - for conditions widget
  • ColumnsPanel - for columns widget
  • ResultPanel - for result panel widget which will combine a grid to show the result set and the chart (if showChart option is turned on).

To simplify the task you can use the EasyQuery.vue file from our sample project

4. Setting component's code

EasyQuery introduces its own "view" concept. In EasyQuery's terms, "view" - is a set of different EasyQuery widgets assembled to work together on some web page. There are several views available out-of-the-box. Here we are going to use the AdvancedSearch view.

So, basically, all you need to do, is to create an instance of some EasyQuery view class during the initialization of your Vue component and then call its init method. Here is an example how it may look like:

<script lang="ts">
    import { Component, Vue } from 'vue-property-decorator';
    import { AdvancedSearchViewJQuery } from '@easyquery/ui-jquery';
    import { EqViewOptions } from '@easyquery/ui';
    import { Message } from '@easyquery/core';

    export default class EasyQueryView extends Vue 
        private view = new AdvancedSearchViewJQuery();

        private mounted() {
            const options: EqViewOptions = {
			   //setting some EasyQuery options here


If you used the EasyQuery.vue file from our sample project on the previous step - then it already contains this initialization part.

5. Wrap it up

To make new component accessible you will also need to add a new item to the routes array in /ClientApp/src/router.ts module:

  routes: [
	  .    .    .    .    .    .
       path: '/easy-query',
       name: 'easy-query',
       component: () => import(/* webpackChunkName: "easy-query" */ './views/EasyQuery.vue'),
	.    .    .    .    .    .

and add a link to the new page to a navigation menu (items array in src/App.vue file):

  private items = [
      .   .   .   .   .   .
      { title: 'EasyQuery', icon: 'search', link: '/easy-query' },

That's all. If everything was done right you will get something like the following in result: