Agile Lite默认控制器CSS扩展实现H5组件动画切换

Stella981
• 阅读 298

Agile Lite中提供了很多控制器和组件的交互,但是实际开发过程中还会遇到很多种场景无法满足。这里介绍一下如何使用Agile Lite的默认控制器和组件的UI渲染来满足不同的场景需要

默认控制器的扩展

默认控制器的扩展是指通过CSS样式对控制器进行UI渲染,使得默认控制器的使用场景更丰富。

扩展默认控制器的方法

Agile Lite的控制器和组件工作基本原理可以知道:当前被触发的控制器会具有active样式,而同组的其他控制器不具有active样式;处于激活状态的组件具有active样式,同组的其他组件不具有active样式。

所以,对默认控制的扩展,可以根据控制器和组件是否具有active样式实现。

实际案例操作

场景:

我们需要实现类似于大众点评筛选菜单的功能,效果如下:

可访问此链接查看

Agile Lite默认控制器CSS扩展实现H5组件动画切换

从效果图看,页面顶部第二排的过滤器按钮其实就是控制器,他们的特点就是当点击某个控制器的时候箭头的方向会改变,所以我们可以给具有active样式的控制器设置箭头向上的样式,不具有active样式的控制器设置箭头向下的样式。

控制器HTML代码片段如下:

<ul class="my_filter_controller">
    <li data-role="tab" data-toggle="view" href="#fujin"><span>附近</span><i>|</i></li>
    <li data-role="tab" data-toggle="view" href="#meishi"><span>美食</span><i>|</i></li>
    <li data-role="tab" data-toggle="view" href="#paixu"><span>智能排序</span><i>|</i></li>
    <li data-role="tab" data-toggle="view" href="#shaixuan"><span>筛选</span></li>
</ul>

此控制器的样式如下:

.my_filter_controller { z-index:2;position:absolute;top:44px; height:44px;width:100%; clear:both; border-bottom:1px solid #e7e7e7; background:#fff;}
.my_filter_controller li { float:left; width:25%; line-height:44px; text-align:center; font-size:12px; }
.my_filter_controller li span:after { color:#95a5a6;font-family: Ratchicons;}
.my_filter_controller li span:after{ content: '\e814'; }
.my_filter_controller li.active span:after{ content: '\e81f'; -webkit-animation: spinner 0.1s 2 linear;animation: spinner 0.1s 2 linear;}
.my_filter_controller li i { float:right; color:#ECF0F1;}

这里尤其关注.my_filter_controller li span:after和.my_filter_controller li.active span:after

.my_filter_controller下的li为控制器,所以li在处于激活和为激活状态时分别具有active样式和非active样式,只需要根据这个特点设置不同的字体图就可以实现点击箭头切换的效果

同样的,点击过滤按钮控制器会向下弹出对应的组件,而向下弹出的动画效果可以加到具有active的组件中,而不具有active样式的组件设置隐藏即可。

组件HTML代码片段如下:

<div id="meishi" class="my_filter_component" data-role="view">
    <div class="my_filter_component_content">
        <div style="text-align:center;padding:20px 0px;">在这里自定义你的内容吧</div>
    </div>
</div>

其样式为:

.my_filter_component.active { z-index:1; position:absolute; display:block; width:100%; height:100%; background:rgba(0,0,0,0.2);}
        
.my_filter_component.active .my_filter_component_content { -webkit-animation: slideDownIn 1s; height:80%; background:#fff;}

只需要给组件的active下的子元素添加动画即可

是不是很简单呢

扩展默认控制器的使用总结


Agile Lite默认内置了很多常用组件,当不够用的时候就可以通过扩展默认控制器实现部分效果。当默认控制器的UI渲染仍然无法达到预定的效果时再考虑控制器的扩展,自己开发一个全新的控制器实现逻辑。

点赞
收藏
评论区
推荐文章
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
光头强的博客 光头强的博客
5个月前
Java面向对象试题
1、请创建一个Animal动物类,要求有方法eat()方法,方法输出一条语句“吃东西”。创建一个接口A,接口里有一个抽象方法fly()。创建一个Bird类继承Animal类并实现接口A里的方法输出一条有语句“鸟儿飞翔”,重写eat()方法输出一条语句“鸟儿吃虫”。在Test类中向上转型创建b对象,调用eat方法。然后向下转型调用eat()方
刚刚好 刚刚好
5个月前
css问题
1、在IOS中图片不显示(给图片加了圆角或者img没有父级)<div<imgsrc""/</divdiv{width:20px;height:20px;borderradius:20px;overflow:h
晴空闲云 晴空闲云
5个月前
css中box-sizing解放盒子实际宽高计算
我们知道传统的盒子模型,如果增加内边距padding和边框border,那么会撑大整个盒子,造成盒子的宽度不好计算,在实务中特别不方便。boxsizing可以设置盒模型的方式,可以很好的设置固定宽高的盒模型。盒子宽高计算假如我们设置如下盒子:宽度和高度均为200px,那么这会这个盒子实际的宽高就都是200px。但是当我们设置这个盒子的边框和内间距的时候,那
艾木酱 艾木酱
5个月前
快速入门|使用MemFire Cloud构建React Native应用程序
MemFireCloud是一款提供云数据库,用户可以创建云数据库,并对数据库进行管理,还可以对数据库进行备份操作。它还提供后端即服务,用户可以在1分钟内新建一个应用,使用自动生成的API和SDK,访问云数据库、对象存储、用户认证与授权等功能,可专
Easter79 Easter79
1年前
SpringMVC中url映射到Controller
SpringMVC也是一种基于请求驱动的WEB框架,并且使用了前端控制器的设计模式。前端控制器就是DispatcherServlet控制器,只要满足web.xml文件中的【urlpattern】的规则,这个请求就会交给这个前端控制器(DispatcherServlet),然而前端控制器在收到请求后自己不进行任何处理,根据相应的【URL的映射规则】委托给其他
Stella981 Stella981
1年前
Sass
嵌套规则(NestedRules)Sass允许将一套CSS样式嵌套进另一套样式中,内层的样式将它外层的选择器作为父选择器mainp{color:00ff00;width:97%;.redbox{
Stella981 Stella981
1年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
1年前
STM32 中断详解
中断,在单片机中占有非常重要的地位。代码默认地从上向下执行,遇到条件或者其他语句,会按照指定的地方跳转。而在单片机执行代码的过程中,难免会有一些突发的情况需要处理,这样就会打断当前的代码,待处理完突发情况之后,程序会回到被打断的地方继续执行。1EXTI控制器外部中断/事件控制器(EXTI)管理了控制器的23个中断/事件线。每
helloworld_28799839 helloworld_28799839
5个月前
常用知识整理
Javascript判断对象是否为空jsObject.keys(myObject).length0经常使用的三元运算我们经常遇到处理表格列状态字段如status的时候可以用到vue