簡體   English   中英

如何根據Ionic2下拉列表中顯示的項目計算日期

[英]How to Calculate Date as per Item Shown in dropdown in Ionic2

我是Ionic 2的初學者。我想根據混合Ionic Application中的Dropdown中顯示的項目計算日期。

我的頁面上有兩個下拉菜單:

  1. 第一個下拉列表

  1. 第二個下拉菜單

在此處輸入圖片說明

我想在選擇過去7天並單擊**阻止按鈕**以后7天后的日期將從當前日期開始計算,與過去1個月和過去12個月相同,然后將這些天傳遞給我的網址以在Piecharts中顯示數據和條形圖

在此處輸入圖片說明

這是我的home.ts代碼

    import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
import { ChartPage } from '../chart/chart';
import moment from 'moment';
var s,p;

@Component({
  selector: 'page-home',
  templateUrl: 'home.html'
})
export class HomePage {

  public states: any[];
  public districts: any[];
  public cities: any[];
  public selectedDistricts: any[];
  public selectedCities: any[];
  public sState: any;
  public sDistrict: any;

  appName = 'Dropdown App';

  constructor(public navController: NavController) { 
    this.initializeState();
    this.initializeDistrict();
    this.initializeCity();
  }

  initializeState(){
  this.states = [
    {id: 1, name: 'PieChart'},
    {id: 2, name: 'Line Chart'},
    {id: 3, name: 'Table'}
  ];
}

initializeDistrict(){
  this.districts = [
    {id: 1, name: 'Last 7 Days', state_id: 1, state_name: 'PieChart'},
    {id: 2, name: 'Last 1 Month', state_id: 1, state_name: 'PieChart'},
    {id: 3, name: 'Last 12 Months', state_id: 1, state_name: 'PieChart'},
    {id: 4, name: 'Custom Date', state_id: 1, state_name: 'PieChart'},

     {id: 5, name: 'Last 7 Days', state_id: 2, state_name: 'Line Chart'},
    {id: 6, name: 'Last 1 Month', state_id: 2, state_name: 'Line Chart'},
    {id: 7, name: 'Last 12 Months', state_id: 2, state_name: 'Line Chart'},
    {id: 8, name: 'Custom Date', state_id: 2, state_name: 'Line Chart'},


     {id: 9, name: 'Last 7 Days', state_id: 3, state_name: 'Table'},
    {id:10, name: 'Last 1 Month', state_id: 3, state_name: 'Table'},
    {id: 11, name: 'Last 12 Months', state_id:3, state_name: 'Table'},
    {id: 12, name: 'Custom Date', state_id: 3, state_name: 'Table'}

  ];
}
public openModal() {
      this.navController.push(ChartPage);
   }

    initializeCity(){
  this.cities = [

  ];
}
setDistrictValues(sState) {
     this.selectedDistricts = this.districts.filter(district => district.state_id == sState.id)
 }
setCityValues(sDistrict) {
      this.selectedCities = this.cities.filter(city => city.district_id == sDistrict.id);
 }

}

這是我的home.html

  <ion-header>
  <ion-navbar>
    <ion-title>{{ appName }}</ion-title>
  </ion-navbar>
</ion-header>

<ion-content padding>
<ion-item>
     <ion-label>Select Chart Type</ion-label>
     <ion-select (ionChange)="setDistrictValues(sState)" [(ngModel)]="sState">
          <ion-option [value]="sState" *ngFor = "let sState of states">{{sState.name}}  </ion-option> 
    </ion-select>

 </ion-item>
<ion-item *ngIf="selectedDistricts">
      <ion-label>Duration</ion-label>
      <ion-select (ionChange)="setCityValues(sDistrict)" [(ngModel)]="sDistrict">
            <ion-option [value]="sDistrict" *ngFor = "let sDistrict of selectedDistricts">{{sDistrict.name}}</ion-option>
      </ion-select>
 </ion-item>



<button ion-button block (click)="openModal()">Block Button</button>
</ion-content>

這是我的提供者

    import { Injectable } from '@angular/core';
import { Http } from '@angular/http';
import 'rxjs/add/operator/map';

@Injectable()
export class EarthquakesProvider {
  firstName: string;
    lastName: string;

  constructor(public http: Http) {

    console.log('Hello EarthquakesProvider Provider');
  }


   loadEarthquakesprovider() {
        return this.http.get(`http://factoryunlock.in/sundar/public/api/v1/production`)
            .map(res => res.json());
    }

}

我想在我的提供商中創建這種類型的網址

http://factoryunlock.in/sundar/public/api/v1/production?from=01/02/2017&to=01/05/2017

嗨,你能嘗試這樣的事情嗎

var days = 7;
var date = new Date();

//todays datetime  to milliseconds
var today = date.getTime();

//get 7 days in milliseconds

var daysinmilli = (days * 24 * 60 * 60 * 1000);

//make a new date for the 7th day
var res = date.setTime(today + daysinmilli );

date = new Date(res);


// pass your dates to the function below and get your date strings

function convertDate(date) {
  var yyyy = date.getFullYear().toString();
  var mm = (date.getMonth()+1).toString();
  var dd  = date.getDate().toString();

  var mmChars = mm.split('');
  var ddChars = dd.split('');

  return (ddChars[1]?dd:"0"+ddChars[0]) + '/' + (mmChars[1]?mm:"0"+mmChars[0]) + '/' + yyyy;
}

您可以簡單地使用setDate()setMonth()函數:

let date = new Date() //current date
date.setDate(date.getDate()+7);//After 7 days
date.setMonth(date.getMonth()+3);//After 3 months

查看有關Date對象的更多信息

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM