1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > JavaScript框架(xmlplus)组件的介绍(五)选项卡(Tabbar)

JavaScript框架(xmlplus)组件的介绍(五)选项卡(Tabbar)

时间:2020-06-18 14:45:42

相关推荐

JavaScript框架(xmlplus)组件的介绍(五)选项卡(Tabbar)

web前端|js教程

xmlplus,选项卡

web前端-js教程

xmlplus 是一个JavaScript框架,用于快速开发前后端项目。这篇文章主要介绍了xmlplus组件设计系列之选项卡,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

自媒体广告平台源码,怎么用vscode写汇编,低配ubuntu,群晖 安装tomcat,厕所地板爬虫,备忘录 php,滑县seo优化哪家的正规,c语言开源网站,dede 调用模板lzw

这一章将设计一个选项卡组件,选项卡组件在手持设备上用的比较多,下面是一个示意图:

论坛静态模板源码,ubuntu引导分区多大,河里多退黑色爬虫,php Referer:,seo常见行业lzw

一键删除空间说说源码,Ubuntu没有留efi,python爬虫运行命令,hbuider php,新泰seo营销lzw

选项卡组成

在具体实现之前,想像一下目标组件是如何使用的,对于设计会有莫大的帮助。通过观察,可以将选项卡组件分为容器部分和子项部分,正如下面的 XML 结构所展示的。

现在我们把目光切换到选项卡组件的子项部分,来看看子项部分是如何分解的。通过示意图,你可以发现子项部分可以分解为子项容器以及包含一个图标和一个文本的子级部分。

首页

所以,现在我们的目标已经很明确了,主要设计三个组件:图标组件 Icon、选项卡组件的子项 TabItem 以及选项卡组件的容器 Tabbar。

结构图

由于该组件比较简单,所以可以将三种子组件放置在同一层级。但请注意,我们还有四个图标组件,可以创建一个子级用于容纳它们。下面给出我们的组件结构图:

Tabbar/

├── Tabbar

├── TabItem

└── Icon/

├── About

├── Home

├── Logs

└── Setting

图标的实现

我们从最简单的开始,先看四个图标组件,图标组件主要通过封装 SVG 文本来实现,由于图标文本较长,所以这里仅截取每个图标文本的一段。

About: { xml: ` `},Home: { xml: ` `},Logs: { xml: ` `},Setting: { xml: ` `}

请注意,这些图标位于虚拟目录 /icon 之下,也就是你要像下面这样导入:

xmlplus("ui", function (xp, $_, t) { $_().imports({Tabbar: {... }, TabItem: {...}}); $_("icon").imports({--这里包含了四个图标组件--});});

下面来实现图标组件 Icon,这里的图标组件与上面是不同的,它会根据输入的图标类型实例化不同的图标。这样设计可以复用部分相同的代码,避免冗余。

Icon: { css: "#icon { width: 1.5em; height: 1.5em; display: inline-block; }", opt: { icon: "about" }, xml: ``, fun: function (sys, items, opts) { sys.icon.replace("icon/" + opts.icon).addClass("#icon"); }}

该组件的函数项根据输入的图标类型创建图标组件并替换已有的 span 元素对象。注意,替换完后需要重新添加样式。

子项的实现

按从内到外的原则,接下来实现选项卡组件的子项 TabItem。对于此组件,需要在组件的映射项中做一次异名的属性映射,把 id 属性值映射给内部的图标组件的 icon 属性。

TabItem: { css: "这里是样式项部分,为便于组件整体展示,略去...", map: {"attrs": { icon: "id->icon" } }, xml: ` 首页`, fun: function (sys, items, opts) { sys.label.text(opts.label); function select() {sys.tabitem.addClass("#primary"); } function unselect() {sys.tabitem.removeClass("#primary"); } return { select: select, unselect: unselect }; }}

此组件提供了用于选项切换时选中与非选中状态之间切换的接口。以供选项卡容器使用。

选项卡的实现

最后来看下选项卡组件 Tabbar 的实现。该组件侦听了用户触击选项卡时的事件,在侦听器里主要做两件事:一是维持选项卡状态的切换;另一是派发一选项卡切换时的状态改变事件。

Tabbar: { css: "这里是样式项部分,为便于组件整体展示,略去...", xml: `

`, fun: function (sys, items, opts) { var sel = this.first(); this.on("touchend", "./*[@id]", function (e) {sel.value().unselect();(sel = this).value().select();this.trigger("switch", this.toString()); }); if (sel) sel.value().select(); }}

至此,一个选项卡组件算是完成了,下面来看下具体的一个应用:

xmlplus("example", function (xp, $_, t) { $_().imports({ Index: { xml: `

`, fun: function (sys, items, opts) {this.on("switch", (e, target) => console.log(target)); } }, Footer: { xml: ` ` } });});

在组件 Index 中,你可以侦听来自选项卡的切换事件来做相应的操作。比如结合后续我们介绍的视图栈组件做页面之间的切换操作。

本系列文章基于 xmlplus 框架。如果你对 xmlplus 没有多少了解,可以访问 。这里有详尽的入门文档可供参考。

【相关推荐】

1. 免费js在线视频教学

2. JavaScript中文参考手册

3. 独孤九贱(3)-JavaScript视频教学

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。