当前位置: 首页 > 编程日记 > 正文

javascript通过json数据按格式生成一个按字母分类排序的分类信息表

效果图如下

1.json数据格式

var _people=[{name:'朱瑞',url:'aaaaaa',nick:'zhu'},{name:'刘桂清',url:'aaaaa',nick:'liu'}];
这里按姓氏排序借用了nick,不用nick的话,需要加载一个汉字拼音对照数组,判断匹配

2.javascript代码

  1 (function ($){
  2     function SortByGroup(arr,option){
  3         this.option=option;
  4         this.arr=arr||[];
  5     }
  6     SortByGroup.prototype={
  7         init:function(){
  8             this.sort();
  9             return this.sortByGroup(this.group());
 10         },
 11         sort:function(){
 12             var tag=this.option.tag;
 13             this.arr=this.arr.sort( function compareFunction(param1,param2){
 14                  return param1[tag].localeCompare(param2[tag]);
 15              });
 16         },
 17         group:function(){
 18             var arr=[],count=0,def;
 19             var charTemp="-1",temp;
 20             for(var i in this.arr){
 21                 temp=this.arr[i];
 22                 if(charTemp!==temp[this.option.tag].charAt(0)){
 23                     var one=[];
 24                     one.push(temp);
 25                     arr[count]=one;
 26                     charTemp=temp[this.option.tag].charAt(0);
 27                     count++;
 28                 }else{
 29                     arr[count-1].push(temp);
 30                 }
 31             }
 32             return arr;
 33         },
 34         sortByGroup:function(arr){
 35             var temp;
 36             for(var i =0;i<arr.length;i++){
 37                 temp=arr[i];
 38                 temp.sort(function compareFunction(param1,param2){
 39                     return param1['name'].localeCompare(param2['name']);
 40                 });
 41             };
 42             return arr;
 43         }
 44     };
 45     function RenderPage(arr){
 46         this.model=arr;
 47         this.index=[];
 48         this.lastIndex="-1";
 49     }
 50     RenderPage.prototype={
 51         init:function(){
 52             
 53             $("#container").html(this.render());
 54             $("#index").html(this.renderIndex());
 55             this.bindEvent();
 56         },
 57         getIndex:function(nick){
 58             this.index.push(nick.charAt(0).toUpperCase());
 59 
 60         },
 61         bindEvent:function(){
 62             $("#index a").mouseover(function(){
 63 
 64                 var tag=$(this).attr("data");
 65                 if(tag!="more"){
 66                     $("#container .block").css("display","none");
 67                     $("#container ."+tag).css("display","block");
 68                 }else{
 69                     $("#container .block").css("display","block");
 70                 }
 71                 
 72             });
 73 
 74 
 75         },
 76         render:function(){
 77             var str="";
 78             for(var i=0;i<this.model.length;i++){
 79                 str+=this.renderGroup(this.model[i],i);
 80             }
 81 
 82             return str;
 83         },
 84         renderGroup:function(arr,num){
 85             var str="",temp;
 86             
 87             for(var i=0;i<arr.length;i++){
 88                 if(i==0){
 89                     this.getIndex(arr[i].nick);
 90                     temp=this.index[num];
 91 
 92                     str='<div class="block '+temp+'"><h3>'+temp+'</h3><ul>'
 93                 }
 94                 str+=this.renderOne(arr[i]);
 95             }
 96             if(str) str+="<div class='clear'></div></ul></div>";
 97             return str;
 98         },
 99         renderOne:function(one){
100             return '<li><a href="'+one.url+'" target="_blank">'+one.name+'</a></li>';
101         },
102         renderIndex:function(){
103             var str="";
104 
105             for(var i =0;i<this.index.length;i++){
106                 str=str+"<a data='"+this.index[i]+"'>"+this.index[i]+"</a>";
107             }
108             str+="<a data='more'>MORE</a>";
109             return str;
110         }
111     };
112     new RenderPage(new SortByGroup(_people,{tag:'nick'}).init()).init();
113 })(jQuery);

3.html页面结构

<!-- 区域32(按字母检索)Start -->
<div id="pd32" class="w1020"><div class="title4"><span>按字母搜索</span><p id="index" class="index"></p><div class="clear"></div></div><!--block--><div id="container" class="container"></div><!--block-->
</div>
<!-- 区域32(按字母检索)End -->

4.css样式

#pd32 .title4{border-bottom:1px solid #cecece;padding-bottom:10px;
}#pd32 .title4 p{float:right;
}#pd32 .title4 p a{background:none;padding:0px;float:none;color:#d26213;font-family:"Microsoft Yahei","����";font-size:22px;cursor:pointer;margin-left:12px;
}#pd32 .block{margin-top:15px;
}#pd32 .block h3{border-bottom:1px dotted #cfcfcf;font-size:30px;font-family:"Arial","Microsoft Yahei","����";color:#000;height:40px;line-height:40px;padding-bottom:5px;margin-bottom:8px;
}#pd32 .block ul{zoom:1;
}#pd32 .block li{float:left;display:inline;width:102px;height:30px;line-height:30px;overflow:hidden;font-size:16px;font-family:"Microsoft Yahei","����";
}#pd32 .block li a{color:#000;
}

注:另外需要引入jquery,这里的json数据是在开始就引入的。后面的js代码直接引用了people这个变量(比较low)。

转载于:https://www.cnblogs.com/licifer/p/4603056.html

相关文章:

(1)学习数组,集合,IEnumerable接口,引申学习迭代器

发展:数组-->集合-->泛型 (1)数组 1. 数组数据结构是System.Array类的一个实例. 2. System.Array类的语法为 [SerializableAttribute] [ComVisibleAttribute(true)] public abstract class Array : ICloneable, IList, ICollection, IEnumerable 3. 下面看一个使用数组…

人工智能尴尬的2019:需要钱却没钱可烧了

作者 | 余洋洋编辑 | 张丽娟来源 | CV智识&#xff08;ID:CVAI2019)【导读】正需要钱的时候&#xff0c;钱却不够用了&#xff0c;人工智能领域缺钱与亟需钱的矛盾在今年集中体现了出来。2019年&#xff0c;中国人工智能领域的投融资热情大幅降低&#xff0c;交易量随之急剧下降…

WMI技术介绍和应用——WMI概述

今天&#xff0c;我要开始一系列关于微软WMI技术的介绍。通过之后若干节的介绍&#xff0c;我想WMI技术将为在windows平台上从事开发的朋友开启另外一扇窗。&#xff08;转载请指明出于breaksoftware的csdn博客&#xff09; 第一次接触WMI技术是在一年前&#xff0c;当时我接到…

综合技术 --@Autowired和@Resource

2019独角兽企业重金招聘Python工程师标准>>> 1.Autowired和Resource 的作用一样&#xff0c;都是自动注入 2.Autowired是按照byType自动注入&#xff0c;而Resource默认是按照byName自动注入。 3.Resource有两个属性比较重要&#xff0c;分别是name和type&#xff0…

CowNew开源团队新书《自己动手写开发工具》隆重上市

《自己动手写开发工具--基于Eclipse的工具开发》本书系统地介绍了SWT、Draw2D、GEF、JET等与Eclipse插件开发相关的基础知识&#xff0c;并且以实际的开发案例来演示这些知识的实战性应用&#xff0c;通过对这些实际开发案例的学习&#xff0c;读者可以非常轻松地掌握Eclipse插…

4000个“不会数学”的程序员出现大反转!居然能学AI,玩算法,搞逻辑!背后原因首次曝光...

不懂数学的程序员&#xff0c;尤其是在工作之后的一些瞬间&#xff0c;有多少次让你感受到数学的重要性&#xff1f;我们来看2个例子&#xff1a;写一行代码会用数学的程序员&#xff1a;我能分析除代码算法的时间复杂度与空间复杂度&#xff0c;不用写就知道这个算法的优缺点。…

WMI技术介绍和应用——VC开发WMI应用的基本步骤

在《WMI技术介绍和应用——WMI概述》中介绍了我们可以使用C、.net或者支持ActiveX技术的脚本语言来使用WMI。但是各种语言对WMI的控制能力是不同的&#xff0c;比如脚本语言只能用来从WMI获取数据或者接收事件通知。而C还可以编写WMI提供者和发送消息。和脚本语言相比&#xff…

WMI技术介绍和应用——使用VC编写一个半同步查询WMI服务的类

在《WMI技术介绍和应用——VC开发WMI应用的基本步骤》文中&#xff0c;我们介绍了VC使用WMI技术的基本框架。本节我将讲解封装和实现一个用于半同步查询WMI的类。&#xff08;转载请指明出于breaksoftware的csdn博客&#xff09; 我曾思考过如何编写一个比较有用的类&#xff0…

致被套基民:老基民的四点教训七点经验(ZT)

四点错误&#xff1a; 一是没有足够的耐心。比如我曾买入一只基金&#xff0c;上半年表现不好&#xff0c;在忍无可忍之下终于赎回&#xff0c;结果它在下半年股市调整时大放异彩&#xff0c;成为收益率的冠军&#xff1b; 二是只看高分红买基金&#xff0c;结果错过了几只净值…

千万用户同时在线,优酷智能档在双11“猫晚”直播如何防卡顿?

作者 | 阿里文娱高级技术专家肖文良出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09; 导读&#xff1a;本文为阿里文娱高级技术专家肖文良在【阿里文娱2019双11猫晚技术沙龙】中的演讲&#xff0c;主要内容为如何通过优酷智能档&#xff0c;降低用户卡顿尤其是双11直播…

导航菜单:jQuery粘性滚动导航栏效果

粘性滚动是当导航在滚动过程中会占粘于浏览器上&#xff0c;达到方便网站页面浏览的效果&#xff0c;也是一种用户体验&#xff0c;下面我们看一下是怎么实现的&#xff1a; jQuery的 smint插件&#xff0c;也是一个导航菜单固定插件。当页滚动时&#xff0c;导航菜单会固定在顶…

如何用Python实现超级玛丽的人物行走和碰撞检测?

作者 | marble_xu编辑 | 郭芮出品 | CSDN博客在《如何用 Python 实现超级玛丽的界面和状态机&#xff1f;》这篇文章中我们讲解如何用代码实现界面和状态机&#xff0c;本文详解人物行走和碰撞检测的实现。功能介绍人物行走人物的行走速度这边分成水平方向&#xff08;X轴&…

WMI技术介绍和应用——查询正在运行的进程信息

在《WMI技术介绍和应用——使用VC编写一个半同步查询WMI服务的类》一文中&#xff0c;我们介绍到了一个半同步查询WMI类的框架。本文将是该技术的一个应用&#xff0c;介绍如何使用WMI技术查询正在运行的进程信息。&#xff08;转载请指明出于breaksoftware的csdn博客&#xff…

20个经典要诀学好英语

出处&#xff1a;我学网互助论坛第一要诀&#xff1a;收听英语气象报告   有些教学录音带为配合初学者的学习&#xff0c;故意放慢语速&#xff0c;这对英语听力的训练是不够的。如果听语速正常的英语&#xff0c;初学者又会感到力不从心。英语气象报告的速度虽快&#xff0c…

ArduinoYun教程之通过网络为Arduino Yun编程

ArduinoYun教程之通过网络为Arduino Yun编程 Arduino Yun的软件部分 通过第一章的介绍后读者就明白了Arduino Yun除了是一个类似其他Arduino的单片机之外&#xff0c;它的另一大组成部分就是运行着一个特殊Linux发行版的Atheros AR9331芯片。所以&#xff0c;本章将会介绍Ather…

WMI技术介绍和应用——查询正在运行的线程信息

本文使用了《WMI技术介绍和应用——使用VC编写一个半同步查询WMI服务的类》中代码做为基础。 一般来说&#xff0c;如果试图枚举系统中的线程。需要先枚举系统中的进程&#xff0c;然后再枚举每个进程中的线程。而WMI给我们提供了一种比较简便的枚举线程信息的方法。&#xff0…

开源生态也难逃“卡脖子”危机?中国AI开发者的警醒和突围

开源不是一个新名词&#xff0c;也不是一个新行动。软件时代&#xff0c;开源推动了全球范围的创新技术成果落地&#xff0c;从而促进全球信息技术发生了全局性、持续性的重大变革&#xff0c;这使它甚至成为一条非常关键且成功的技术路线。随着AI时代的来临&#xff0c;阿里、…

Linux下应用软件的安装

对于刚刚接触Linux的朋友来说,安装一些应用软件是一件头疼的事,因为在Linux下安装应用软件和Windows下截然不同的&#xff0c;下面介绍一下Linux下安装应用软件来解决刚刚接触Linux而不会安装软件朋友的困惑.Linux下软件包有两种比较常见的形式,一种是以 RPM、deb包为代表的智能…

Hibernate 的 session.load()使用方法

2019独角兽企业重金招聘Python工程师标准>>> protected Person getOne(int id){ Session session HibernateSessionFactory.getSession(); Person person new Person(); try{ session.load(person, id); }catch(Exception e){ e.printStackTrace(); }final…

WMI技术介绍和应用——查询桌面信息

本文使用了《WMI技术介绍和应用——使用VC编写一个半同步查询WMI服务的类》中代码做为基础。 在Windows操作系统中&#xff0c;存在很多Windows Station。而每一个Windows Station又存在一个或者多个Windows Desktop。我们一般所说的桌面只是这些众多桌面中的一个。以下内容将介…

联泰集群发布水晶系列工作站,用于深度学习场景

北京时间2019年12月26日&#xff0c;联泰集群在北京正式发布了水晶系列工作站产品 W722、W7224和W5232。 联泰集群硬件产品技术中心总监刘振锋、软件产品技术中心总监孙建军、硬件产品技术中心工程师肖学文分别从应用方向、水晶工作站一体化软件平台及水晶系列产品硬件方面对本…

航空黑客私人YY

坐飞机从从云南飞回老家广州~~~当然绝对支持深圳航空啦!嘎嘎!为啥?当然是服务好 MM太PL了!呵呵!而且在看杂志的同时还看到了一则新闻 内容如下 近日&#xff0c;深圳航空公司与瑞士OnAir公司在香港签约&#xff0c;合作推动在飞机上实现万米高空的自由通信。2008年奥运会前&am…

Redis安装整理(window平台) +php扩展redis

window平台Redis安装 redis windows安装文件下载地址:http://code.google.com/p/servicestack/wiki/RedisWindowsDownload#Download_32bit_Cygwin_builds_for_Windows我选择的redis为最新版的安装文件&#xff0c;见下图&#xff1a; Redis安装文件解压后&#xff0c;有以下…

WMI技术介绍和应用——查询环境变量

本文使用了《WMI技术介绍和应用——使用VC编写一个半同步查询WMI服务的类》中代码做为基础。 我们可以通过系统属性查看当前系统和当前用户的环境变量。&#xff08;转载请指明出于breaksoftware的csdn博客&#xff09; 如何使用WMI枚举所有环境变量的信息&#xff1f; CSynQue…

想学新的编程语言?考虑下Go吧

作者 | Lewis Fairweather译者 | 弯月&#xff0c;责编 | Elle来源 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;【导读】快速的运行时、高效的并发、简单易学的语法&#xff0c;这些都是Go语言最吸引人的特性。以下为译文&#xff1a;Go语言的入门门槛之低令我感到惊…

oracle学习总结三(bulk collect用法)

通过bulk collect减少loop处理的开销发表人:logzgh | 发表时间: 2006年五月19日, 10:56采用bulk collect可以将查询结果一次性地加载到collections中。而不是通过cursor一条一条地处理。可以在select into,fetch into,returning into语句使用bulk collect。注意在使用bulk coll…

MQTT的学习研究(五) MQTT moquette 的 Blocking API 发布消息服务端使用

参看官方文档&#xff1a; http://publib.boulder.ibm.com/infocenter/wmqv7/v7r0/index.jsp?topic/com.ibm.mq.amqtat.doc/tt00000_.htm * Java 为 MQ Telemetry Transport 创建异步发布程序 *在此任务中&#xff0c;您将遵循教程来修改第一个发布程序。通过修改&#xff0c…

WMI技术介绍和应用——查询驱动信息

本文使用了《WMI技术介绍和应用——使用VC编写一个半同步查询WMI服务的类》中代码做为基础。 如何使用WMI查询所有驱动信息&#xff1f;&#xff08;转载请指明出于breaksoftware的csdn博客&#xff09; CSynQueryData recvnotify(L"root\\CIMV2",L"SELECT * FR…

NumericUpDown

NumericUpDown控件主要功能是为一个TextBox控件添加上下按钮&#xff0c;当单击按钮时实现数字的加减&#xff0c;同时也可以提供静态数据&#xff0c;实现这些数据的上下选择。 属性列表&#xff1a; TargetControlID&#xff1a;该控件的目标作用控件。 Width&…

提高建模效率,改变手工作坊式生产,AutoML的技术研究与应用进展如何了?

整理 | 王银出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;【导读】12 月 5-7 日&#xff0c;由中国计算机学会主办&#xff0c;CCF 大数据专家委员会承办&#xff0c;CSDN、中科天玑协办的中国大数据技术大会&#xff08;BDTC 2019&#xff09;在北京长城饭店隆重举…