• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

TypeScript option-t.Option类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了TypeScript中option-t.Option的典型用法代码示例。如果您正苦于以下问题:TypeScript Option类的具体用法?TypeScript Option怎么用?TypeScript Option使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



在下文中一共展示了Option类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的TypeScript代码示例。

示例1: _createSuggestion

    private _createSuggestion(value: string): Array<string> {
        const candidate: Array<string> = ([] as Array<string>).concat(words);
        const users: Option<Array<User>> = this._currntChannel.map(function (channel) {
            return channel.userList();
        });

        if (users.isSome) {
            for (const user of users.unwrap()) {
                const n = user.nickname;
                candidate.push(n.toLowerCase());
            }
        }

        return candidate.filter(function (word: string, item: string) {
            return item.indexOf(word) === 0;
        }.bind(null, value.toLowerCase()));
    }
开发者ID:karen-irc,项目名称:karen,代码行数:17,代码来源:InputBoxView.ts


示例2:

 domain.getCurrentTab().map((v) => v.channelId).do((channelId: Option<ChannelId>) => {
     this._currentId = channelId;
     if (channelId.isSome) {
         const id = channelId.unwrap();
         this._notableChannelSet.delete(id);
         this._unreadCount.set(id, 0);
     }
 });
开发者ID:karen-irc,项目名称:karen,代码行数:8,代码来源:SidebarStore.ts


示例3: handleShortcut

    handleShortcut(event: KeyboardEvent, key: string): void {
        const channelList: Array<Channel> = this._domain.networkSet.getChannelList();
        // tslint:disable-next-line:no-non-null-assertion
        const currentIndex: Option<ChannelId> = this._domain.currentTab!.channelId.map(function (currentId: ChannelId): number {
            const result = channelList.findIndex(function (channel: Channel) {
                return channel.id === currentId;
            });
            if (result === undefined) {
                throw new Error('should not be undefined');
            }
            else {
                return result;
            }
        });

        if (currentIndex.isNone) {
            return;
        }

        const index = currentIndex.unwrap();
        const length = channelList.length;
        switch (key) {
            case 'ArrowUp':
                {
                    // Loop
                    const target = (length + (index - 1 + length)) % length;
                    const id = channelList[target].id;
                    event.preventDefault();
                    this._uiAction.selectChannel(id);
                }
                break;

            case 'ArrowDown':
                {
                    // Loop
                    const target = (length + (index + 1 + length)) % length;
                    const id = channelList[target].id;
                    event.preventDefault();
                    this._uiAction.selectChannel(id);
                }
                break;
        }
    }
开发者ID:karen-irc,项目名称:karen,代码行数:43,代码来源:WindowPresenter.ts


示例4: onSubmit

    socket.auth().subscribe(function (_: any) { // tslint:disable-line:no-any
        const body: HTMLElement = window.document.body;
        const login = document.getElementById('sign-in');
        if (login === null) {
            intent.app.reload();
            return;
        }
        // @ts-ignore
        Array.from(login.querySelectorAll('.btn')).forEach(function (element: HTMLInputElement) {
            element.disabled = false;
        });
        const token: Option<string> = auth.getToken();
        if (token.isSome) {
            auth.removeToken();
            socket.emit('auth', { token: token.unwrap() });
        }
        if (body.classList.contains('signed-out')) {
            const error = login.querySelector('.error') as HTMLElement;
            error.style.display = '';
            // tslint:disable-next-line:no-non-null-assertion
            const form = login.querySelector('.container')!;
            form.addEventListener('submit', function onSubmit() {
                form.removeEventListener('submit', onSubmit);
                error.style.display = 'none';
            });
        }
        if (token.isNone) {
            body.classList.add('signed-out');
        }
        const input = login.querySelector('input[name=\'user\']') as HTMLInputElement;
        if (input.value === '') {
            input.value = auth.getUser().unwrapOr('');
        }
        if (token.isSome) {
            return;
        }

        uiAction.showSignIn();
    });
开发者ID:karen-irc,项目名称:karen,代码行数:39,代码来源:karen.ts


示例5:

 this._disposer.add(domain.getSelectedChannel().subscribe((id: ChannelId) => {
     const current: Option<Channel> = domain.networkSet.getChannelById(id);
     const title = current.unwrap().name;
     this.onCurrentTabChanged(title);
 }));
开发者ID:karen-irc,项目名称:karen,代码行数:5,代码来源:WindowPresenter.ts


示例6: clearLog

    clearLog(): void {
        if (this._currntChannel.isNone) {
            return;
        }

        const channel = this._currntChannel.unwrap();
        this._msgAction.clear(channel.id);
    }
开发者ID:karen-irc,项目名称:karen,代码行数:8,代码来源:InputBoxView.ts


示例7: _updateUnreadCount

    private _updateUnreadCount(channelId: ChannelId): boolean {
        const targetIsCurrent: boolean = this._currentId.mapOr(false, function(id){
            return id === channelId;
        });
        if (targetIsCurrent) {
            return false;
        }

        let current: number | undefined = this._unreadCount.get(channelId);
        if (current === undefined) {
            this._unreadCount.set(channelId, 0);
            current = 0;
        }

        const latest = current + 1;
        this._unreadCount.set(channelId, latest);
        return true;
    }
开发者ID:karen-irc,项目名称:karen,代码行数:18,代码来源:SidebarStore.ts



注:本文中的option-t.Option类示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript ora.default函数代码示例发布时间:2022-05-25
下一篇:
TypeScript optimist.usage函数代码示例发布时间:2022-05-25
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap