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

Stella981
• 阅读 433

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
2年前
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
Wesley13 Wesley13
2年前
STM32 中断详解
中断,在单片机中占有非常重要的地位。代码默认地从上向下执行,遇到条件或者其他语句,会按照指定的地方跳转。而在单片机执行代码的过程中,难免会有一些突发的情况需要处理,这样就会打断当前的代码,待处理完突发情况之后,程序会回到被打断的地方继续执行。1EXTI控制器外部中断/事件控制器(EXTI)管理了控制器的23个中断/事件线。每
Wesley13 Wesley13
2年前
K8S各知识点整理
一、k8s组成部分Master1、  kubeapiserver封装了核心对象的增删改查操作,以RESTAPI接口方式提供给外部和内部组件调用。它维护的REST对象将持久化到Etcd中2、  kubecontroller负责执行各种控制器,目前已经实现很多控制器来
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Easter79 Easter79
2年前
SpringMVC中url映射到Controller
SpringMVC也是一种基于请求驱动的WEB框架,并且使用了前端控制器的设计模式。前端控制器就是DispatcherServlet控制器,只要满足web.xml文件中的【urlpattern】的规则,这个请求就会交给这个前端控制器(DispatcherServlet),然而前端控制器在收到请求后自己不进行任何处理,根据相应的【URL的映射规则】委托给其他
Stella981 Stella981
2年前
Sass
嵌套规则(NestedRules)Sass允许将一套CSS样式嵌套进另一套样式中,内层的样式将它外层的选择器作为父选择器mainp{color:00ff00;width:97%;.redbox{
Stella981 Stella981
2年前
OFBiz 快速入门——续二
OFBiz快速入门——续二2011年03月17日星期四00:03OFBiz 快速入门2.5 创建一个文件,取名为(controller.xml),被OFBiz webapp控制器使用的。在没有额外增加功能时,这个文件内容非常的小与简单,如下:<?xml version"1.0" encoding"UTF8"?<siteco
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
2年前
JOptionPane修改图标
1.在Linux平台下.JOptionPane会显示Java默认的图标,在window平台不显示图标,如何替换这个图标了?2JOptionPane.setIcon(Icon)修改的是内容区域的icon,而不是左上角的Icon.所以需要通过修改Jdialog/Frame的图标来达到修改默认图标的问题.3.代码:if(JOptio
Stella981 Stella981
2年前
Noark入门之协议映射
0x00消息控制器消息控制器,主要作用就是为每个模块提供消息处理的入口.这里的消息不仅仅是协议,还有内部指令,事件等等逻辑入口,这也是为了响应线程模型作出的一种支撑,只要入口在此消息控制器内,那必然走期望的线程调度。@Controller用于标识一个类为当前模块的消息控制器入口.@Controller(threadGroup