2017-09-26 7 views
0

こんにちは、私はclickOutsideイベントをトリガーしようとしています。私のアプリにするとき、変数show == true私はdiv要素を示すが、私はそれを表示するときに、私はclickOutside角2のクリック外がうまくいきません

を使用しようとしたところ他の私は、いずれかをクリックしてください、私はangular2-click-outside

このページから次のコマンドを使用したとき、私は再びそれを隠すことはできません
npm i angular2-click-outside 

と私のコンポーネントで

 <div class="row hidden_one" (clickOutside)="close()"> 

これは

<div class="container-fluid"> 
    <div class="row wrapper"> 
    <div class="col-lg-8 col-md-8 col-sm-9 first"> 
    <input type="text" class="form-control title" placeholder="{{placeholder}}" #task> 
</div> 
<div class="col-lg-4 col-md-4 col-sm-3 second hiddden"> 
    <div class="row"> 
    <div class="col-lg-8 col-md-8 col-sm-8 col-xs-8"> 
     <input type="text" class="form-control right" value="00:00:00" (click)="showdiv()" [(ngModel)]="timer" #time> 
    </div> 
    <div class="col-lg-4 col-md-4 col-sm-4 col-xs-4 font"> 
     <i class="fa fa-play-circle fa-3x first" aria-hidden="true" *ngIf="play" (click)="startPause()"></i> 
     <i class="fa fa-stop-circle fa-3x second" aria-hidden="true" *ngIf="pause" (click)="startPlay(task.value, time.value)"></i> 
    </div> 
    </div> 
    <div class="row hidden_one" (clickOutside)="close()"> 
    <div class="start-end" *ngIf="show" (clickOutside)="hide($event)"> 
     <div class="col-lg-6"> 
     <div class="form-group"> 
      <label for="Start">Start</label><br> 
      <input type="text" class="form-control" class="startTime" value="{{startTime}}" #val (blur)="validate(val.value)"> 
     </div> 
     </div> 
     <div class="col-lg-6"> 
     <div class="form-group"> 
      <label for="Start">Stop</label><br> 
      <input type="text" class="form-control" class="startTime" [(ngModel)]="stopTime" [disabled]="pause"> 
     </div> 
     </div> 
    </div> 
    </div> 
</div> 
私のhtmlページです

、これが私のTSコード

import { Component } from '@angular/core'; 
import { timeInterface } from './timeInterface'; 
import { timesList } from './times-list-component'; 
import { TimeService } from './time-service'; 
import * as moment from 'moment'; 

@Component({ 
selector: 'my-app', 
templateUrl: './html/app-component.html', 
styleUrls: ['./css/app-component.css'] 

})

export class AppComponent { 
    placeholder:string = "What are you working on?"; 
    play:boolean = true; 
pause:boolean = false; 
show:boolean=false;// For Showing The Hidden Div 
countup:any; 
timeSum :any; 
timer:string = "00:00:00"; 
// hidden Div Start Time 
startTime: any; 
stopTime: any; 
bs:any; 
bbs:any; 
// Array to Hold The Tasks With Time 
tasks:timeInterface[] =[]; 

constructor(private timeService:TimeService) {} 

startPause() {// when click on play button 
    // this.bs = moment(); 
    // this.startTime = this.bs.format('hh:mm A'); 
    // this.play = false; 
    // this.pause = true; 

    // let sec= 0; 
    // let min = 0; 
    // let hour = 0; 
    // this.countup = setInterval(() => { 
    // if(sec === 59) { 
    //  min++; 
    //  sec = 0; 
    // }else if(min > 59) { 
    //  hour++; 
    //  min = 0; 
    // }else { 
    //  sec++; 
    // } 
    // this.timer = `${this.pad(hour)}:${this.pad(min)}:${this.pad(sec)}`; 
    // }, 1000); 
    this.timeService.startPause(); 
} 

startPlay(name:string, time:any) { 
    this.play = true; 
    this.pause = false; 
    this.timer = "00:00:00"; 
    clearInterval(this.countup); 
    //push the task to array 
    if(name == "") { 
    // this.placeholder = "(no description)"; 
    name = "Add description"; 
    this.tasks.push({title: name, time: time}); 
    } else { 
    name = name; 
    this.tasks.push({title: name, time: time}); 
    } 

} 

pad(num:number, size:number=2): string { // to add zero before sec if it < 
    10 
    var s = num+""; 
    while (s.length < size) s = "0" + s; 
    return s; 
} 
//Show the hidden div 
showdiv() { 
    this.bbs = moment();   
    //console.log(moment(this.bbs.diff(this.bs, 
    'hh:mm:ss')).format('hh:mm:ss')); 
    this.show = true; 
    this.stopTime = this.bbs.format('hh:mm A'); 
    if(!this.pause) { 
    this.startTime = this.stopTime 
    } 
} 
// Validate input value 
    validate(val:string) { 
    let temp =this.startTime; 
    let parsedTime = moment(val, "hh:mm A"); 
    if(parsedTime.isValid()) { 
    this.startTime = parsedTime.format('hh:mm A') 
    } else { 
    this.startTime = "temp"; 
    console.log("no"); 
    } 
} 
close() {// to hide the pop up div 
    console.log('Clicked outside:'); 
    this.show = false 
} 
} 

であると私はコンソールにログインしたときに、私はイベントにはないようだが何の事はありません何か助けてください.thxを事前に

答えて

0

あなたnそれはここのように動作するようにするためのイベントを渡すためのEED:

<div class="row hidden_one" (clickOutside)="onClickOutside($event)"> 

そして、あなたのJSで:

onClickOutside(event:Object) { 
    alert('works'); 
    } 
+0

私はuが言ってみましたが、それはうまくいきませんでした。 –

関連する問題