原文摘自我的前端博客,欢迎大家来访问

起因

今天和豪哥聊天,才知道他是我老乡,而且特别近。。真的感觉他是我的贵人,这是他从 联想校招扣出来的,我们就用JavaScript来实现吧

联想校招员工信息展示点击弹出详细信息

过程

给的有HTML还有CSS3,我打算先用前端模板技术讲信息都出来,之前数据是写死在HTML

数据封装在data.js里

var data = [];

data.push({
'name' : 'Dillon',
'enname' : 'Dillon',
'desc' : '来自哈佛的战略伙伴经理',
'pic' : 'images/n8_10.png',
'bigpic' : 'images/j2.jpg'
}); data.push({
'name' : '成俞晟',
'enname' : 'cheng',
'desc' : '技术宅服务器工程师',
'pic' : 'images/n8_07.png',
'bigpic' : 'images/j3.jpg'
}); data.push({
'name' : 'Said',
'enname' : 'Said',
'desc' : '开朗健谈的中国通',
'pic' : 'images/n8_18.png',
'bigpic' : 'images/j5.jpg'
}); //...

我们讲以前的HTML写成一个模板

展示区模板

<div id="temp_li" style="display: none;">
<li data-id="{i}" class="transform">
<div>
<i></i>
<span>{name}</span>
<p>{desc}</p>
</div>
<img src="{pic}">
</li>
</div>

弹出层模板

<div id="dialog"  class="box_ovo ">
<span id="close" class="close"><i></i></span>
<span class="prev"><i></i></span>
<span class="next"><i></i></span>
<div id="div_temp1" data-id="{i}" >
<img class="oimg1" src="{bigpic}">
<div class="ovotxt">
<div class="ovohead">
<h1>{name}</h1>
<i>{enname}</i>
<em>{desc}</em>
<span>ECS</span>
</div>
<p>2013年加入联想,联想游戏中心最霸气的女商务,性格大大咧咧,柔弱的外表下有一颗强大的心。自诩内可安邦定天下,外可御敌千里外。</p>
<p>联想游戏中心作为北研最靓丽的风景线,不仅有着最潮、最流行的游戏可以玩,有各种精美的游戏周边随便拿,最关键的是有这样娇(ba)媚(qi)可(shi)人(zu)的女汉子陪聊,陪工作,陪吃饭。总之一句话,联想游戏中心,你值得拥有。</p>
</div>
</div>
</div>

然后用一下代码弄到HTML里面

//获取LI模板HTML
var tempLi = document.getElementById('temp_li').innerHTML;
//HTML + 数据最后放到这个数组里
var liArr = [];
for (var i = 0; i < data.length; i++) {
//替换模板里{}表达式
var itemLi = tempLi.replace(/\{i\}/, i)
.replace(/\{name\}/,data[i].name)
.replace(/\{desc\}/,data[i].desc)
.replace(/\{pic\}/,data[i].pic);
liArr.push(itemLi);
} //加入到ul里
ul.innerHTML = liArr.join(''); //获取详细信息模板
var tempDialog = dialog.innerHTML; //打开弹出层
function openDialog(dataIndex) {
dialog.innerHTML = tempDialog.replace(/\{i\}/,dataIndex)
.replace(/\{name\}/,data[dataIndex].name)
.replace(/\{enname\}/,data[dataIndex].enname)
.replace(/\{desc\}/,data[dataIndex].desc)
.replace(/\{bigpic\}/,data[dataIndex].bigpic);
bg.className += ' current';
dialog.className += ' current';
}

因为HTML是动态生成的,直接不能加绑定事件,所以使用事件委托

//给每一个li加事件
ul.onclick = function(event) {
var e = event || window.event;
var target = e.target || e.srcElement;
target = getLiByChild(target);
if(target) {
var curIndex = target.getAttribute('data-id');
openDialog(curIndex);
}
} //给弹出层加事件
dialog.onclick = function(){
var e = event || window.event;
var target = e.target || e.srcElement;
var curIndex = +dialog.lastElementChild.getAttribute('data-id');
//点击关闭
if(target.nodeName == 'I' && target.parentNode.className == 'close') {
closeDialog();
}
//点击上一个
if(target.nodeName == 'I' && target.parentNode.className == 'prev') {
var preIndex= curIndex-1;
if(preIndex > -1) {
closeDialog(function() {
openDialog(preIndex);
});
}else {//否则循环到最后一个
closeDialog(function() {
openDialog(data.length-1);
});
} } //点击下一个
if(target.nodeName == 'I' && target.parentNode.className == 'next') {
var nextIndex= curIndex+1;
if(nextIndex < data.length) {
closeDialog(function() {
openDialog(nextIndex);
});
}else {//否则循环到最后一个
closeDialog(function() {
openDialog(0);
});
}
} }

其中,弹出层里有三个动作;

1.关闭弹窗 2.前一个 2.后一个

我们在里面做处理,如果是前一个为第一个则跳到最后一个,如果为最后一个则跳到前一个

因为我们点击的时候有可能点到SPAN,有可能点到DIV(原因看展示区模板),所以要有个函数来 找到顶层的LI,因为关闭有一个动画效果,我看了CSS是0.3s,所以我们加一个定时器做一个回调

//找到最顶层LI
function getLiByChild(element) {
var li = element;
while(li.nodeName != 'LI') {
li = li.parentNode;
}
return li;
} //关闭Dialog
function closeDialog(func) {
bg.className = 'box_bg1';
dialog.className = 'box_ovo';
setTimeout(function(){
if(dialog.className == 'box_ovo') {
func && func();
}
},300);
}

获取代码

代码就不贴在博客上了,很简单,没什么可看的,大家可以去我的github上检出

JavaScript实现联想校招员工信息展示的更多相关文章

  1. 无废话ExtJs 入门教程十五[员工信息表Demo:AddUser]

    无废话ExtJs 入门教程十五[员工信息表Demo:AddUser] extjs技术交流,欢迎加群(201926085) 前面我们共介绍过10种表单组件,这些组件是我们在开发过程中最经常用到的,所以一 ...

  2. SSH_框架整合4--添加员工信息

    SSH_框架整合4--添加员工信息 一. 1 index.jsp:添加:<a href="emp-input">添加员工向信息:Add Employees' Infor ...

  3. Python 员工信息管理系统

    学Python将近一个月了,第一次写了两百多行代码,一个很简单的脚本. 员工信息管理系统: 需求: 1.管理员账户能够增加,删除,修改,查询员工信息,并且设置管理员账户. 2.普通账户可以查看所有员工 ...

  4. jQuery实现的3个基础案例(仿QQ列表分组,二级联动下拉框,模拟员工信息管理系统)

    1.仿QQ列表分组 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type&quo ...

  5. Python_查找员工信息-48

    ''' 查找出userinfo文件中年龄大于22岁的员工姓名和年龄 1,Alex,22,13651054608,IT 2,Egon,23,13304320533,Tearcher 3,nezha,25 ...

  6. s9.16作业,员工信息表

    转载https://blog.csdn.net/qq_35883464/article/details/83151464 实现员工信息表文件存储格式如下:id,name,age,phone,job1, ...

  7. qt项目:员工信息管理系统

    开发一个员工信息管理系统 一.项目具体要求: 1.用qt开发界面,数据库用QSqlite 数据库文件名:demostudent.db 2.通过界面能够查看到数据库中员工信息表中内容,包括员工姓名.年龄 ...

  8. day21 05 员工信息表

    day21 05 员工信息表 假设有一个员工信息表,里面有每个员工的名字,id,年龄,电话,还有他们所作的工作,而有时候我们并不需要所有的信息,而想根据某些条件,寻找符合条件即可,即筛选, 比如想要筛 ...

  9. Ajax应用查询员工信息

    首先要用上一篇的步骤启动服务器,建立站点.然后在该站点下创建php文件和html文件. php代码如下,文件名为server.php <?php //设置页面内容是html编码格式是utf-8 ...

随机推荐

  1. Python Twisted、Reactor

    catalogue . Twisted理论基础 . 异步编程模式与Reactor . Twisted网络编程 . reactor进程管理编程 . Twisted并发连接 1. Twisted理论基础 ...

  2. malware analysis、Sandbox Principles、Design && Implementation

    catalog . 引言 . sandbox introduction . Sandboxie . seccomp(short for secure computing mode): API级沙箱 . ...

  3. Google Guava vs Apache Commons for Argument Validation

    It is an established good practice to validate method arguments at the beginning of the method body. ...

  4. AngularJs ngCsp、ngFocus、ngBlur、ngForm

    ngCsp 处理CSP(上下文安全策略)的支持. 当开发如google浏览器的扩展时候这个就必须使用. CSP禁止应用程序使用eval和Function(string)生成的函数.如果我们需要兼容,我 ...

  5. PL/0编译器(java version) – SymbolTable.java

    1: package compiler; 2: //竟然没有对符号表检查大小,会溢出的. 3:   4: import java.io.IOException; 5:   6: public clas ...

  6. POJ1185炮兵阵地(状态压缩 + dp)

    题目链接 题意:给出一张n * m的地图,其中 有的地方能放大炮,有的地方不能,大炮与上下左右两个单位范围内会相互攻击,问最多能放几个大炮 能放大炮为1不能放大炮为0,把每一行看做一个状态,要除去同一 ...

  7. JS-流程控制汇集

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>流 ...

  8. css的核心内容 标准流、盒子模型、浮动、定位等分析

    1.块级元素:如:<div></div>2.行内元素:如:<span></span>从效果中看块级元素与行内元素的区别: 通过CSS的设置把行内元素转换 ...

  9. yum提示another app is currently holding the yum lock;waiting for it to exit

    Another app 解决方法:rm -rf /var/run/yum.pid 来强行解除锁定,然后你的yum就可以运行了

  10. 第一章 基础设施,1.3 阿里视频云ApsaraVideo是怎样让4000万人同时狂欢的(作者:蔡华)

    1.3 阿里视频云ApsaraVideo是怎样让4000万人同时狂欢的 前言 在今年的双11中,双11天猫狂欢夜的直播成为一大亮点. 根据官方披露数据,直播总观看人数超4257万,同时观看人数峰值达5 ...