Agularjs妙用双向数据绑定实现手风琴效果


Posted in Javascript onMay 26, 2017

最近在工作总遇到需要实现类似手风琴效果的需求,如下图所示:

Agularjs妙用双向数据绑定实现手风琴效果 

因为汇总(上半部分)和明细(下面的浅色部分)在不同的情况下显示的字段数量是不一样的,而且还有编辑和展示的状态切换,所以需要自己实现手风琴效果。

初步的想法是用css的transform做动效,点击详情按钮(或中间部分的下拉图标)时请求详情数据,然后将详情部分的height设置成指定高度,再次点击详情按钮(或中间部分的下拉图标),详情部分被收起。

但是这样的问题在于我们如何精确的控制到底该显示哪一行汇总数据的明细和关闭其他行的明细,经过一番思考我决定利用一下双向数据绑定来帮我完成这个事情。具体代码如下:

js:

$scope.toogleShowDtl = function (item, e) {
       //阻止事件冒泡
       e.stopPropagation();
      for (var i = 0; i < $scope.OrderHdr.length; i++) {
        if ($scope.OrderHdr[i].Bill_Hdr_Id != item.Bill_Hdr_Id) {
          $scope.OrderHdr[i].mxShow = false;
          $scope.OrderHdr[i].iconChange = "glyphicon glyphicon-menu-down";
        }
      }
      switch (item.mxShow) {
        case undefined:
          item.mxShow = true;
          item.iconChange = "glyphicon glyphicon-menu-up";
          break;
        case true:
          item.mxShow = false;
          item.iconChange = "glyphicon glyphicon-menu-down";
          break;
        case false:
          item.mxShow = true;
          item.iconChange = "glyphicon glyphicon-menu-up";
          break;
        default:
          item.mxShow = false;
          item.iconChange = "glyphicon glyphicon-menu-down";
          break;
      }
    }

html:

<div class="col-sm-12 detial_box" ng-click="selectHdr($index)" ng-class="{ dtl_select : $index == selectedIndex }">
  <div class="col-sm-3" style="margin-top:60px; ">
   <button class="btn btn-primary" ng-click="toogleShowDtl(o,$event)">详情</button>
  </div>
  <div class="down_img">
    <span class="{{o.iconChange}} glyphicon glyphicon-menu-down" ng-click="toogleShowDtl(o,$event)"></span>
  </div>
</div>
<div class="col-sm-12 mx_box check-element animate-show-hide" ng-show="o.mxShow">
  <!--明细内容-->
</div>

当点击事件触发的时候,当前行数据中并没有mxShow这个字段,故循环为其添加上该字段并赋值为false,当前被点击的行不能执行这个操作,否则第一次点击的时候改行的明细是不会展示的。后面的switch case语句保证了第一次点击mxShow没有值 以及mxShow值切换的问题。item.iconChange 的值是用来控制中间字体图标的切换,当明细没展示的时候图标是向下的,代表可以展开,当明细显示的时候图标向上,代表可以收起。

ng-show="o.mxShow" 根据mxShow的值来确定明细是否展示。

class="{{o.iconChange}} glyphicon glyphicon-menu-down"

用来切换图标

最终效果图如下(不知道怎么上传动图o(?□?)o)

Agularjs妙用双向数据绑定实现手风琴效果

以上所述是小编给大家介绍的Agularjs妙用双向数据绑定实现手风琴效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
让iframe自适应高度(支持XHTML,支持FF)
Jul 24 Javascript
XHTML下,JS浮动代码失效的问题
Nov 12 Javascript
很好用的js日历算法详细代码
Mar 07 Javascript
jQuery如何实现点击页面获得当前点击元素的id或其他信息
Jan 09 Javascript
JavaScript返回0-1之间随机数的方法
Apr 06 Javascript
JavaScript中DOM详解
Apr 13 Javascript
数据分析软件之FineReport教程:[5]参数界面JS(全)
Aug 13 Javascript
javascript显示倒计时控制按钮的简单实现
Jun 07 Javascript
JavaScript设计模式之单体模式全面解析
Sep 09 Javascript
setTimeout与setInterval的区别浅析
Mar 23 Javascript
js实现网页版贪吃蛇游戏
Feb 22 Javascript
element-plus一个vue3.xUI框架(element-ui的3.x 版初体验)
Dec 02 Vue.js
详解vue-cli快速构建项目以及引入bootstrap、jq
May 26 #Javascript
基于layer.js实现收货地址弹框选择然后返回相应的地址信息
May 26 #Javascript
jQuery导航条固定定位效果实例代码
May 26 #jQuery
mongoose中利用populate处理嵌套的方法
May 26 #Javascript
Angularjs修改密码的实例代码
May 26 #Javascript
详解vue.js的devtools安装
May 26 #Javascript
详解Vue.js基于$.ajax获取数据并与组件的data绑定
May 26 #Javascript
You might like
php递归列出所有文件和目录的代码
2008/09/10 PHP
Cannot modify header information错误解决方法
2008/10/08 PHP
php图像处理函数大全(推荐收藏)
2013/07/11 PHP
PHP与javascript实现变量交互的示例代码
2013/07/23 PHP
PHP多态代码实例
2015/06/26 PHP
PHP实现的简单分页类及用法示例
2016/05/06 PHP
PHP基于rabbitmq操作类的生产者和消费者功能示例
2018/06/16 PHP
Nigma vs AM BO3 第一场2.13
2021/03/10 DOTA
基于JQuery的访问WebService的代码(可访问Java[Xfire])
2010/11/19 Javascript
javascript中length属性的探索
2011/07/31 Javascript
js+xml生成级联下拉框代码
2012/07/24 Javascript
jquery动态添加删除一行数据示例
2014/06/12 Javascript
JQuery对表单元素的基本操作使用总结
2014/07/18 Javascript
js控制再次点击按钮之间的间隔时间可防止重复提交
2014/08/01 Javascript
jQuery+formdata实现上传进度特效遇到的问题
2016/02/24 Javascript
快速使用Bootstrap搭建传送带
2016/05/06 Javascript
jQuery获取浏览器类型和版本号的方法
2016/07/05 Javascript
nodejs中实现用户注册路由功能
2019/05/20 NodeJs
浅谈layer弹出层按钮颜色修改方法
2019/09/11 Javascript
Postman环境变量全局变量使用方法详解
2020/08/13 Javascript
python进阶教程之循环相关函数range、enumerate、zip
2014/08/30 Python
python检测远程端口是否打开的方法
2015/03/14 Python
浅析Python中signal包的使用
2015/11/13 Python
Python机器学习之SVM支持向量机
2017/12/27 Python
python如何在循环引用中管理内存
2018/03/20 Python
使用11行Python代码盗取了室友的U盘内容
2018/10/23 Python
pygame实现俄罗斯方块游戏(AI篇1)
2019/10/29 Python
python输出数学符号实例
2020/05/11 Python
墨尔本最受欢迎的复古风格品牌:Princess Highway
2018/12/21 全球购物
施华洛世奇匈牙利官网:SWAROVSKI匈牙利
2019/07/06 全球购物
澳大利亚最便宜的网上药房:Chemist Warehouse
2020/01/30 全球购物
幼儿运动会邀请函
2014/01/17 职场文书
青年文明号服务承诺
2014/03/31 职场文书
护理工作个人总结
2015/03/03 职场文书
2015年助残日活动总结
2015/03/27 职场文书
浅谈Python类的单继承相关知识
2021/05/12 Python