Welcome to ngx-bootstrap!

The best way to quickly integrate Bootstrap 5 or Bootstrap 4 Components with Angular

npm latest versionnpm next version
npm downloads

Links

Table of contents

  1. Getting Started
  2. Usage & Demo
  3. Supporting NGX-Bootstrap
  4. Installation
  5. Compatibility
  6. Troubleshooting
  7. Contributing
  8. Credits
  9. License

Getting Started #

ngx-bootstrap provides Bootstrap components powered by Angular, so you don't need to include original JS components.

Check our Getting started guide if it's your first project with Angular Bootstrap.

Usage & Demo #

Bootstrap components for Angular applications, dozens of demos and API documentation could be found here: https://valor-software.com/ngx-bootstrap.

Supporting NGX-Bootstrap #

ngx-bootstrap is an Open Source (MIT Licensed) project, it's an independent project with ongoing development made possible thanks to the support of our awesome backers. If you also would like to show support or simply give back to Open Source community, please consider becoming a backer sponsor of ngx-bootstrap on OpenCollective.

All donated funds are managed transparently on OpenCollective and will be used solely for compensating work and expenses for contributors. Valor Software employees and contractors are not eligible to use these funds.

What's there for you? Proper recognition and exposure of your name/logo/website on our page. Our main sponsors will be presented under this section! Be the first!

Installation #

Angular CLI way

Make sure that your app uses modular approach and you have app.module.ts set as your starting point before you proceed

import { platformBrowser } from '@angular/platform-browser';
import { AppModule } from './app.module';
 
platformBrowser().bootstrapModule(AppModule).catch((err) => console.error(err));
      

Use the Angular CLI ng add command for updating your Angular project.

ng add ngx-bootstrap

Manual way

Install ngx-bootstrap from npm

npm install ngx-bootstrap --save

Add wanted package to NgModule imports:

  import { TooltipModule } from 'ngx-bootstrap/tooltip';
   
  @NgModule({
  
    imports: [ TooltipModule.forRoot(), … ]
  
  })

Add component to your page:

  <button type="button" class="btn btn-primary"
          tooltip="Vivamus sagittis lacus vel augue laoreet rutrum faucibus.">
    Simple demo
  </button>

You will need to add bootstrap css:

  • Bootstrap 5
<!--- index.html -->
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" crossorigin="anonymous" integrity="sha384-rbsA2VBKQhggwzxH7pPCaAqO46MgnOM80zW1RWuH61DGLwZJEdK2Kadq2F9CUG65">
  • Bootstrap 4
<!--- index.html -->
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" crossorigin="anonymous" integrity="sha384-TX8t27EcRE3e/ihU7zmQxVncDAy5uIKz4rEkgIXeMed4M0jlfIDPvg6uqKI2xXr2">

Setting up the bootstrap version manually

As you may know ngx-bootstrap support several bootstrap.css versions at the same time and has automatic tool to guess current used version of library, but if this guess fails you can specify version of bootstrap.css manually.

Sometimes, your project might contain some library that could interfere with the bootstrap framework, or you might have a customized version of bootstrap. The consequence is that the process of determining bootstrap version might be failed, which can break the UI. In that case, we can still set the bootstrap version manually in the bootstrapping component (i.e. AppComponent):

  import { setTheme } from 'ngx-bootstrap/utils';
   
  @Component({})
  export class AppComponent {
    constructor() {
      setTheme('bs5'); // or 'bs4'
      
    }
  }

How to build lib for development

First time:

  git clone https://github.com/valor-software/ngx-bootstrap.git
  cd ngx-bootstrap
  npm ci
  npm run build
  npm start

Compatibility #

The only two dependencies are Angular and Bootstrap CSS.

Here is the versions compatibility list:

ngx-bootstrapAngularBootstrap CSS
18.x.x18.x.x5.x.x or 4.x.x
12.x.x17.x.x5.x.x or 4.x.x
11.x.x16.x.x5.x.x or 4.x.x
10.x.x15.x.x5.x.x or 4.x.x
9.0.014.x.x5.x.x or 4.x.x or 3.x.x
8.0.012.x.x - 13.x.x5.x.x or 4.x.x or 3.x.x
7.1.011.x.x - 12.x.x5.x.x or 4.x.x or 3.x.x
7.0.011.x.x - 12.x.x3.x.x or 4.x.x
6.0.09.x.x - 10.x.x3.x.x or 4.x.x
5.6.x7.x.x - 9.1.03.x.x or 4.x.x
5.0.0 - 5.6.07.x.x - 8.x.x3.x.x or 4.x.x
4.x.x6.x.x - 7.x.x3.x.x or 4.x.x
3.x.x6.x.x - 7.x.x3.x.x or 4.x.x
2.x.x2.x.x - 4.x.x3.x.x or 4.x.x
1.x.x2.x.x3.x.x or 4.x.x

Troubleshooting #

So if you are in trouble, here's where you can look for help.

The best place to ask questions is on StackOverflow (under the ngx-bootstrap tag) You can also join our Slack channel and link your stackoverflow question there. But try to avoid asking generic help questions directly on Slack since they can easily get lost in the chat. You can also search among the existing GitHub issues.

If, and only if, none of the above helped, please open a new issue

Contribution #

Are very welcome! And remember, contribution is not only PRs and code, but any help with docs or helping other developers to solve issues are very appreciated! Thanks in advance!

Please read our contribution guidelines.

Credits #

Crossbrowser testing sponsored by SaucelabsSaucelabs

License #

MIT