http://www.cnblogs.com/qianjinyan/p/8961086.html

题目要求:

1. 通过jquery动态的创建一个表格,随机生成(id自增,name随机2-3个中文汉字(10个姓,20个名字),age随机100以内整数)大于50小于100行的数据(用户对象:id,name,age)
2. 每行分4列,第一列显示checkbox,第二列显示用户名,第三列显示年龄,第四列显示删除操作,点击删除按钮可以把这行数据删掉
3. 区分基数行和偶数行背景色
4. 把所有年龄超过60岁的行字号 + 10px
5. 统计出平均年龄(jquery方法)
6. 把姓氏最多的行边框变成蓝色
7. 随机删除10行数据
8. 把第二列和第三列调换位置
9. 取出第5-10行每行的用户名和年龄,姓名去重,年龄求和

  

<!DOCTYPE html>
<html lang="en" dir="ltr"> <head>
<meta charset="utf-8">
<title>Tommy Exam</title>
<style>
.table {
border-collapse: collapse;
} .table td {
width: 150px;
} .evenTr {
background: #ccc;
} .blueBorder {
border:1px solid blue;
}
</style>
</head> <body> <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<script type="text/javascript" >
$(document).ready(function () { var table, buttons;
var __id__ = 1;
var firstNames = Array.from('赵钱孙李周吴郑王冯陈');
var lastNames = Array.from('大小中高矮胖瘦宝兵杰武明一婷婉晓奇志远林');
var nameIndex = 1, ageIndex = 2;
var init = function() {
createButtons();
createTable();
}; var createButtons = function() {
buttons = $('<div/>', {style:'margin-top:10px; text-align:center;'});
$('body').append(buttons);
createButton('>60岁字体+10px', addFontSizeFor60);
createButton('统计平均年龄', average);
createButton('姓氏最多边框变蓝', mostLastName);
createButton('随机删除10行数据', randomDelete10Rows);
createButton('调换2,3列', change23);
createButton('5-10姓名去重', names5to10);
}; var addFontSizeFor60 = function() {
table.find('tr').find('td:eq('+ageIndex+')').each((i, ele) => {if (parseInt($(ele).text()) > 60){
$(ele).parent().css('font-size', (index, value) => parseInt(value) + 10 + 'px');
}})
}; var average = function() {
var total = table.find('tr').find('td:eq('+ageIndex+')').map((index, ele) => parseInt($(ele).text())).get().reduce((p,c) => p+c);
var rows = table.find('tr').length;
alert('平均年龄=' + total/rows);
}; var mostLastName = function() {
$('.blueBorder').removeClass('blueBorder');
var map = {};
table.find('tr')
.find('td:eq(' + nameIndex +')')
.map((index, ele) => $(ele).text().substring(0,1))
.get()
.forEach(v => {
if (!map[v]) {
map[v] = {name : v, nums : 1};
} else {
map[v].nums ++;
}
});
var _firstName = Object.values(map).sort((a, b) => b.nums - a.nums)[0].name;
table.find('tr')
.find('td:eq(' + nameIndex +'):contains("'+_firstName+'")').parent().addClass('blueBorder');
alert('最多的姓氏是[' + _firstName + ']');
}; var randomDelete10Rows = function(){
for (var i = 0; i < 10; i++) {
randomDeleteRow();
}
}; var randomDeleteRow = function() {
var rows = table.find('tr').length;
var _num = randomNumber(0, rows - 2);
table.find('tr').eq(_num).remove();
recssTable();
}; var change23 = function() {
table.find('tr').each((i, ele) => {
$(ele).find('td:eq(1)').before($(ele).find('td:eq(2)'));
});
var _temp = nameIndex;
nameIndex = ageIndex;
ageIndex = _temp;
}; var names5to10 = function() {
var users = table.find('tr:gt(3):lt(6)').map((i,ele) => {return {name:$(ele).find('td:eq(' + nameIndex+ ')').text(), age: parseInt($(ele).find('td:eq('+ageIndex+')').text())}}).get()
var map = {};
users.forEach(user => {
if (!map[user.name]) {
map[user.name] = {
name : user.name,
ages : user.age
}
} else {
map[user.name].ages += user.age;
}
});
alert(JSON.stringify(Object.values(map)));
}; var createButton = function(name, _event_){
var button = $('<input/>', {type:'button', value:name, style:'font-size:20px;'});
button.bind('click', _event_);
buttons.append(button);
}; var createTable = function () {
table = $('<table/>', {class:'table', style:'margin:10px auto;'});
createRandomUsers();
$('body').append(table); recssTable();
}; var recssTable = function() {
table.find('.evenTr').removeClass('evenTr');
table.find('tr:even').addClass('evenTr');
}; var createRandomUsers = function () {
var nums = randomNumber(50, 99);
for (var i = 0; i < nums; i++) {
createRandomUser();
}
}; var createRandomUser = function () {
var tr = $("<tr/>");
var id = __id__;
__id__ ++;
var name = randomName();
var age = randomNumber(0, 99);
createTd(tr, $('<input/>', {type:'checkbox', value:id}));
createTd(tr, name);
createTd(tr, age);
var deleteButton = $('<input/>', {type :"button", value:'Delete', style:'width:100px;'});
deleteButton.bind('click', function(){
tr.remove();
recssTable();
});
createTd(tr, deleteButton);
table.append(tr);
}; var createTd = function(tr, child) {
var td = $("<td/>", {style:'height:30px; line-height:30px;'});
td.append(child);
tr.append(td);
}; var randomName = function(){
return firstNames[randomNumber(0, 9)] + lastNames[randomNumber(0, 19)];
}; var randomNumber = function(min, max) {
return Math.floor(Math.random() * (max - min)) + min + 1;
} init();
});
</script>
</body> </html>

  

jquery作业 教授答案的更多相关文章

  1. JQuery面试题答案

    jQuery面试题答案 转自:http://blog.csdn.net/zhangpei_xf/article/details/8822021 一.Jquery测试题 下面哪种不是jquery的选择器 ...

  2. 与左侧的 圆括号“(”(位于“e:\大二上课程课件、作业和答案\数据结构\chapter4\sqstack\sqstack\mysqstack.h(23)”)匹配之前遇到文件结束

    错误原因是“某对圆括号只打了左括号而没有右括号”,debug方法是:直接根据报错提示:“与左侧的 圆括号“(”(位于“e:\大二上课程课件.作业和答案\数据结构\chapter4\sqstack\sq ...

  3. java第一天学习作业及答案

    作业一 一.选择题 1.选出在java中有效的注释声明(AD)(选两项) A.//这是注释 B.*/这是注释*/ C./这是注释 D./*这是注释*/ 2.在控制台运行一个java程序,使用的命名正确 ...

  4. jquery作业

    1. 通过jquery动态的创建一个表格,随机生成(id自增,name随机2-3个中文汉字(10个姓,20个名字),age随机100以内整数)大于50小于100行的数据(用户对象:id,name,ag ...

  5. jQuery 作业三个按钮

    作业三个按钮 <!--声明 文档--> <!DOCTYPE html> <!--定义字符集--> <html lang="zh-CN"&g ...

  6. jQuery作业 点击显示

    代码如下: 里: 导入jQuery包: 里:内容 水果 苹果 橘子 梨子 香蕉 化妆品 口红 眼影 腮红 高光 护肤品 水 乳 霜 精华

  7. CSAPP深入理解计算机系统(第二版)第三章家庭作业答案

    <深入理解计算机系统(第二版)>CSAPP 第三章 家庭作业 这一章介绍了AT&T的汇编指令 比较重要 本人完成了<深入理解计算机系统(第二版)>(以下简称CSAPP) ...

  8. JQUERY 测验

    1.下面哪种说法是正确的? 您的回答:jQuery 是 JSON 库 正确答案:jQuery 是 JavaScript 库 2.jQuery 使用 CSS 选择器来选取元素? 您的回答:错误 正确答案 ...

  9. jquery常见问题

    1.下面哪种说法是正确的? 您的回答:jQuery 是 JavaScript 库 2.jQuery 使用 CSS 选择器来选取元素? 您的回答:错误 正确答案:正确 3.jQuery 的简写是? 您的 ...

随机推荐

  1. 【Cocos2dx 3.3 Lua】触屏事件

    cocos2dx 3.x触屏时间分为单点触摸和多点触摸:     单点触摸:(即只有注册的Layer才能接收触摸事件)      多点触摸点单用法(多个Layer获取屏幕事件):           ...

  2. windows下docker的安装并使用

    硬件虚拟化:硬件虚拟化是一种对计算机或操作系统的虚拟.虚拟化对用户隐藏了真实的计算机硬件,表现出另一个抽象计算平台. 打开任务管理器的性能查看是否支持虚拟化技术 下载windows docker ht ...

  3. 下载及安装selenium IDE

    安装方法1:可以从官方网站下载:http://seleniumhq.org/download/,但是由于selenium服务器在美国,中美的网络经常不稳定,经常会连接失败,导致下载不了 可以找一下se ...

  4. 测试开发-web测试要点

    参数输入考虑 参数数值包含1个.多个.很多个.null.参数值前后包含空格的2种情况   数字类型:正数.负数.0.0.0.+0.0.-0.0.指数.对数.分数.小数.复数.科学计数法的测试,全角的数 ...

  5. C++原创应用类库和工具类库

    此博文记载着自编C++应用类库和生成器库的源代码的链接地址,并且对库的开发环境.开发过程.缺陷以及改进更新进行说明. 分数类 利用中午的时间,自己在Visual Studio 2013环境下编写了一个 ...

  6. ant编译无法依赖rt.jar

    最近同事在用ant编译投产的时候报了一个错误: 程序包com.sun.org.apache.xml.internal.security.exceptions不存在 大致网上搜集了一下资源:具体原因是相 ...

  7. 升级到php7相关问题,日请求过亿QQ会员活动平台PHP7升级实践

    升级到php7相关问题,日请求过亿QQ会员活动平台PHP7升级实践 日请求过亿:QQ会员活动平台PHP7升级实践http://mp.weixin.qq.com/s?__biz=MjM5MjAwODM4 ...

  8. jenkin环境搭建

      Jenkins是一个用Java编写的开源的持续集成(CI)工具,可持续.自动地构建/测试软件项目,监控一些定时执行的任务.具有开源,支持多平台和插件扩展,安装简单,界面化管理等特点. 1.下载并解 ...

  9. oracle中使用函数控制过程是否执行(结合job使用)

    oracle中使用函数控制过程是否执行(结合job使用时候,循环时间不好写的时候,可以此种方法比较方便) CREATE OR REPLACE FUNCTION wsbs_pk_date_validat ...

  10. bzoj1635 / P2879 [USACO07JAN]区间统计Tallest Cow

    P2879 [USACO07JAN]区间统计Tallest Cow 差分 对于每个限制$(l,r)$,我们建立一个差分数组$a[i]$ 使$a[l+1]--,a[r]++$,表示$(l,r)$区间内的 ...