amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse
amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse
一、总结
注意点:
1、data-am-collapse:这个东西就是展开折叠事件
2、am-collapse(包括其下属):这个控制折叠样式
1、折叠面板:结合 Panel 组件实现手风琴效果。需结合以下辅助 class 使用:
- 要隐藏的内容添加
.am-collapse; - 默认显示的内容添加
.am-collapse.am-in;
添加以上 class 以后,通过 Data API 来调用:
<h4 data-am-collapse="{parent: '#accordion', target: '#do-not-say-1'}"></h4>
其中:
parent为容器 IDtarget为要伸缩的容器 ID
如果触发元素为 <a> 元素,可以把 target 设置在 href 属性里。
<a data-am-collapse="{parent: '#accordion'}" href="#do-not-say-1">
...
</a>
<div class="am-panel-group" id="accordion">
<div class="am-panel am-panel-default">
<div class="am-panel-hd">
<h4 class="am-panel-title" data-am-collapse="{parent: '#accordion', target: '#do-not-say-1'}">
...
</h4>
</div>
<div id="do-not-say-1" class="am-panel-collapse am-collapse am-in">
<div class="am-panel-bd">
...
</div>
</div>
</div>
2、折叠菜单:使用时注意目标元素外面应该有一个容器,以便动画执行时计算高度。
<button class="am-btn am-btn-primary" data-am-collapse="{target: '#collapse-nav'}">Menu <i class="am-icon-bars"></i></button>
<nav>
<ul id="collapse-nav" class="am-nav am-collapse">
<li><a href="">开始使用</a></li>
<li><a href="">CSS 介绍</a></li>
<li class="am-active"><a href="">JS 介绍</a></li>
<li><a href="">功能定制</a></li>
</ul>
</nav>
3、折叠列表:注意 <li> 标签上需要添加 am-panel class。
4、通过data API设置折叠:在元素上添加 data-am-collapse 并设置 target 的值为折叠元素 ID:
<button data-am-collapse="{target: '#my-collapse'}"></button>
5、通过js调用折叠:$('#myCollapse').collapse()
$().collapse(options)- 绑定元素展开/折叠操作
$('#myCollapse').collapse({
toggle: false
})
$().collapse('toggle')- 切换面板状态$().collapse('open')- 展开面板$().collapse('close')- 关闭面板
6、自定义事件:
$('#collapse-nav').on('open.collapse.amui', function() {
console.log('折叠菜单打开了!');
}).on('close.collapse.amui', function() {
console.log('折叠菜单关闭鸟!');
});
| 事件 | 描述 |
|---|---|
open.collapse.amui |
open 方法被调用时立即触发 |
opened.collapse.amui |
元素完全展开后触发 |
close.collapse.amui |
close 方法被调用后立即触发 |
closed.collapse.amui |
元素折叠完成后触发 |
二、折叠面板Collapse
Collapse
折叠效果组件,用于制作下滑菜单或手风琴效果。
使用演示
折叠面板
结合 Panel 组件实现手风琴效果。需结合以下辅助 class 使用:
- 要隐藏的内容添加
.am-collapse; - 默认显示的内容添加
.am-collapse.am-in;
添加以上 class 以后,通过 Data API 来调用:
<h4 data-am-collapse="{parent: '#accordion', target: '#do-not-say-1'}"></h4>
其中:
parent为容器 IDtarget为要伸缩的容器 ID
如果触发元素为 <a> 元素,可以把 target 设置在 href 属性里。
<a data-am-collapse="{parent: '#accordion'}" href="#do-not-say-1">
...
</a>
莫言 - 你不懂我,我不怪你 #1
我把最深沉的秘密放在那里。
你不懂我,我不怪你。
每个人都有一道伤口, 或深或浅,盖上布,以为不存在。
我把最殷红的鲜血涂在那里。
你不懂我,我不怪你。
莫言 - 你不懂我,我不怪你 #2
莫言 - 你不懂我,我不怪你 #3
<div class="am-panel-group" id="accordion">
<div class="am-panel am-panel-default">
<div class="am-panel-hd">
<h4 class="am-panel-title" data-am-collapse="{parent: '#accordion', target: '#do-not-say-1'}">
...
</h4>
</div>
<div id="do-not-say-1" class="am-panel-collapse am-collapse am-in">
<div class="am-panel-bd">
...
</div>
</div>
</div>
<div class="am-panel am-panel-default">
<div class="am-panel-hd">
<h4 class="am-panel-title" data-am-collapse="{parent: '#accordion', target: '#do-not-say-2'}">
...
</h4>
</div>
<div id="do-not-say-2" class="am-panel-collapse am-collapse">
<div class="am-panel-bd">
...
</div>
</div>
</div>
<div class="am-panel am-panel-default">
<div class="am-panel-hd">
<h4 class="am-panel-title" data-am-collapse="{parent: '#accordion', target: '#do-not-say-3'}">...</h4>
</div>
<div id="do-not-say-3" class="am-panel-collapse am-collapse">
<div class="am-panel-bd">
...
</div>
</div>
</div>
</div>
折叠菜单
使用时注意目标元素外面应该有一个容器,以便动画执行时计算高度。
<button class="am-btn am-btn-primary" data-am-collapse="{target: '#collapse-nav'}">Menu <i class="am-icon-bars"></i></button>
<nav>
<ul id="collapse-nav" class="am-nav am-collapse">
<li><a href="">开始使用</a></li>
<li><a href="">CSS 介绍</a></li>
<li class="am-active"><a href="">JS 介绍</a></li>
<li><a href="">功能定制</a></li>
</ul>
</nav>
折叠列表
感谢 @looly 提供的例子。注意 <li> 标签上需要添加 am-panel class。
<ul class="am-list admin-sidebar-list" id="collapase-nav-1">
<li class="am-panel">
<a data-am-collapse="{parent: '#collapase-nav-1'}" href="#/"><i class="am-icon-home am-margin-left-sm"></i> 首页</a>
</li>
<li class="am-panel">
<a data-am-collapse="{parent: '#collapase-nav-1', target: '#user-nav'}">
<i class="am-icon-users am-margin-left-sm"></i> 人员管理 <i class="am-icon-angle-right am-fr am-margin-right"></i>
</a>
<ul class="am-list am-collapse admin-sidebar-sub" id="user-nav">
<li><a href="#/userAdd"><i class="am-icon-user am-margin-left-sm"></i> 添加人员 </a></li>
<li><a href="#/userList/0"><i class="am-icon-user am-margin-left-sm"></i> 人员列表 </a></li>
</ul>
</li>
<li class="am-panel">
<a data-am-collapse="{parent: '#collapase-nav-1', target: '#company-nav'}">
<i class="am-icon-table am-margin-left-sm"></i> 单位(部门)管理 <i class="am-icon-angle-right am-fr am-margin-right"></i>
</a>
<ul class="am-list am-collapse admin-sidebar-sub" id="company-nav">
<li><a href="#/companyAdd"><span class="am-icon-table am-margin-left-sm"></span> 添加单位(部门) </a></li>
<li><a href="#/companyList/0"><span class="am-icon-table am-margin-left-sm"></span> 单位(部门)列表 </a></li>
</ul>
</li>
<li class="am-panel">
<a data-am-collapse="{parent: '#collapase-nav-1', target: '#role-nav'}">
<i class="am-icon-table am-margin-left-sm"></i> 角色管理 <i class="am-icon-angle-right am-fr am-margin-right"></i>
</a>
<ul class="am-list am-collapse admin-sidebar-sub" id="role-nav">
<li><a href="#/roleAdd"><span class="am-icon-table am-margin-left-sm"></span> 添加角色 </a></li>
<li><a href="#/roleList/0"><span class="am-icon-table am-margin-left-sm"></span> 角色列表 </a></li>
</ul>
</li>
</ul>
调用方式
通过 Data API
在元素上添加 data-am-collapse 并设置 target 的值为折叠元素 ID:
<button data-am-collapse="{target: '#my-collapse'}"></button>
通过 JS
使用方法:
$('#myCollapse').collapse()
方法
$().collapse(options)- 绑定元素展开/折叠操作
$('#myCollapse').collapse({
toggle: false
})
$().collapse('toggle')- 切换面板状态$().collapse('open')- 展开面板$().collapse('close')- 关闭面板
选项
| 参数 | 类型 | 默认 | 描述 |
|---|---|---|---|
parent |
选择符 | false |
如果设置了 parent 参数,且该容器下有多个可折叠的面板时,展开一个面板会关闭其它展开的面板。换言之,如果想让多个面板可以都处于展开状态,那不设置这个参数即可。 |
toggle |
布尔值 | true |
交替执行展开/关闭操作 |
自定义事件
自定义事件在折叠的元素上触发,以上面的折叠菜单为例,#collapse-nav 触发自定义事件:
$('#collapse-nav').on('open.collapse.amui', function() {
console.log('折叠菜单打开了!');
}).on('close.collapse.amui', function() {
console.log('折叠菜单关闭鸟!');
});
| 事件 | 描述 |
|---|---|
open.collapse.amui |
open 方法被调用时立即触发 |
opened.collapse.amui |
元素完全展开后触发 |
close.collapse.amui |
close 方法被调用后立即触发 |
closed.collapse.amui |
元素折叠完成后触发 |
注意事项
不要在折叠内容的容器上设置垂直的 margin/padding/border 样式。
jQuery 计算元素高度的方式有点奇葩,暂时只能通过上面的方式规避。
Issue 列表
amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse的更多相关文章
- amazeui学习笔记--js插件(UI增强)--警告框Alert
amazeui学习笔记--js插件(UI增强)--警告框Alert 一.总结 1.警告框基本样式:用am-alert声明div容器, <div class="am-alert" ...
- amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown
amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown 一.总结 1.am-dropdown(及其孩子):控制下拉列表的样式 2.data-am-dropdown(及其孩子):控 ...
- amazeui学习笔记--js插件(UI增强2)--按钮交互Button
amazeui学习笔记--js插件(UI增强2)--按钮交互Button 一.总结 1.按钮loading状态: <button type="button" class=&q ...
- amazeui学习笔记--css(常用组件12)--面板Panel
amazeui学习笔记--css(常用组件12)--面板Panel 一.总结 1.面板基本样式:默认的 .am-panel 提供基本的阴影和边距,默认边框添加 .am-panel-default,内容 ...
- amazeui学习笔记二(进阶开发1)--项目结构structure
amazeui学习笔记二(进阶开发1)--项目结构structure 一.总结 1.项目结构:是说的amazeui在github上面的项目结构,二次开发amazeui用 二.项目结构structure ...
- amazeui学习笔记三(你来我往1)--常见问题FAQs
amazeui学习笔记三(你来我往1)--常见问题FAQs 一.总结 1.DOM事件失败:记得加上初始化代码,例如 图片轮播 $('#my-slider').flexslider(); 2.jquer ...
- amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules
amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules 一.总结 1.见名知意:见那些class名字知意,见函数名知意,见文件名知意 例如(HISTORY.md Web 组件更新历史 ...
- amazeui学习笔记二(进阶开发2)--Web组件简介Web Component
amazeui学习笔记二(进阶开发2)--Web组件简介Web Component 一.总结 1.amaze ui:amaze ui是一个web 组件, 由模板(hbs).样式(LESS).交互(JS ...
- amazeui学习笔记一(开始使用3)--兼容性列表compatibility
amazeui学习笔记一(开始使用3)--兼容性列表compatibility 一.总结 1.不要用ie做前端测试,不要碰ie,尽量用google 浏览器: 按照微软官方的说法,IE 开发者工具中的浏 ...
随机推荐
- socket编程之中的一个:计算机网络基础
在開始学习网络之前先复习下计算机网络基础吧. 鲁迅说,天下文章一大抄.看你会炒不会炒,基础知识就抄抄书吧. 一 分层模型 1 为什么分层 为了简化网络设计的复杂性.通讯协议採用分层结构.各层协议之间既 ...
- 归并排序_分治算法 (白书P226)
#include<iostream> #include<cstdio> #include<algorithm> using namespace std; int a ...
- sqlserver 小计合计总计
SELECT CASE WHEN GROUPING(F1) = 1 THEN '总计'WHEN GROUPING(F1) = 0 AND GROUPING(F2) = 1 THEN F1+'合计'W ...
- #学习记录#——CSS content 属性
CSS content 属性常结合:before 和:after 这两个伪类一起使用,给指定的元素添加内容来丰富页面. 1. 添加文本内容 html: <h1>给末尾添加内容. </ ...
- jQuery简单tab按钮切换
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- OpenCV —— 写入AVI视频文件
打开视频文件,对每一帧进行极坐标变换,然后将转换生成的图像序列写入视频文件中 #include "cv.h" #include "highgui.h" int ...
- mv---移动文件或目录
mv命令用来对文件或目录重新命名,或者将文件从一个目录移到另一个目录中.source表示源文件或目录,target表示目标文件或目录.如果将一个文件移到一个已经存在的目标文件中,则目标文件的内容将被覆 ...
- mysql允许外部连接设置
错误信息: SQL Error (1130): Host ‘192.168.1.88’ is not allowed to connect to this MySQL server 说明所连接的用户帐 ...
- CSUOJ 1554 SG Value
1554: SG Value Time Limit: 5 Sec Memory Limit: 256 MBSubmit: 140 Solved: 35 Description The SG val ...
- nyist oj 1058 部分和问题 (DFS搜索)
部分和问题 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描写叙述 给定整数a1.a2........an.推断能否够从中选出若干数,使它们的和恰好为K. 输入 首先,n和k ...