- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于学校,我们必须制作一个可用的恒温器应用程序(这是关于设计的,但仍然需要能够与服务器交互)。我们决定在 ionic 3 中做到这一点。到目前为止,我的道路远非一帆风顺,但这个问题确实让我很困扰。用于选择特定的开启和关闭时间(您需要能够设置多个)。我正在使用标准的 DatePicker,但它的代码似乎是反向运行的..而且我不知道到底是谁在这样做。
完整的代码如下,但我遇到问题的函数是 setNewTime()
这似乎是反向运行的。现在该函数如下所示:
setNewTime() {
this.newTimes = [];
this.timePicker('Day');
this.timePicker('Night');
console.log(this.newTimes);
}
现在奇怪的是,当单击运行此功能的按钮时。首先,它会记录一个空的 newTimes,之后它会使用时间选择器请求夜间时间,然后它会请求白天时间.. 在我看来,这真的很奇怪。首先,我有两个独立的 timePicker 函数。一个用于白天,一个用于晚上,但它们的行为完全相同。我的其余代码似乎运行得很好,而且也是我想要的,但这一部分似乎有它自己的想法。
有人能帮我吗?
鲁本
完整代码:
import { Component } from '@angular/core';
import { DatePicker } from '@ionic-native/date-picker';
import { AlertController } from 'ionic-angular';
import { API } from '../../api';
import { ActionSheetController } from 'ionic-angular';
@Component({
selector: 'page-monday',
templateUrl: 'monday.html'
})
export class MondayPage {
// Variables for get and put
public day : string = 'day';
public current_day : string = 'current_day';
public time : string = 'time';
public weekProgramState : string = 'weekProgramState';
public currentTemperature : string = 'currentTemperature';
public current_temperature : string = 'current_temperature';
public targetTemperature : string = 'targetTemperature';
public target_temperature : string = 'target_temperature';
public dayTemperature : string = 'dayTemperature';
public day_temperature : string = 'day_temperature';
public nightTemperature : string = 'nightTemperature';
public night_temperature : string = 'night_temperature';
// Arrays for pushing the data
newTimes: any = [];
currentPeriods: any = [];
sparePeriods: any = [];
constructor(
private datePicker: DatePicker,
public alertCtrl: AlertController,
public api: API,
public actionSheetCtrl: ActionSheetController
) {
this.getPeriods();
}
// Add a new time to the schedule
setNewTime() {
this.newTimes = [];
this.timePicker('Day');
this.timePicker('Night');
console.log(this.newTimes);
}
// Timepicker that lets you set the time
timePicker(time) {
this.datePicker.show({
date: new Date(),
mode: 'time',
//titleText: 'Please pick a ' + time + ' time',
okText: 'Set ' + time + ' time',
minuteInterval: 5,
is24Hour: true,
androidTheme: 16974393
}).then(
date => {
let minutes = date.getMinutes();
let hours = date.getHours();
let time : string;
if ( hours < 10 ) {
time = '0' + String(hours);
} else {
time = String(hours);
}
if ( minutes < 10 ) {
time = time + ':0' + String(minutes);
} else {
time = time + ':' + String(minutes);
}
//console.log(time)
this.newTimes.push(time);
console.log(this.newTimes)
},
err => this.alert(err) //this.newTimes.push(err)
);
}
// Makes sure the times are for format 00:00
setTime(date) {
let minutes = date.getMinutes();
let hours = date.getHours();
let time : string;
if ( hours < 10 ) {
time = '0' + String(hours);
} else {
time = String(hours);
}
if ( minutes < 10 ) {
time = time + ':0' + String(minutes);
} else {
time = time + ':' + String(minutes);
}
console.log(time)
this.newTimes.push(time);
}
// Push an alert out
alert(typeOfAlert : string) {
let cancel: string = 'CANCEL';
if (typeOfAlert == cancel) {
return;
} else {
let alert = this.alertCtrl.create({
title: 'Error occured!',
subTitle: 'For some reason an error occured while picking the time. Please try again!',
buttons: ['OK']
});
alert.present();
}
}
// Options for a set time period (change, delete)
optionsPeriod(id) {
let actionSheet = this.actionSheetCtrl.create({
title: 'Modify this time period',
buttons: [
{
text: 'Change',
handler: () => {
//this.newTimes = [];
this.timePicker('night');
this.timePicker('day');
this.removeTimePeriod('Monday', this.currentPeriods.indexOf(id));
this.addTimePeriod('Monday', this.newTimes[0], this.newTimes[1]);
}
},{
text: 'Delete',
handler: () => {
this.removeTimePeriod('Monday', this.currentPeriods.indexOf(id));
}
},{
text: 'Cancel',
role: 'cancel',
handler: () => {
}
}
]
});
actionSheet.present();
}
// Get data from the server
getServer(tag) {
return this.api.get(tag);
}
// Push data to the server
putServer(tag, xmlTag, value) {
this.api.put(tag, xmlTag, value);
}
// Add a time period
addTimePeriod(day, start, end) {
this.api.addPeriod(day, start, end);
}
// Remove a time period
removeTimePeriod(day, id) {
this.api.removePeriod(day, id);
}
// Gets the current periods and adds empty ones depending on that number.
getPeriods() {
this.currentPeriods = [];
this.sparePeriods = [];
this.currentPeriods = this.api.getWeekProgram().Monday;
for(var i = 0; i < (5 - this.currentPeriods.length); i++) {
this.sparePeriods.push(i);
}
}
}
最佳答案
由于函数 datePicker.show()
的异步性质以及函数 timePicker()
的扩展,此行为是预期的。
注意 .then
部分。这意味着 datePicker.show() 返回一个 Promise,该 Promise 会在将来解析并返回一个值。 当发生这种情况时,then 部分将异步执行,但在此之前它会被添加到所谓的事件队列中。您可以在视频 What the heck is the event loop anyway? 中了解有关所有这些有趣内容的更多信息。 .
因此,实际发生的情况是,每次调用 timePicker()
时,datePicker.show() 的 .then()
部分都会堆积在事件队列中等待当浏览器的 javacript 引擎无事可做时执行。
确保一切顺利运行的方法是调用 timePicker('Day')
并在其内部的 then() 函数调用 timePicker('Night')
>。但要做到这一切,timePicker()
需要返回一个 promise 。
所以我们可以将您的代码更改为如下所示:
// Timepicker that lets you set the time
timePicker(time) {
return new Promise( (resolve, reject) => { // notice I'm wrapping your code with a return of a new Promise
this.datePicker.show({
date: new Date(),
mode: 'time',
//titleText: 'Please pick a ' + time + ' time',
okText: 'Set ' + time + ' time',
minuteInterval: 5,
is24Hour: true,
androidTheme: 16974393
}).then(
date => {
let minutes = date.getMinutes();
let hours = date.getHours();
let time : string;
if ( hours < 10 ) {
time = '0' + String(hours);
} else {
time = String(hours);
}
if ( minutes < 10 ) {
time = time + ':0' + String(minutes);
} else {
time = time + ':' + String(minutes);
}
//console.log(time)
this.newTimes.push(time);
console.log(this.newTimes)
},
err => window.alert(err) //this.newTimes.push(err)
);
});
}
然后我们可以像这样链接异步函数调用:
// Add a new time to the schedule
setNewTime() {
this.newTimes = [];
this.timePicker('Day')
.then(() => {
this.timePicker('Night')
.then(() => {
console.log(this.newTimes);
});
});
}
你们的学校教授这样的酷炫编码练习真是太棒了,更重要的是你们正在使用 Ionic 和 Angular 等现代框架。坚持下去!
关于javascript - Ionic 3 typescript cordova DateTimePicker代码反向运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44604092/
我尝试理解[c代码 -> 汇编]代码 void node::Check( data & _data1, vector& _data2) { -> push ebp -> mov ebp,esp ->
我需要在当前表单(代码)的上下文中运行文本文件中的代码。其中一项要求是让代码创建新控件并将其添加到当前窗体。 例如,在Form1.cs中: using System.Windows.Forms; ..
我有此 C++ 代码并将其转换为 C# (.net Framework 4) 代码。有没有人给我一些关于 malloc、free 和 sprintf 方法的提示? int monate = ee; d
我的网络服务器代码有问题 #include #include #include #include #include #include #include int
给定以下 html 代码,将列表中的第三个元素(即“美丽”一词)以斜体显示的 CSS 代码是什么?当然,我可以给这个元素一个 id 或一个 class,但 html 代码必须保持不变。谢谢
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我试图制作一个宏来避免重复代码和注释。 我试过这个: #define GrowOnPage(any Page, any Component) Component.Width := Page.Surfa
我正在尝试将我的旧 C++ 代码“翻译”成头条新闻所暗示的 C# 代码。问题是我是 C# 中的新手,并不是所有的东西都像 C++ 中那样。在 C++ 中这些解决方案运行良好,但在 C# 中只是不能。我
在 Windows 10 上工作,R 语言的格式化程序似乎没有在 Visual Studio Code 中完成它的工作。我试过R support for Visual Studio Code和 R-T
我正在处理一些报告(计数),我必须获取不同参数的计数。非常简单但乏味。 一个参数的示例查询: qCountsEmployee = ( "select count(*) from %s wher
最近几天我尝试从 d00m 调试网络错误。我开始用尽想法/线索,我希望其他 SO 用户拥有可能有用的宝贵经验。我希望能够提供所有相关信息,但我个人无法控制服务器环境。 整个事情始于用户注意到我们应用程
我有一个 app.js 文件,其中包含如下 dojo amd 模式代码: require(["dojo/dom", ..], function(dom){ dom.byId('someId').i
我对“-gencode”语句中的“code=sm_X”选项有点困惑。 一个例子:NVCC 编译器选项有什么作用 -gencode arch=compute_13,code=sm_13 嵌入库中? 只有
我为我的表格使用 X-editable 框架。 但是我有一些问题。 $(document).ready(function() { $('.access').editable({
我一直在通过本教程学习 flask/python http://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-i-hello-wo
我想将 Vim 和 EMACS 用于 CNC、G 代码和 M 代码。 Vim 或 EMACS 是否有任何语法或模式来处理这种类型的代码? 最佳答案 一些快速搜索使我找到了 this vim 和 thi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve this
这个问题在这里已经有了答案: Enabling markdown highlighting in Vim (5 个回答) 6年前关闭。 当我在 Vim 中编辑包含 Markdown 代码的 READM
我正在 Swift3 iOS 中开发视频应用程序。基本上我必须将视频 Assets 和音频与淡入淡出效果合并为一个并将其保存到 iPhone 画廊。为此,我使用以下方法: private func d
pipeline { agent any stages { stage('Build') { steps { e
我是一名优秀的程序员,十分优秀!