全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

xmlplus组件设计系列之列表(4)

列表组件是极其常用的一类组件,是许多视图组件系统的必须包含的。列表可以做的很简单,只显示简洁的内容。列表也可以做的很复杂,用于展示非常丰富的内容。

组成元素

列表离不开列表项以及包含列表项的容器。下面是最简单的列表组件,它包含一个列表项组件 Item 以及一个列表项容器组件 List。

Item: {
 xml: "<li id='item'/>"
},
List: {
 xml: "<ul id='list'/>"
}

此列表组件尽管简单,但所构建的框架为我们的继续扩展奠定了基础。

动态操作

如上定义的列表组件的最基本的用法如下所示。这种用法与原生列表标签的用法没什么区别。我们将进行做进一步的改造。

Example: {
 xml: "<List id='example'>\
  <Item>Item 1</Item>\
  <Item>Item 2</Item>\
  </List>"
}

列表组件普遍包含添加、删除以及修改这三种操作。为简单起见,不妨先来实现这些操作。由于我们定义的列表项足够的简单,所以这里不再定义新的操作接口,而直接使用系统接口。

Example: {
 xml: "<div id='example'>\
  <List id='list'/>\
  <button id='append'>append</button>\
  <button id='remove'>remove</button>\
  <button id='modify'>modify</button>\
  </div>",
 fun: function (sys, items, opts) {
 sys.append.on("click", function() {
  sys.list.append("Item").text("Item 1");
 });
 sys.remove.on("click", function() {
  sys.list.first() && sys.list.first().remove();
 });
 sys.modify.on("click", function() {
  sys.list.first() && sys.list.first().text("Item 2");
 });
 }
}

该示例使用列表的系统函数 append 来追加列表项,并使用列表项的系统函数 remove 来移除列表项,同时还使用列表项的系统函数 text 来修改列表项的数据。

由于上面的列表项所包含的是简单的文本数据,所以上面示例使用 text 函数来操作数据是适合的。现在给出一个包含较复杂数据的列表项,该列表项额外定义了数据操作接口。

Item: {
 xml: "<li id='item'>\
  <span id='color'>red</span>
  <span id='shape'>square</span>
  </li>",
 fun: function (sys, items, opts) {
 function getValue() {
  return {color: sys.color.text(), shape: sys.shape.text()};
 }
 function setValue(obj) {
  sys.color.text(obj.color);
  sys.shape.text(obj.shape);
 }
 return Object.defineProperty({}, "data", { get: getValue, set: setValue});
 }
}

下面是包含新列表项的列表操作的一个示例。其中对于组件的追加与删除还可以使用系统提供的函数,但对于数据的获取与修正就只能使用新定义的接口了。

Example: {
 xml: "<div id='example'>\
  <List id='list'/>\
  <button id='append'>append</button>\
  <button id='remove'>remove</button>\
  <button id='modify'>modify</button>\
  </List>",
 fun: function (sys, items, opts) {
 sys.append.on("click", function() {
  sys.list.append("Item");
 });
 sys.remove.on("click", function() {
  sys.list.first() && sys.list.first().remove();
 });
 sys.modify.on("click", function() {
  sys.list.first() && items.list.first().data = {color: "blue", shape: "rectangle"};
 });
 }
}

对列表项接口的定义没有什么特别的要求,比如一定要使用 setValue 和 getValue 之类。这取决于具体的场景,根据需要灵活选择。

使用第三方列表组件

如今市面上已经有了种种功能丰富的列表组件,我们可以通过二次封装为我所用。这里结合 JQuery 带有排序功能的列表组件来说明如何操作。

首先对列表项进行封装,因为这个列表项实在太长了。注意要引出数据操作接口。

Item: {
 xml: "<li class='ui-state-default'><span class='ui-icon ui-icon-arrowthick-2-n-s'/><span id='data'/></li>",
 map: { appendTo: "data" },
 fun: function (sys, items, opts) {
 return { data: sys.data.text };
 }
}

其次,定义下列表项的容器组件,该容器组件主要封装 JQuery 的列表初始化代码,这里定义了该列表为可排序但不可选。

List: {
 css: "#list{ list-style-type: none; margin: 0; padding: 0; width: 60%; }\
  #list li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }\
  #list li span { position: absolute; margin-left: -1.3em; }",
 xml: "<ul id='list'/>",
 fun: function (sys, items, opts) {
 var elem = this.elem();
 $(elem).sortable();
 $(elem).disableSelection();
 }
}

最后我们来看看如何使用该列表组件。该示例的使用与前面没什么不同,但功能与表现可就大不一样了。

Example: {
 xml: "<List id='example'>\
  <Item>Item 1</Item>\
  <Item>Item 2</Item>\
  <Item>Item 3</Item>\
  </List>"
}

优化

如果你的列表有频繁更新数据的要求,必然会产生频繁的列表项的增删操作,这可能会带来不好的应用体验。下面给出一个可行的优化方案,该方案在官方文档的 优化 章节中已出现过。

List: {
 xml: "<ul id='list'/>",
 fun: function (sys, items, opts) {
 function setValue(array) {
  var list = sys.list.children();
  for ( var i = 0; i < array.length; i++ )
  (list[i] || sys.list.append("Item")).show().text(array[i]);
  for ( var k = i; k < list.length; k++ )
  list[k].hide();
 }
 return Object.defineProperty({}, "value", { set: setValue });
 }
}

对于复杂的列表项,重新创建的代价是巨大的。所以此优化方案尽可能地复用已有的列表项,非必要时只刷新数据而不是删除并重建新的列表项,只有当已有的列表项不够用时才创建新的列表项。

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# xmlplus  # 组件  # 列表  # xmlplus组件设计系列之网格(DataGrid)(10)  # xmlplus组件设计系列之文本框(TextBox)(3)  # xmlplus组件设计系列之选项卡(Tabbar)(5)  # xmlplus组件设计系列之下拉刷新(PullRefresh)(6)  # xmlplus组件设计系列之路由(ViewStack)(7)  # xmlplus组件设计系列之分隔框(DividedBox)(8)  # xmlplus组件设计系列之树(Tree)(9)  # xmlplus组件设计系列之按钮(2)  # xmlplus组件设计系列之图标(ICON)(1)  # 的是  # 没什么  # 文档  # 还可以  # 为我所用  # 没有什么  # 我们可以  # 很简单  # 你对  # 来看看  # 只显示  # 可选  # 可供  # 所示  # 可就  # 实在太  # 第三方  # 但不  # 已经有了  # 最简单 


相关文章: 电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  购物网站制作公司有哪些,哪个购物网站比较好?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  网站app免费制作软件,能免费看各大网站视频的手机app?  如何快速搭建高效WAP手机网站吸引移动用户?  建站之星如何实现五合一智能建站与营销推广?  如何打造高效商业网站?建站目的决定转化率  常州自助建站工具推荐:低成本搭建与模板选择技巧  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  如何快速查询网站的真实建站时间?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  建站之星备案是否影响网站上线时间?  建站之星官网登录失败?如何快速解决?  宝塔Windows建站如何避免显示默认IIS页面?  成都网站制作报价公司,成都工业用气开户费用?  如何快速生成橙子建站落地页链接?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  如何在Windows虚拟主机上快速搭建网站?  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  建站之星代理费用多少?最新价格详情介绍  建站之星如何实现PC+手机+微信网站五合一建站?  *服务器网站为何频现安全漏洞?  中山网站制作网页,中山新生登记系统登记流程?  如何快速搭建个人网站并优化SEO?  历史网站制作软件,华为如何找回被删除的网站?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  如何在阿里云通过域名搭建网站?  电商网站制作价格怎么算,网上拍卖流程以及规则?  测试制作网站有哪些,测试性取向的权威测试或者网站?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  ,购物网站怎么盈利呢?  python的本地网站制作,如何创建本地站点?  网站制作难吗安全吗,做一个网站需要多久时间?  网页设计网站制作软件,microsoft office哪个可以创建网页?  建站之星后台密码如何安全设置与找回?  建站主机SSH密钥生成步骤及常见问题解答?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  动图在线制作网站有哪些,滑动动图图集怎么做?  网站网页制作专业公司,怎样制作自己的网页?  青岛网站建设如何选择本地服务器?  建站之星上传入口如何快速找到?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  高性能网站服务器配置指南:安全稳定与高效建站核心方案  XML的“混合内容”是什么 怎么用DTD或XSD定义  如何快速生成凡客建站的专业级图册?  活动邀请函制作网站有哪些,活动邀请函文案?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。