- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我已经成功地将一个按钮变成了一个可以改变标签的关闭和打开开关。
我还能够让它在发生这种情况时启动定时处理,并且它能够关闭定时过程。
无论如何,我需要关闭定时进程的方法,我想知道是否有办法在不使用一次性用品的情况下停止它。使用第二个 takeUntil 信号。
编辑我认为我试图做的有点误导让我展示我当前有效的解决方案。
-(RACSignal*) startTimer {
return [[RACSignal interval:1.0
onScheduler:[RACScheduler mainThreadScheduler]]
startWith:[NSDate date]];
}
-(void) viewWillAppear:(BOOL)animated {}
-(void) viewDidLoad {
self.tableView.delegate = self;
self.tableView.dataSource = self;
RACSignal* pressedStart = [self.start rac_signalForControlEvents:UIControlEventTouchUpInside];
@weakify(self);
RACSignal* textChangeSignal = [pressedStart map:^id(id value) {
@strongify(self);
return [self.start.titleLabel.text isEqualToString:@"Start"] ? @"Stop" : @"Start";
}];
// Changes the title
[textChangeSignal subscribeNext:^(NSString* text) {
@strongify(self);
[self.start setTitle:text forState:UIControlStateNormal];
}];
RACSignal* switchSignal = [[textChangeSignal map:^id(NSString* string) {
return [string isEqualToString:@"Stop"] ? @0 : @1;
}] filter:^BOOL(id value) {
NSLog(@"Switch %@",value);
return [value boolValue];
}];
[[self rac_signalForSelector:@selector(viewWillAppear:)]
subscribeNext:^(id x) {
}];
static NSInteger t = 0;
// Remake's it self once it is on finished.
self.disposable = [[[textChangeSignal filter:^BOOL(NSString* text) {
return [text isEqualToString:@"Stop"] ? [@1 boolValue] : [@0 boolValue];
}]
flattenMap:^RACStream *(id value) {
NSLog(@"Made new Sheduler");
@strongify(self);
return [[self startTimer] takeUntil:switchSignal];
}] subscribeNext:^(id x) {
NSLog(@"%@",x);
@strongify(self);
t = t + 1;
NSLog(@"%zd",t);
[self updateTable];
}];
[[self rac_signalForSelector:@selector(viewWillDisappear:)] subscribeNext:^(id x) {
NSLog(@"viewWillAppear Dispose");
[self.disposable dispose];
}];
}
-(BOOL) isGroupedExcercisesLeft {
BOOL isGroupedLeft = NO;
for (int i =0;i < [self.excercises count]; i++) {
Excercise* ex = [self.excercises objectAtIndex:i];
if(ex.complete == NO && ex.grouped == YES) {
isGroupedLeft = YES;
break;
}
}
return isGroupedLeft;
}
-(void) updateTable {
// Find the
NSInteger nextRow;
if (([self.excercises count] > 0 || self.excercises !=nil) && [self isGroupedExcercisesLeft]) {
for (int i =0;i < [self.excercises count]; i++) {
Excercise* ex = [self.excercises objectAtIndex:i];
if(ex.complete == NO && ex.grouped == YES) {
nextRow = i;
break;
}
}
NSIndexPath* path = [NSIndexPath indexPathForItem:nextRow inSection:0];
NSArray* indexPath = @[path];
// update //
Excercise* ex = [self.excercises objectAtIndex:nextRow];
[self.tableView scrollToRowAtIndexPath:path atScrollPosition:UITableViewScrollPositionTop animated:YES];
if (ex.seconds <= 0) {
RLMRealm* db = [RLMRealm defaultRealm];
[db beginWriteTransaction];
ex.complete = YES;
[db commitWriteTransaction];
}
else {
// Update Seconds
RLMRealm* db = [RLMRealm defaultRealm];
[db beginWriteTransaction];
ex.seconds = ex.seconds - 1000;
NSLog(@"Seconds: %zd",ex.seconds);
[db commitWriteTransaction];
// Update table
[self.tableView reloadRowsAtIndexPaths:indexPath withRowAnimation:UITableViewRowAnimationNone];
}
} else {
NSLog(@"Done");
SIAlertView *alertView = [[SIAlertView alloc] initWithTitle:@"Deskercise" andMessage:@"Excercises Complete"];
[alertView addButtonWithTitle:@"Ok"
type:SIAlertViewButtonTypeDefault
handler:^(SIAlertView *alert) {
}];
alertView.transitionStyle = SIAlertViewTransitionStyleBounce;
[alertView show];
NSLog(@"Dispose");
[self.disposable dispose];
}
}
最佳答案
使用 takeUntil:self.completeSignal
的问题是当你改变completeSignal
到另一个值,它不会传递给任何已经在等待 completeSignal
变量的函数之前持有。
- (RACSignal*) startTimer {
@weakify(self)
return [[[RACSignal interval:1.0
onScheduler:[RACScheduler mainThreadScheduler]]
startWith:[NSDate date]]
takeUntil:[[self.start rac_signalForControlEvents:UIControlEventTouchUpInside]
merge:[[RACObserve(self, completeSignal) skip:1] flattenMap:
^RACStream *(RACSignal * signal) {
@strongify(self)
return self.completeSignal;
}]]
];
}
信号现在正在观察和变平completeSignal
,这将产生预期的效果。 takeUntil:
忽略未发送下一个事件而完成的信号, 所以使用 self.completedSignal = [RACSignal return:nil]
, 它发送一个下一个事件然后完成。
但是,这段代码并不理想,让我们看看更好的解决方案。
@property (nonatomic, readwrite) RACSubject * completeSignal;
- (RACSignal*) startTimer {
return [[[RACSignal interval:1.0
onScheduler:[RACScheduler mainThreadScheduler]]
startWith:[NSDate date]]
takeUntil:[[self.start rac_signalForControlEvents:UIControlEventTouchUpInside]
merge:self.completeSignal]
];
}
- (void) viewDidLoad {
[super viewDidLoad];
self.completeSignal = [RACSubject subject];
self.tableView.delegate = self;
self.tableView.dataSource = self;
RACSignal * pressedStart = [self.start rac_signalForControlEvents:UIControlEventTouchUpInside];
@weakify(self);
RACSignal* textChangeSignal = [[pressedStart startWith:nil] scanWithStart:@"Stop" reduce:^id(id running, id next) {
return @{@"Start":@"Stop", @"Stop":@"Start"}[running];
}];
[self.start
rac_liftSelector:@selector(setTitle:forState:)
withSignals:textChangeSignal, [RACSignal return:@(UIControlStateNormal)], nil];
[[[pressedStart flattenMap:^RACStream *(id value) { //Using take:1 so that it doesn't get into a feedback loop
@strongify(self);
return [self startTimer];
}] scanWithStart:@0 reduce:^id(NSNumber * running, NSNumber * next) {
return @(running.unsignedIntegerValue + 1);
}] subscribeNext:^(id x) {
@strongify(self);
[self updateTable];
NSLog(@"%@", x);
}];
}
- (void) updateTable {
//If you uncomment these then it'll cause a feedback loop for the signal that calls updateTable
//[self.start sendActionsForControlEvents:UIControlEventTouchUpInside];
//[self.completeSignal sendNext:nil];
if ([self.excercises count] > 0 || self.excercises !=nil) {
} else {
}
}
让我们浏览一下更改列表:
completeSignal
现在是 RACSubject(手动控制的 RACSignal)。@weakify
指令,textChangeSignal
现在使用得心应手的 scanWithStart:reduce:
方法,它允许您访问累加器(这适用于处理递增或递减数字的方法)。start
的文本现在被 rac_liftSelector
更改了函数,它接受 RACSignals 并在所有信号都触发时解包它们。flattenMap:
替换 pressedStart
与 [self startTimer]
现在使用 scanWithStart:reduce
,这是一种更实用的计数方式。我不确定您是否通过 updateTable
进行测试包含完成信号,但它肯定会导致您的 flattenMap:
出现逻辑问题的 pressedButton
,由此产生的反馈循环最终会在堆栈溢出时使程序崩溃。
关于ios - ReactiveCocoa takeUntil 2 个可能的信号?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31092146/
我想找到所有等于第一个7的项目: val list = List(1,4,5,2,3,5,5,7,8,9,2,7,4) 我的解决方案是: list.takeWhile(_ != 7) ::: List
我有一个服务调用,我每 5 秒检查它是否返回 true 或 false。 notifier(){ return Rx.Observable.of(true) // based on some c
来自 the docs for the TakeUntil operator (强调我的): The TakeUntil subscribes and begins mirroring the sou
向 TakeUntil 添加多个条件的最佳方法是什么?是否只是将 TakeUntil() 调用相互链接起来的问题? IObservable propertyToObserve = ... var ob
在下面的代码示例中,目的是通过向 Subject mid$ 发出 1 来阻止来自 second$ 的事件。 import { Subject, timer } from "rxjs"; import
我订阅了从 NgRx reducer 获取提供程序的订阅。我想用takeUntil()当最终返回一个包含内容的数组时自动关闭订阅: // Fetch providers this.store.pipe
这里没什么太严肃的,只是好奇。 我想举个例子,想出了这段代码: const { Observable, Subject } = Rx const timeout$ = new Subject() co
这里没什么太严肃的,只是好奇。 我想举个例子,想出了这段代码: const { Observable, Subject } = Rx const timeout$ = new Subject() co
我想根据两个条件停止可观察订阅: 时间(使用 import { timer } from 'rxjs/internal/observable/timer'; ) 或 执行状态(使用您将在下面看到的请求
我正在尝试在可观察对象上实现一个辅助方法,该方法返回一个新的可观察对象,在达到超时之前只发出值: implicit class ObservableOps[T](obs: Observable[T])
我想在触发 takeUntil 运算符时执行一个函数(在 ajaxObservable 之外)。 In this way被立即触发,因为我调用了 observer.complete(),但如果我不调用
以下代码定义了我想要的行为(有效)。仅当鼠标按下时才会触发 mousemove 事件。 Rx.Observable.fromEvent(window,"mouseup") .subscribe(
我想使用“takeUntil”运算符以声明式方式取消订阅。但这基本上是行不通的。无论如何我都可以看到控制台输出。 const unsubscribe = new Subject(); function
我有一个未知大小的用户列表。我想要的是查询 first 30 并更新 UI。然后我想通过以 100 为步长的偏移量来查询所有其他用户,直到我得到最后一批用户 - 我应该在这里使用 takeUntil
是否有可能在 takeUntil 运算符中发出满足条件的项目? 最佳答案 嗯,我不确定我是否理解你的问题。是这样的吗? @Test public void tesTakeUntil() { L
我有以下倒计时: userClick=new Subject() resetCountdown(){this.userClick.next()} setCountDown() { let co
因此,如果函数运行的时间足够长以触发在计时器上运行的 takeUntil 函数,我试图让 bool 值为真。 这是代码 start = this.http.get(environment.shocha
我在听 mousemove事件直到mouseup .我正在做 takeUntil . 我的代码: const onMouseMove = fromEvent(window, "mousemov
我有一个简单的 Rxjs 计时器,它会一直运行直到通知程序发出一些东西,直到这里非常基本。 enum TimerResult = { COMPLETE, ABORTED, SK
目前我正在使用 takeWhile (\x -> x /= 1 && x /= 89) l 从列表中获取最多为 1 或 89 的元素。但是,结果不包括这些标记值。 Haskell 是否有一个标准函数可
我是一名优秀的程序员,十分优秀!