今日分享一点干货。PHP中课程表的实现。
首先贴代码,代码贴完再细说:
前段HTML:
<div id="studentRead" class="reading" style="z-index:10" >
<div class="class-table">
<div class="class-table-tit clearfix">
<h3 class="fl">班级课程表</h3>
<a class="fr" id ='studentEditKcb' attr="edit" onclick = "editKcb(this);" style="cursor:pointer;">编辑
</a>
</div>
<table border="0" cellspacing="0" cellpadding="0" id = "myTable">
<tr>
<th width="5%"></th>
<th width="19%">周一</th>
<th width="19%">周二</th>
<th width="19%">周三</th>
<th width="19%">周四</th>
<th width="19%">周五</th>
</tr>
<tr id = "focustr">
<td rowspan="4" class="td-bg">上<br/>午</td>
<volist name = "dataListStu" id = "val" offset="0" length='1'>
<volist name = "val" id = "value">
<td>
<input id = "focusId" readonly="true" maxlength='7' type="text" value="{$value}" />
</td>
</volist>
</volist>
</tr>
<volist name = "dataListStu" id = "val" offset="1" length='3'>
<tr>
<volist name = "val" id = "value">
<td>
<input readonly="true" maxlength='7' type="text" value="{$value}" />
</td>
</volist>
</tr>
</volist>
<tr>
<td rowspan="4" class="td-bg">下<br/>午</td>
<volist name = "dataListStu" id = "val" offset="4" length='1'>
<volist name = "val" id = "value">
<td>
<input readonly="true" maxlength='7' type="text" value="{$value}" />
</td>
</volist>
</volist>
</tr>
<volist name = "dataListStu" id = "val" offset="5" length='3'>
<tr>
<volist name = "val" id = "value">
<td>
<input readonly="true" maxlength='7' type="text" value="{$value}" />
</td>
</volist>
</tr>
</volist>
</table>
</div>
</div>
CSS:
/*课程表*/
.class-table{
background: #f6fafe;
border: 1px solid #e9ecee;
-webkit-border-radius: 5px;
width: 478px;
padding: 10px 20px 20px;
-moz-border-radius: 5px;
border-radius: 5px;
}
.class-table-tit{
height: 30px;
line-height: 30px;
}
.class-table-tit h3{
color: #666;
font-size: 16px;
font-weight: bold;
}
.class-table-tit a{
font-size: 14px;
color: #187aff;
}
.class-table table{
width: 100%;
}
.class-table table th{
height: 40px;
background: #aedf74;
text-align: center;
border-right: 1px solid #9dc968;
}
.class-table table th:first-child{
background: #89cc4a;
border-right:;
}
.class-table table td{
height: 30px;
border: solid #e3eaf1;
border-width: 0 1px 1px 0;
text-align: center;
font-size: 14px;
color: #666;
}
.class-table table td input{
border:;
height: 20px;
line-height: 20px;
width: 70%;
background: none;
text-align: center;
color: #666;
}
.class-table table td input.activeStu{
background: #66a7ff;
color: #fff;
}
.td-bg{
background: #c4ea96;
}
JS部分:
var flagkcb = true;
//控制课程表编辑和完成。
function editKcb(obj){
var editHtml = $(obj).attr('attr');
if(editHtml == 'edit'){
$(".class-table table td input").attr('class','activeStu');
$(".class-table input").attr('readonly',false);
$("#studentEditKcb").html('完成');
$(".class-table table td input").attr('class','activeStu');
$("#focustr td:nth-child(2) input").focus();
$(obj).attr('attr','save');
}else{
if(flagkcb){
reloadKCB();
$(obj).attr('attr','edit');
}else{
alert('数据保存中,请勿重复提交!');
}
}
} //获取页面表格内的数据
function getTableValue(){
var kecbInput = $(".activeStu");
var i = 0;
var j= 0;
var data = [];
var data2 = [];
$.each(kecbInput,function(k,v){
data2[j] = v.value;
j++;
if((k+1)%5==0){
j = 0;
data[i] = data2;
data2 = [];
i++;
}
});
return data;
} //课程表
function reloadKCB(){
$("#records").hide();
$("#classba").hide();
$("#classhare").hide();
$("#homework").hide();
$('#studentRead').show();
var data = getTableValue();
//根据ajax加载,若加载后数据为空,则证明该学生没有编辑过课程表,直接显示
$.ajax({
type:"POST",
url: U('public/Index/savekcb'),
data:{"data":data},
dataType:"json",
success:function(response){
flagkcb = true;
$(".class-table table td input").removeAttr('class','activeStu');
$(".class-table input").attr('readonly',true);
$("#studentEditKcb").html('编辑');
},
error:function(msg){
flagkcb = true;
alert('保存失败请重试');
// $("#studentRead").show();
// $("#studentRead").html("").html("<p style='padding:20px;'>加载失败,<a href='javascript:topic.init();'>请重试!</a></p>");
}
}); //
// }
}
后端部分:
/**
* 学生课程表个人编辑保存
*/
public function savekcb(){
$saveResult = array('status'=>200,'msg'=>'保存成功');
//拿到的是一个二维数组
$data = $_REQUEST['data'];
$user=$GLOBALS['ts']['cyuserdata'];
//课程表数据转成json格式保存
$saveArray = json_encode($data);
//空间用户id
$uid = $this->uid ;
//用户cyuid
$saveData = array();
$saveData['cyuid'] = $user['user']['cyuid'];
$saveData['uid'] = $uid;
$saveData['kcb'] = $saveArray;
//创建时间
$saveData['createtime'] = date('Y-m-d H:i:s');
$saveData['updatetime'] = date('Y-m-d H:i:s'); $isExit = D('StudentKcb')->where("`uid`=$uid")->find();
if($isExit){
unset($saveData['createtime']);
$result = D('StudentKcb')->where("`uid`=$uid")->save($saveData);
}else{
$result = D('StudentKcb')->add($saveData);
}
if(!$result){
$saveResult = array('status'=>400,'msg'=>'保存失败');
}else{
$stuKcb = json_decode($result['kcb'],true);
S($this->uid."_student_kcb",$stuKcb,60*5);
}
exit(json_encode($saveResult));
} /**
* 个人学生空间页面课程表初始化
*/
private function initkcb(){
$result = S($this->uid."_student_kcb");
if(!$result){
//空间用户id
$uid = $this->uid ;
$result = D('StudentKcb')->where("`uid`=$uid")->find();
$result = json_decode($result['kcb'],true);
if(!$result){
$result = array(
0=>array('','','','',''),
1=>array('','','','',''),
2=>array('','','','',''),
3=>array('','','','',''),
4=>array('','','','',''),
5=>array('','','','',''),
6=>array('','','','',''),
7=>array('','','','',''),
);
}
S($this->uid."_student_kcb",$result,60*5);
} $this->assign('dataListStu',$result);
} }
开始细说:先来一张效果图吧。编辑前:
编辑中(点右上角编辑后):
加了一些定位跟背景色的变化。让用户有更好体验,
第一步: 在接这个需求的时候,首先我在想怎么去获取表格内的数据,我首先想到的是 利用for循环嵌套,而后加判断,把数据往定义好的数组里添加,但是后来一想那样的话会导致
数据正确没错,但是存的数据有问题我打个比方 data[]={
data[1]={
data[1][1] = 0;
... ...
}
data[2]={ data[2][0]= 1;
... ...
}
... ...
}
意思就是我按照行循环的时候, 因为第一行跟第五行 多了一个<td>的存在, 会导致我的下标是从1开始 而不是跟其他行一样从0开始。
后来我想不这样做,我加一个独有的class,就有了 var kecbInput = $(".activeStu"); 这句话。 这句话的意思是获取所有class="activeStu" 的对象的集合。
至于余下的循环写法 如果有看不懂的可以在文章里直接提问,就不细说了。
第二步:写完获取值后,剩下的无非就是传值到后台了,思路是每一个学生有一张属于他自身独有的课程表。还是老方法 利用ajax传值。 在保存数据的时候,将数据保存成json格式进行存 储。
第三步:传值到前台页面并展示, 其实这个地方 ,如果有不少同学说, 这个简单着呢,不就是for循环 利用js 控制显示嘛, 那么就证明你没有掌握php volist 标签的好用之处!
利用volist 可以很轻松的如我贴出来的代码一样 将你想要赋的值 展现出来。
很多东西其实都在贴出来的代码里了,我表达能力不是很好,或者说我对这些东西理解也没到一定的程度。
本来我是想 可以分享一些思路给大家, 但是写着写着发现 ,其实也没什么好说的。 不就这样么。 但是我还是觉得发出来好些吧, 可能有些人需要呢?虽然简单也没花多长时间。但是我相 信不停的分享,可能你的感悟就更深一些。
今日分享一点干货。PHP中课程表的实现。的更多相关文章
- 【分享】IT产业中的三大定理(一) —— 摩尔定理(Moore's Law)
科技行业流传着很多关于比尔·盖茨的故事,其中一个是他和通用汽车公司老板之间的对话.盖茨说,如果汽车工业能够像计算机领域一样发展,那么今天,买一辆汽车只需要 25 美元,一升汽油能跑四百公里.通用汽车老 ...
- 3D语音天气球(源码分享)——在Unity中使用Android语音服务
转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 开篇废话: 这个项目准备分四部分介绍: 一:创建可旋转的"3D球":3 ...
- 【分享】IT产业中的三大定理(二) —— 安迪&比尔定理 (Andy and Bill's Law)
摩尔定理给所有的计算机消费者带来一个希望,如果我今天嫌计算机太贵买不起,那么我等十八个月就可以用一半的价钱来买.要真是这样简单的话,计算机的销售量就上不去了.需要买计算机的人会多等几个月,已经有计算机 ...
- 分享在MVC3.0中使用jQuery DataTable 插件
前不久在网络上看见一个很不错的jQuery的DataTable表格插件.后来发现在MVC中使用该插件的文章并不多.本文将介绍在MVC3.0如何使用该插件.在介绍该插件之前先简单介绍一下,推荐该插件的原 ...
- 【分享】IT产业中的三大定理(三) —— 反摩尔定理 (Reverse Moore's Law)
Google(谷歌)的 CEO 埃里克·施密特在一次采访中指出,如果你反过来看摩尔定理,一个 IT 公司如果今天和十八个月前卖掉同样多的.同样的产品,它的营业额就要降一半.IT 界把它称为反摩尔定理. ...
- 【腾讯Bugly干货分享】职场中脱颖而出的成长秘诀
本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:http://mp.weixin.qq.com/s/uQKpVg7HMLfogGzzMyc9iQ 导语 时光 ...
- 分享一些前端开发中最常用的JS代码片段~ 干货~
http://www.w3cfuns.com/notes/25068/1d0d350a974d879e63f1115cf80a3288.html
- 分享点干货(此this非彼this)this的详细解读
在javascript编程中,this关键字经常让初学者感到迷惑,这里,针对此this根据查阅的资料和个人的理解分享一下,纯手打,大神勿喷. 首先先说一下this的指向,大致可以分为以下四种. 1.作 ...
- 分享.NET系统开发过程中积累的扩展方法
.NET 3.5提供的扩展方法特性,可以在不修改原类型代码的情况下扩展它的功能.下面分享的这些扩展方法大部分来自于Code Project或是Stackoverflow,.NET为此还有一个专门提供扩 ...
随机推荐
- [JavaScript] JavaScript作用域深度解析
JavaScript作用域 JavaScript中的函数运行在它们被定义的作用域里,而不是它们被执行的作用域里. -- JS权威指南 在JS里,一切皆对象,函数也是. 一.有什么用 什么时候会用到它? ...
- 第三方账号登录--QQ登录,以及QQ微博账号登录
在QQ登陆测试的时候,刚申请正常登陆,但是由于app未上线,或许是腾讯升级造成的个别时候QQ登陆无法成功会提示下图代码,功能上没啥问题,已经达到 测试效果了.附上腾讯错误代码图(大家测试QQ登陆的时候 ...
- Javascript url 小逻辑
情况1 : var xhr = new XMLHttpRequest(); xhr.open("GET", "/api/products", true); xh ...
- Currency 货币 filter
angularjs 其实也有一个currency指令,不过好像只是换符号而已. 这里自己写了一个简单的兑换率filter <div ng-controller="ctrl"& ...
- Android 给TextView添加点击事件
首先设定TextView的clickable属性为true. 可以在布局文件中进行设定,比如: <TextView android:id="@+id/phone" andro ...
- BZOJ2091: [Poi2010]The Minima Game
2091: [Poi2010]The Minima Game Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 243 Solved: 163[Subm ...
- 学习下关于ViewStub实例的用法及带Drawable的TextView的妙用
在项目中,我们可能有多种数据来源比如: 里面有ListView也有当获得数据为空的时候显示的空信息.根据点击的项目还是差事不同,显示的空消息也不同.a.没有收藏的项目,b目前没有收藏的差事. 其实实现 ...
- Android UI 之TextView控件属性列表
在网上收集到了TextView 的属性,在开发过程中还是挺有用的. android:autoLink 设置是否当文本为URL链接/email/电话号码/map时,文本显示为可点击的链接.可选值(non ...
- B - Network - uva 315(求割点)
题意:给一个无向连通图,求出割点的数量. 首先输入一个N(多实例,0结束),下面有不超过N行的数,每行的第一个数字代表后面的都和它存在边,0表示行输入的结束(很蛋疼的输入方式). 分析:割点的模板题 ...
- hdu1166敌兵布阵
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...