Angular2中Bootstrap界面库ng-bootstrap详解


Posted in Javascript onOctober 18, 2016

准备 Angular 2 环境

ng-bootstrap 是基于 Angular 2 的, 因此需要先准备 Angular 2 的环境。

使用 ng-bootstrap

下载 ng-bootstrap

ng-bootstrap 使用 bootstrap 4.0 alpha2 , 因此需要先下载 bootstrap , 推荐使用 npm 包的形式:

npm install bootstrap@4.0.0-alpha.2 --save

接着下载 ng-bootstrap , 同样使用 npm 包的形式:

npm install @ng-bootstrap/ng-bootstrap --save

修改 systemjs.config.js

现在需要修改一下 systemjs.config.js 文件, 让 SystemJS 能够正确加载 ng-bootstrap :

// map tells the System loader where to look for things
var map = {
 'app':      'dist', // 'dist',
 '@angular':     'node_modules/@angular',
 'angular2-in-memory-web-api': 'node_modules/angular2-in-memory-web-api',
 'rxjs':      'node_modules/rxjs',
 // add ng-bootstrap location map 
 '@ng-bootstrap':    'node_modules/@ng-bootstrap'
};
// packages tells the System loader how to load when no filename and/or no extension
var packages = {
 'app': { main: 'main.js', defaultExtension: 'js', format: 'amd' },
 'rxjs': { defaultExtension: 'js' },
 'angular2-in-memory-web-api': { main: 'index.js', defaultExtension: 'js' },
 // add ng-bootstrap package config
 '@ng-bootstrap/ng-bootstrap': { main: 'index.js', defaultExtension: 'js' }
};

修改 index.html

index.html 文件也要修改一下, 把 bootstrap 的样式表关联进来:

<link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.css"/>

修改 app.component.ts

还需要修改一下 app.component.ts 文件, 导入 ng-bootstrap 的指令:

import { Component, OnInit } from '@angular/core';
import { HTTP_PROVIDERS } from '@angular/http';
import { provideRouter, ROUTER_DIRECTIVES } from '@angular/router';
// import ng-bootstrap directives
import { NGB_DIRECTIVES, NGB_PRECOMPILE } from '@ng-bootstrap/ng-bootstrap';

import { routes } from './app.routes';

@Component({
 //moduleId: module.id,
 selector: 'app',
 providers: [ HTTP_PROVIDERS ],
 templateUrl: 'dist/app.component.html',
 styleUrls: ['dist/app.component.css'],
 // ng-bootstrap required precompile directives
 precompile: [NGB_PRECOMPILE],
 // add ng-bootstrap directives to app
 directives: [
  ROUTER_DIRECTIVES, NGB_DIRECTIVES
 ],
 pipes: []
})
export class AppComponent implements OnInit {

 ngOnInit() {
 }

}

ng-bootstrap 以指令 (directive) 的形式提供组件, 方便在 html 视图中使用, 选择器 (selector) 使用同一的前缀 ngb , 类名则统一使用 Ngb 前缀。

接下来就可以使用 ng-bootstrap 的组件了, 接下来以 NgbAlert 为例说明 ng-bootstrap 的用法。

NgbAlert 的 selector 是 ngb-alert , 支持的 Input 有 dismissible 和 type , Output 有 close 。

接下来看一个 NgbAlert 的例子:

<p>
 <ngb-alert [dismissible]="false">
 <strong>Warning!</strong> Better check yourself, you're not looking too good.
 </ngb-alert>
</p>

显示效果如下:

Angular2中Bootstrap界面库ng-bootstrap详解

再来一个稍微复杂一点儿的, 在 app.component.ts 文件中添加下面的代码:

export class AppComponent implements OnInit {

 alert: IAlert[];

 ngOnInit() {
  this.alert = [
   {
    id: 1,
    type: 'success',
    message: 'This is an success alert',
   },
   {
    id: 2,
    type: 'info',
    message: 'This is an info alert',
   },
   {
    id: 3,
    type: 'warning',
    message: 'This is a warning alert',
   },
   {
    id: 4,
    type: 'danger',
    message: 'This is a danger alert',
   }
  ];
 }

 closeAlert(alert: IAlert) {
  const index: number = this.alerts.indexOf(alert);
  this.alerts.splice(index, 1);
 }
}

interface IAlert {
 id: number;
 type: string;
 message: string;
}

在对应的 html 文件中添加 *ngFor 指令, 绑定 alerts 数组:

<p *ngFor="let alert of alerts">
 <ngb-alert
  [type]="alert.type"
  (close)="closeAlert(alert)">\{\{ alert.message }}
 </ngb-alert>
</p>

现在得到的效果如下图所示:

Angular2中Bootstrap界面库ng-bootstrap详解

ng-bootstrap 还有更多的组件, 就不一一列举了。

总结

实现 ng-bootstrap 的人还是原来做 angular-ui 的那些人, 可以说配方还是原来的配方, 但是这味道么就跟原来有很大的不同了, 完全切换到了 Angular2 的风格。

不过总的来说, ng-bootstrap 的推出将会极大的推进 Angular 2 在实际项目中的应用, 而不只是停留在 demo 阶段, 因为 AngularJS 1.x 时期, 很多项目都是以 AngularJS + UI-Bootstrap 为基础的, 现在有了 Angular 2 的 ng-bootstrap , 相信已经由很多人蠢蠢欲动了吧!以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
Prototype 工具函数 学习
Jul 23 Javascript
js textarea自动增高并隐藏滚动条
Dec 16 Javascript
始终在屏幕中间显示Div的代码(css+js)
Mar 10 Javascript
基于jQuery实现的百度导航li拖放排列效果,即时更新数据库
Jul 31 Javascript
jQuery中removeProp()方法用法实例
Jan 05 Javascript
Actionscript与javascript交互实例程序(修改)
Sep 22 Javascript
JS正则匹配URL网址的方法(可匹配www,http开头的一切网址)
Jan 06 Javascript
AngularJS中的作用域实例分析
May 16 Javascript
AngularJS实现的base64编码与解码功能示例
May 17 Javascript
讲解vue-router之什么是嵌套路由
May 28 Javascript
解决jQuery使用append添加的元素事件无效的问题
Aug 30 jQuery
Vue实现回到顶部和底部动画效果
Jul 31 Javascript
微信小程序 教程之事件
Oct 18 #Javascript
微信小程序 教程之模板
Oct 18 #Javascript
微信小程序 教程之列表渲染
Oct 18 #Javascript
微信小程序 教程之条件渲染
Oct 18 #Javascript
微信小程序 教程之数据绑定
Oct 18 #Javascript
vue.js通过自定义指令实现数据拉取更新的实现方法
Oct 18 #Javascript
微信小程序 教程之WXML
Oct 18 #Javascript
You might like
基于mysql的论坛(1)
2006/10/09 PHP
很好用的PHP数据库类
2009/05/27 PHP
PHP设计模式 注册表模式(多个类的注册)
2012/02/05 PHP
ThinkPHP基于PHPExcel导入Excel文件的方法
2014/10/15 PHP
Yii2.0 模态弹出框+ajax提交表单
2016/05/22 PHP
从零开始学习jQuery (十) jQueryUI常用功能实战
2011/02/23 Javascript
js单例模式的两种方案
2013/10/22 Javascript
js根据日期判断星座的示例代码
2014/01/23 Javascript
js判断元素是否隐藏的方法
2014/06/09 Javascript
js添加select下默认的option的value和text的方法
2014/10/19 Javascript
Javascript编写俄罗斯方块思路及实例
2015/07/07 Javascript
jquery实现简单合拢与展开网页面板的方法
2015/09/01 Javascript
js中获取键盘事件的简单实现方法
2016/10/10 Javascript
JS定时器用法分析【时钟与菜单中的应用】
2016/12/21 Javascript
利用JS测试目标网站的打开响应速度
2017/12/01 Javascript
vue--vuex详解
2019/04/15 Javascript
每周一练 之 数据结构与算法(Stack)
2019/04/16 Javascript
javascript 构建模块化开发过程解析
2019/09/11 Javascript
Vue中父子组件的值传递与方法传递
2020/09/28 Javascript
Python 数据结构之队列的实现
2017/01/22 Python
Python用imghdr模块识别图片格式实例解析
2018/01/11 Python
Python列表推导式、字典推导式与集合推导式用法实例分析
2018/02/07 Python
Python将文本去空格并保存到txt文件中的实例
2018/07/24 Python
Python实现的逻辑回归算法示例【附测试csv文件下载】
2018/12/28 Python
Python3 安装PyQt5及exe打包图文教程
2019/01/08 Python
python读取hdfs并返回dataframe教程
2020/06/05 Python
Python通过zookeeper实现分布式服务代码解析
2020/07/22 Python
基于python实现百度语音识别和图灵对话
2020/11/02 Python
五款漂亮的纯CSS3动画按钮的实例教程
2014/11/21 HTML / CSS
浅析数据存储的三种方式 cookie sessionstorage localstorage 的异同
2020/06/04 HTML / CSS
俄罗斯街头服装品牌:Black Star Wear
2017/03/01 全球购物
eBay意大利购物网站:eBay.it
2019/09/04 全球购物
绩效工资分配方案
2014/01/18 职场文书
中班上学期幼儿评语
2014/04/30 职场文书
师范毕业生求职信
2014/07/11 职场文书
2014市国税局对照检查材料思想汇报
2014/09/23 职场文书