RxAndroid中observable的基本使用和表单校验操作

RxAndroid 响应式编程 类似于监听-观察者模式

在观察者模式中,你的对象需要实现 RxJava 中的两个关键接口:Observable 和 Observer。当 Observable 的状态改变时,所有的订阅它的 Observer 对象都会被通知。

在 Observable 接口的众多方法中,调用 subscribe() 让 Observer 开始订阅该Observable

从这时起,Observer 接口有三个方法是 Observable 调用时需要的:

  • onNext(T value) 提供了一个新的 T 类型的条目给 Observer
  • onComplete() 通知 ObserverObservable 已发送完条目
  • onError(Throwable e) 通知 ObserverObservable 遇到了一个错误

gradle配置

observable操作大概分为以下几种

1.创建操作

Create — 通过调用观察者的方法从头创建一个ObservableDefer — 在观察者订阅之前不创建这个Observable,为每一个观察者创建一个新的ObservableEmpty/Never/Throw — 创建行为受限的特殊ObservableFrom — 将其它的对象或数据结构转换为ObservableInterval — 创建一个定时发射整数序列的ObservableJust — 将对象或者对象集合转换为一个会发射这些对象的ObservableRange — 创建发射指定范围的整数序列的ObservableRepeat — 创建重复发射特定的数据或数据序列的ObservableStart — 创建发射一个函数的返回值的ObservableTimer — 创建在一个指定的延迟之后发射单个数据的Observable

2.组合操作
And/Then/When — 通过模式(And条件)和计划(Then次序)组合两个或多个Observable发射的数据集CombineLatest — 当两个Observables中的任何一个发射了一个数据时,通过一个指定的函数组合每个Observable发射的最新数据(一共两个数据),然后发射这个函数的结果Join — 无论何时,如果一个Observable发射了一个数据项,只要在另一个Observable发射的数据项定义的时间窗口内,就将两个Observable发射的数据合并发射Merge — 将两个Observable发射的数据组合并成一个StartWith — 在发射原来的Observable的数据序列之前,先发射一个指定的数据序列或数据项Switch — 将一个发射Observable序列的Observable转换为这样一个Observable:它逐个发射那些Observable最近发射的数据Zip — 打包,使用一个指定的函数将多个Observable发射的数据组合在一起,然后将这个函数的结果作为单项数据发射
3.辅助操作(用于处理Observable的操作符)
Delay — 延迟一段时间发射结果数据Do — 注册一个动作占用一些Observable的生命周期事件,相当于Mock某个操作Materialize/Dematerialize — 将发射的数据和通知都当做数据发射,或者反过来ObserveOn — 指定观察者观察Observable的调度程序(工作线程)Serialize — 强制Observable按次序发射数据并且功能是有效的Subscribe — 收到Observable发射的数据和通知后执行的操作SubscribeOn — 指定Observable应该在哪个调度程序上执行TimeInterval — 将一个Observable转换为发射两个数据之间所耗费时间的ObservableTimeout — 添加超时机制,如果过了指定的一段时间没有发射数据,就发射一个错误通知Timestamp — 给Observable发射的每个数据项添加一个时间戳Using — 创建一个只在Observable的生命周期内存在的一次性资源

4.条件和布尔操作(可用于单个或多个数据项,也可用于Observable)
All — 判断Observable发射的所有的数据项是否都满足某个条件Amb — 给定多个Observable,只让第一个发射数据的Observable发射全部数据Contains — 判断Observable是否会发射一个指定的数据项DefaultIfEmpty — 发射来自原始Observable的数据,如果原始Observable没有发射数据,就发射一个默认数据SequenceEqual — 判断两个Observable是否按相同的数据序列SkipUntil — 丢弃原始Observable发射的数据,直到第二个Observable发射了一个数据,然后发射原始Observable的剩余数据SkipWhile — 丢弃原始Observable发射的数据,直到一个特定的条件为假,然后发射原始Observable剩余的数据TakeUntil — 发射来自原始Observable的数据,直到第二个Observable发射了一个数据或一个通知TakeWhile — 发射原始Observable的数据,直到一个特定的条件为真,然后跳过剩余的数据

5.错误处理
Catch — 捕获,继续序列操作,将错误替换为正常的数据,从onError通知中恢复Retry — 重试,如果Observable发射了一个错误通知,重新订阅它,期待它正常终止

简单用法

匹配字符串过滤

        final List<String> data = new ArrayList<String>() ;        data.add("a");        data.add("ac");        data.add("acccc");        data.add("a3ddcc");        data.add("bnbbc");        data.add("9if");

        RxTextView .textChanges(et_name)                .debounce(500 , TimeUnit.MILLISECONDS)                .map(new Function<CharSequence, String>() {                    @Override                    public String apply(CharSequence charSequence) throws Exception {                        return charSequence.toString();                    }                })                .observeOn(Schedulers.io())//                .filter(new Predicate<String>() {//                    @Override//                    public boolean test(String s) throws Exception {//                        return false;//                    }//                })                .map(new Function<String, List<String>>() {                    @Override                    public List<String> apply(String s) throws Exception {                        List<String> dataList = new ArrayList<String>() ;                        if ( !TextUtils.isEmpty(s)){                            //通过key s去过滤list集合                            for(String bean : data){                                if(bean.contains(s)){                                    dataList.add(bean);                                }                            }                        }                        return dataList;                    }                })                .observeOn(AndroidSchedulers.mainThread())                .subscribe(new Consumer<List<String>>() {                    @Override                    public void accept(List<String> strings) throws Exception {                        Log.e("LM" , "符合的数据个数  " + (strings == null ? 0 : strings.size()));                    }                });上面的例子就是通过key去过滤list 最后打印出来符合数据的个数。

RxAndroid更好的实现了主/子线程之间的切换,上面的例子我们可以看到subscribeOn()指定向subscribe()动作发生的线程。observeOn()指定观察者得到通知回调时的线程。

AndroidSchedulers.mainThread()//主线程

Schedulers.immediate()//当前线程立马执行

Schedulers.newThread()//每次创建新线程运行代码

Scheduler.io()//执行IO操作,或者是网络访问耗时但不耗费CPU的操作

Schedulers.computation() //执行图形计算等复杂计算


最后 讲一个表单校验的例子,我们很多情况下会有这种场景,一个页面需要用户输入很多信息,刚开始按钮不可点击,当每项信息都输入了之后 按钮变成可点击的状态。这种情况我们一般会想到监听每个输入框的输入事件,比较麻烦,我们可以通过observable去实现它,如下:比如有三项准备要输入的内容
InitialValueObservable<CharSequence> observableName = RxTextView.textChanges(et_name);InitialValueObservable<CharSequence> observablePhone = RxTextView.textChanges(et_phone);InitialValueObservable<CharSequence> observablePwd = RxTextView.textChanges(et_pwd);List<InitialValueObservable<CharSequence>> observableList = new ArrayList<>();
observableList.add(observableName);observableList.add(observablePhone);observableList.add(observablePwd);
Observable.combineLatest(observableList, new Function<Object[], Boolean>() {

    @Override    public Boolean apply(Object[] objects) throws Exception {        for (Object o : objects){            if(TextUtils.isEmpty((CharSequence) o)){                return false;            }        }        return true;    }}).observeOn(AndroidSchedulers.mainThread()).subscribe(new Observer<Boolean>() {    @Override    public void onSubscribe(Disposable d) {

    }

    @Override    public void onNext(Boolean aBoolean) {        if(aBoolean){            btn.setEnabled(true);        }else{            btn.setEnabled(false);        }    }

    @Override    public void onError(Throwable e) {

    }

    @Override    public void onComplete() {

    }});
代码很清晰,通过apply方法的返回值 会判断按钮是否可以点击。未完待续...
 
 
时间: 2024-10-14 02:38:28

RxAndroid中observable的基本使用和表单校验操作的相关文章

应用二:Vue之ElementUI Form表单校验

  表单校验是前端开发过程中最常用到的功能之一,根据个人的工作经验总结在此对表单校验功能的基础用法进行整理说明~ 如下代码是Form表单校验的demo示例: <template> <div id="demo"> <el-dialog title="表单校验示例" :close-on-click-modal="false" :visible.sync="dialogVisible" width=&q

在javascript中关于submit和button提交表单区别

原文:在javascript中关于submit和button提交表单区别 原文来自:http://www.jb51.net/article/42236.htm submit是button的一个特例,也是button的一种,它把提交这个动作自动集成了,submit和button,二者都以按钮的形式展现,看起来都是按钮,所不同的是type属性和处发响应的事件上. 1. 如果表单在点击提交按钮后需要用JS进行处理(包括输入验证)后再提交的话,通常都必须把submit改成button,即取消其自动提交的

JQuery中内容操作函数、validation表单校验

JQuery:内容体拼接(可以直接拼接元素节点和内容节点) JQuery实现: 方案1:A.append(B); == B.appendTo(A);A的后面拼接B 方案2: A.prepend(B); == B.prependTo(A);A文本的最前面插入B text()与html()比较: 1.相同点: 都可以设置或获取内容 2.不同点: 获取时,html()获取的是所有内容体:标签+文本 text()获取的只是文本 设置时,如果设置的内容有html()标签 html()设置的内容可以被浏览器

(转)在javascript中关于submit和button提交表单区别

原文来自:http://www.jb51.net/article/42236.htm submit是button的一个特例,也是button的一种,它把提交这个动作自动集成了,submit和button,二者都以按钮的形式展现,看起来都是按钮,所不同的是type属性和处发响应的事件上. 1. 如果表单在点击提交按钮后需要用JS进行处理(包括输入验证)后再提交的话,通常都必须把submit改成button,即取消其自动提交的行为, 否则,将会造成提交两次的效果,对于动态网页来说,也就是对数据库操作

【JAVAWEB学习笔记】28_jqueryAjax:json数据结构、jquery的ajax操作和表单校验插件

Ajax-jqueryAjax 今天内容: 1.json数据结构(重点) 2.jquery的ajax操作(重点) 3.jquery的插件使用   一.json数据结构 1.什么是json JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯.这些特性使JSON成 为理想的数据交换语言.易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络

利用jquery.validate以及bootstrap的tooltip开发气泡式的表单校验组件

表单校验是页面开发中非常常见的一类需求,相信每个前端开发人员都有这方面的经验.网上有很多成熟的表单校验框架,虽然按照它们默认的设计,用起来没有多大的问题,但是在实际工作中,表单校验有可能有比较复杂的个性化的需求,使得我们用这些插件的默认机制并不能完成这些功能,所以要根据自己的需要去改造它们(毕竟自己还不到那个写一个完美的校验框架的层次).我用过formValidation这个校验框架,虽然它跟bootstrap配合地很好,但是校验风格太死板,不太满足个性化的场景:后来我找到了jquery.val

简约的form表单校验插件

前言 网上有好多form表单校验插件,包括jquery的表单检验插件,这些中好多插件功能很齐全强大,提示方式很酷,很美观好看.本想拿来用,但是发现几个问题: 1.使用不方便.校验规则繁多,调用校验函数难记忆. 2.提示方式固定.一般插件给出固定的几种提示方式,但是实际中,不同系统都有自己的页面风格样式,有自己的提示方式,插件自带的一般用不上. 因此,我最终没有采用这些插件,以免用后出现难以修改或实现的情况. 如果一种校验插件能避免以上两个问题最好了,方便使用,提示方式自定义 ,所以自己做了一个简

开发指南专题十:JEECG微云快速开发平台--表单校验组件ValidForm

10.4Validform对象[方法支持链式调用] 如示例 var demo=$(".formsub").Validform(),那么demo对象会有以下属性和方法可以调用: tipmsg[object] 如:demo.tipmsg.s="error! no messageinputed."; 通过该对象可以修改除 tit 以外的其他提示文字,这样可以实现同一个页面的不同表单使用不同的提示文字. 具体可修改的提示文字 $.Tipmsg={//默认提示文字; tit:

创建通用的表单校验逻辑库

表单校验一直是web开发中最基础,也是最不好做的一个环节.说是基础,相信多少从事web开发的人第一件事就是学习如果基于js.jQuery实现表单验证工作.在10年前,甚至是5年前,JavaScript还是被多数工程师轻视的一门语言,那时候很多人认为JavaScript充其量也就能完成一部分表单校验的工作.由此可知表单校验是多么基础的一件事情:说它不好做,是因为表单校验往往工作量极大,可以说是一个没太大技术含量但是很耗费体力的活,而且在一些对交互友好性要求较高的项目中,表单校验就更加费事了. 于是