zoukankan      html  css  js  c++  java
  • ngx-bootstrap学习笔记(一)-popover

    前言

    这月做了个ng2模块,其中有个校验功能,当校验不通过时给出提示,项目中使用jQuery实现,今天才发现ngx-bootstrap已经有现成功能了,且可封装成通用组件放入shareModule,使用方便。故记录如下。

    安装

    npm install ngx-bootstrap --save

    引入模块

    import {PopoverModule} from 'ngx-bootstrap/';
    
    @NgModule({
      declarations: [XxxComponent...],
      imports: [
        BrowserModule,
        PopoverModule.forRoot(),
        FormsModule
      ],
      providers: [XxxService...],
      bootstrap: [XxxComponent]
    })
    

    封装组件

    popover.component.ts

    import {Component, ViewChild} from '@angular/core';
    import {PopoverDirective} from 'ngx-bootstrap';
    
    @Component({
      selector: 'nepsd-popover',
      templateUrl: './popover.component.html',
      styleUrls: ['./popover.component.css']
    })
    export class PopoverComponent {
      @ViewChild('pop') popover: PopoverDirective;
    }
    

    popover.component.html

    <span popover #pop="bs-popover">
      <ng-content></ng-content>
    </span>
    

    popover.component.css

    	:host > > > .popover {
    	  background-color: #FCFCFC;
    	}
    	:host > > > .popover > .arrow:after {
    	  border-top-color: #FCFCFC;
    	}
    

    其他组件引用

    app.component.ts

    import {Component, ViewChild} from '@angular/core';
    import {PopoverComponent} from './popover/popover.component';
    
    @Component({
      selector: 'app-root',
      templateUrl: './app.component.html',
      styleUrls: ['./app.component.css']
    })
    export class AppComponent {
      tip: string;
      @ViewChild('pop') popoverComponent: PopoverComponent;
    
      validInput() {
        let valid = Math.random() > 0.5;
        if (!valid) {
          /**pop config*/
          this.popoverComponent.popover.popoverTitle = undefined;
          this.popoverComponent.popover.popover = this.tip;
    
          this.popHover();
        }
      }
    
      private popHover(timeout?: number) {
        timeout = timeout ? timeout : 1000;
        this.popoverComponent.popover.show();
        setTimeout(() => {
          this.popoverComponent.popover.hide();
        }, timeout);
      }
    }
    

    app.component.html

    <div style="margin-top: 100px">
      <nepsd-popover #pop>
        <input [(ngModel)]="tip" (change)="validInput()" (blur)="popHover()">
      </nepsd-popover>
    </div>
    

    效果

    参考

    ngx-bootstrap

  • 相关阅读:
    全文检索 部署及使用
    mysql 数据库常见的一些基本操作 !详不详细你说了算!
    Django 语法笔记
    CentOs Linux 对于 修改 yum源 为 阿里
    小白老凯,初出茅庐!请多关照!简单分享一些 mysql 数据库的安装操作!请给为大神雅正!
    sql server 之一条Sql语句引发的悲剧
    翻译高质量JavaScript代码书写基本要点(转载)
    翻编JavaScript有关的10个怪癖和秘密(转载)
    IIS7.5部署ASP.NET失败
    linq to sql报错,
  • 原文地址:https://www.cnblogs.com/yw0219/p/7995305.html
Copyright © 2011-2022 走看看