TabLayout是在APICloud现有窗口系统基础上升级而来的高级窗口组件,符合Material Design规范,可通过简单的配置为窗口实现原生的导航栏和TabBar,它将帮助您节省30%以上的重复编码工作量,同时为APP节省50%以上的系统资源开销,带来APP页面打开速度、应用性能上的整体提升,助您更快速的开发精美APP。

使用tabLayout主要优点

1、减少代码,提升开发效率
使用tabLayout只需要简单配置参数即可实现首页tabBar+frameGroup的整体布局,不用在window页面中书写header、footer标签和css样式来实现导航栏、标签栏,同时也不用考虑适配状态栏和虚拟home键。因此可以将更多时间花在具体业务的实现上面,从而提高开发效率。

2、加快打开页面速度,提升应用性能
使用tabLayout来实现导航栏时,由于导航栏是原生实现的,那么只需要打开一个window页面来实现内容页,相较于之前window+frame的结构,减少了一个webView的开销,因此大大提高了页面打开速度,并且减少了应用的内存占用。

tabLayout相关的方法请参考API文档,下面介绍tabLayout的基本使用:

 

◆◆实现导航栏navigationBar效果◆◆

tabLayout封装了原生的导航栏,可以方便地实现头部效果,导航栏会自动适配屏幕状态栏和沉浸式。

实现的代码只需要简单的几行:

function openNavWin(){
    var param = {
        name: 'nav',
        url: './main_content.html',
        bgColor: '#fff',
        title: 'navigationBar',
        navigationBar: {
            rightButtons: [{
                iconPath: "widget://image/more.png"
            }]
        }
    }
    api.openTabLayout(param);
}

对于导航栏上面按钮的点击事件,则可以在打开的页面中通过监听事件进行处理:

function apiready(){
    api.addEventListener({
        name: 'navbackbtn'
    }, function(ret, err) {
        alert('点击了返回按钮');
        api.closeWin();
    });

api.addEventListener({
        name: 'navitembtn'
    }, function(ret, err) {
        if (ret.type == 'right') {
            alert('点击了右边按钮');
        }
    });
}

◆◆实现tabBar效果◆◆

tabLayout将tabBar控件和frameGroup结合到了一起,tabLayout会自动管理tabBar项和对应的页面,同时tabBar会自动适配底部虚拟home键。

实现的代码如下:

function openNavTabWin(){
    var param = {
        name: 'nav-tab',
        title:'nav-tab',
        bgColor:'#fff',
        slidBackEnabled: false,
        navigationBar: {
            hideBackButton: true
        },
        tabBar: {
            animated: true,
            list: [
                {
                    text: "微信",
                    iconPath: "widget://image/nav_tab_1.png",
                    selectedIconPath: "widget://image/nav_tab_1_on.png"
                }, {
                    text: "通讯录",
                    iconPath: "widget://image/nav_tab_2.png",
                    selectedIconPath: "widget://image/nav_tab_2_on.png"
                }, {
                    text: "发现",
                    iconPath: "widget://image/nav_tab_3.png",
                    selectedIconPath: "widget://image/nav_tab_3_on.png"
                }, {
                    text: "我",
                    iconPath: "widget://image/nav_tab_4.png",
                    selectedIconPath: "widget://image/nav_tab_4_on.png"
                }
            ],
            frames: [
                {
                    title: "微信",
                    name: "tab_frm_1",
                    url: "widget://html/tab_content_1.html"
                }, {
                    title: "通讯录",
                    name: "tab_frm_2",
                    url: "widget://html/tab_content_2.html"
                }, {
                    title: "发现",
                    name: "tab_frm_3",
                    url: "widget://html/tab_content_3.html"
                }, {
                    title: "我",
                    name: "tab_frm_4",
                    url: "widget://html/tab_content_4.html"
                }
            ]
        }
    }
    api.openTabLayout(param);
}

如果需要在点击tabBar项后做其它的处理,可以监听tabitembtn事件进行处理,监听点击事件后tabBar将不会自动切换页面,需要调用setTabBarAttr方法进行切换。

function apiready(){
    api.addEventListener({
        name:'tabitembtn'
    }, function(ret) {
        console.log('点击了第'+(ret.index+1)+'项');
        api.setTabBarAttr({
            index: ret.index
        });
    });
}

打开tabBar后,可以为tabBar上面的各项设置角标,如:

function setTabBarItemDot(){
    api.setTabBarItemAttr({
        index: 2,
        badge: {
            text: '',
            radius: 5,
            x: 8
        }
    });
}

重磅推出TabLayout高级窗口组件的更多相关文章

  1. OSS重磅推出OSS Select——使用SQL选取文件的内容

    对象存储OSS(Object Storage Service)具有海量.可靠.安全.高性能.低成本的特点.OSS提供标准.低频.归档类型,覆盖多种数据从热到冷的存储需求,单个文件的大小从1字节到48. ...

  2. 个推一键认证SDK重磅推出,打造秒级登录体验,让用户一“键”倾心

    移动互联网时代,用户注意力的持续时间越来越短,他们追求便捷与高效.从账号密码登录.短信验证,到第三方登录甚至人脸识别登录,APP的注册/登录方式在逐步变化,开发者希望在这重要的交互端口提升用户的体验, ...

  3. 阿里云重磅推出物联网设备身份认证Link ID²

     2018年12月19日,阿里云宣布推出新版物联网设备身份认证Link ID²及物联网安全运营中心Link SOC,护航万物智联.   随着越来越多的设备连接到网络中,随之而来的安全问题越来越突出. ...

  4. 腾讯云Redis混合存储版重磅推出,万字长文助你破解缓存难题!

    导语 | 缓存+存储的系统架构是目前常见的系统架构,缓存层负责加速访问,存储层负责存储数据.这样的架构需要业务层或者是中间件去实现缓存和存储的双写.冷热数据的交换,同时还面临着缓存失效.缓存刷脏.数据 ...

  5. anyRTC 重磅推出在线实时 K 歌解决方案

    在线音乐领域一直是各大资本巨头投资的热点,从抢占版权到现在的"云上之争", 主流平台的战火从版权资源转向创新领域扩延.而如今,在线K歌正在成为抢占"云音乐"市场 ...

  6. Houdini FX 14 重磅推出!(附下载方式)

    把之前发布在新浪的博客搬过来了,新浪广告太多,影响阅读和观感,博客园很清净~ SideFX于2015年1月在官网发布Houdini FX 14,喜爱尝鲜.充满好奇心的我迫不及待的装上Apprentic ...

  7. 重磅推出:AutoProject Studio 自动化项目生成器

    AutoProject Studio 自动化项目生成器 核心架构图 AutoProject Studio 自动化项目生成器是一款基于C#.Net Framework 4.0为平台自主研发.专为软件设计 ...

  8. 阿里云重磅推出物联网安全运营中心Link SOC

    阿里云IoT自主研发了新一代物联网安全平台Link Security,面向IoT设备全生命周期构建了一整套全链路多层次的安全防御体系,IoT物联网平台的业务在不同层面可以按需集成安全能力. 1.首先在 ...

  9. 阿里云 EMAS HTTPDNS 联合函数计算重磅推出 SDNS 服务,三大能力获得突破

    1. 什么是 HTTPDNS ? 传统的 DNS(Domain Name System)使开发者常面临着域名劫持.调度不精准的问题. HTTPDNS 使用 HTTP 协议替换常用的 UDP 协议,完成 ...

随机推荐

  1. Win10 iot 配置防火墙限制应用部署

    最近在玩树莓派接大触摸屏 发现一个问题,vs 在 iot 上部署应用,使用的是 Universal (Unencrypted Protocol) https://docs.microsoft.com/ ...

  2. 记录一些 APM 仓储

      记录地址,慢慢研究...   https://github.com/openzipkin/zipkin   https://github.com/apache/incubator-skywalki ...

  3. 小程序-canvas在IOS手机层级最高无法展示问题

    要求的效果: 正面: 背面: 在开发者工具 利用css 和定位实现了一个版本 .topBox.on { transform:rotateY(180deg); } .topBox { position: ...

  4. UOJ#435. 【集训队作业2018】Simple Tree 树链剖分,分块

    原文链接www.cnblogs.com/zhouzhendong/p/UOJ435.html 前言 分块题果然是我这种蒟蒻写不动的.由于种种原因,我写代码的时候打错了很多东西,最致命的是数组开小了.* ...

  5. 2018-2019-2 20165235《网络对抗技术》Exp2 后门原理与实践

    2018-2019-2 20165235<网络对抗技术>Exp2 后门原理与实践 实验内容 1.使用netcat获取主机操作Shell,cron启动 2.使用socat获取主机操作Shel ...

  6. twig模板的进一步学习以及在symfony当中的使用

    首先,twig可以理解为用于输出html代码的,虽然用PHP等其他语言也可以输出,但是twig更为简洁高效,同时twig模板被编译成原生的php类缓存起来,所以才会这么快, 其实twig跟php类差不 ...

  7. php 缓存 加速缓存

    PHP四大加速缓存器opcache,apc,xcache,eAccelerator eAccelerator,xcache,opcache,apc(偏数据库缓存,分系统和用户缓存)是PHP缓存扩展, ...

  8. 南京邮电大学//bugkuCTF部分writeup

    WEB 1.签到题 nctf{flag_admiaanaaaaaaaaaaa} 右键查看源代码或按f12即可. 2.这题不是web nctf{photo_can_also_hid3_msg} 下载图片 ...

  9. 安装docker以及问题解决办法

    1.使用官方推荐的方式安装 yum-utilsyum install -y yum-utils2.使用如下的命令设置稳定版的 repositoryyum-config-manager \    --a ...

  10. 硬核机器学习干货,手把手教你写KNN!

    机器学习相关概念 人工智能.机器学习和深度学习的关系 在探讨算法之前,我们先来谈一谈什么是机器学习.相信大家都听说过AlphaGo:2016年3月,AlphaGo与围棋世界冠军李世石进行围棋人机大战, ...