通过ajax调用php生成json转给js,生成html
1
function onDate()2
{3
@$month = !isset($_POST['month'])? date('n') : $_POST['month'];4
@$year = !isset($_POST['year'])? date('Y') : $_POST['year'];5
//某月的总天数6
$count_month = date("t", mktime(0, 0, 0, $month, 1, $year));7
//某月的开始时间8
$start_time = mktime(0, 0, 0, $month, 1, $year);9
//某月的结束时间10
$end_time = mktime(23, 59, 59, $month, $count_month, $year);11
//取出这个有日记的所有数据12
$data = $_ENV['Diray']->getByTimeDirayList($start_time, $end_time);13
$arr_data = $data;14
$index = 0;15
//将取出的时间戳, 转换成时间, 再整理成数组16
foreach ($data as $row)17
{18
$arr_data[$index]['year'] = date("Y", $row['select_time']);19
$arr_data[$index]['month'] = date("n", $row['select_time']);20
$arr_data[$index]['day'] = date("j", $row['select_time']);21
$index++;22
}23
//将php数据数组转换成json24
$json_string = json_encode($arr_data);25
//ajax调用26
if (isset($_POST['month']) && isset($_POST['year']))27
{28
echo $json_string;29
exit;30
}31
else32
{33
$this->assign('year', $year);34
$this->assign('month', $month);35
$this->assign('data', $json_string);36
//config文件变量初始化37
$this->initSpace();38
$this->display("diray/date2.php");39
}40
}
js代码:
1

function prev()
{2
var prav_year=$('#year_hidden').val();3
var prav_month=$('#month_hidden').val();4
var prav_month =parseInt(prav_month) - 1;5
if (prav_month < 1)6

{7
var prav_month = 12;8
prav_year = parseInt(prav_year) - 1;9
}10

$.ajax(
{11
type:"POST",12
url: 'diray.php?m=diray&a=date',13
data: "month="+prav_month+"&year="+prav_year,14
dataType:"json",15

success:function(msg)
{16
showCalender(msg, prav_year, prav_month);17
}18
});19
}20
21

function next()
{22
var back_year=$('#year_hidden').val();23
var back_month=$('#month_hidden').val();24
var back_month =parseInt(back_month) + 1;25
if (back_month > 12)26

{27
var back_month = 1;28
back_year = parseInt(back_year) + 1;29
}30

$.ajax(
{31
type:"POST",32
url: 'diray.php?m=diray&a=date',33
data: "month="+back_month+"&year="+back_year,34
dataType:"json",35

success:function(msg)
{36
showCalender(msg, back_year, back_month);37
}38
});39
} 40

41

function showCalender(data, year, month)
{42
var arr = data;43

$(function()
{44
var maxDaysOfMonth = new Array(31,28,31,30,31,30,31,31,30,31,30,31);45
var cur_date = new Date(),cur_year,cur_month,cur_day;46
//传入参数47
cur_year = year;48
cur_month = month;49
if (isLeapYear(cur_year)) maxDaysOfMonth[1] = 29;50
var now_date = new Date();51
now_date.setFullYear(cur_year);52
now_date.setMonth(cur_month - 1);53
now_date.setDate(1);54
$("#year").html("");55
$("#month").html("");56
$('#year_hidden').val(cur_year);57
$('#month_hidden').val(cur_month);58
$('#year').append(cur_year+"年");59
$('#month').append(cur_month+"月");60
//第一天星期几61
weekOf1stDay = now_date.getDay();62
maxDays = maxDaysOfMonth[cur_month - 1] == 7? maxDaysOfMonth[cur_month - 1] : maxDaysOfMonth[cur_month - 1] + weekOf1stDay; 63
var j = 1;64
var k = 0;65
for (var clean=1;clean <= 42; clean++ )66

{67
$("#date"+clean).html("");68
$('#date'+clean).removeClass('today');69
}70
for (var i = 1; i <= maxDays; i++)71

{72
var have_value = true;73
if (i > weekOf1stDay || weekOf1stDay == 7)74

{75
for (var k in arr)76

{77
if(arr[k]['day'] == j)78

{79
have_value = false;80
//$("#date"+i).html(""); //以后做成div, 现在有两个数据的都清除了81
$('#date'+i).html("<a href='#'>"+j+"</a>");82
} 83
}84
if (have_value)85

{86
//$("#date"+i).html("");87
$("#date"+i).html(j);88
}89
if(cur_year == cur_date.getFullYear() && cur_month == cur_date.getMonth() + 1 && j == cur_date.getDate())90

{91
$('#date'+i).addClass('today');92
}93
j++;94
}95
else96

{97
//$("#date"+i).html("");98
$("#date"+i).html("");99
}100
}101
});102
}103

function isLeapYear(year)
{104
if(year % 4 ==0 || (year % 400 == 0 && year % 100 != 0)) return true;105
return false;106
}
html代码:
1
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">2
<html xmlns="http://www.w3.org/1999/xhtml">3
<head>4
<meta http-equiv="content-type" content="text/html; charset=utf-8" />5
<title></title>6
<link rel="stylesheet" href="style/a.css" type="text/css" media="screen" />7
<script type="text/javascript" src="js/jquery.js"></script>8
<script type="text/javascript" src="js/diray.js"></script>9

<script type="text/javascript">
{if $data neq ""}showCalender(
{$data},
{$year},
{$month});
{/if}</script>10
</head>11
<body>12
<div id="borderDivId">13
<div id="pageDivId"><span><a id="prav_link" href="javascript:void(0)" onclick="prev()"><<</a></span><span id="year"></span><span id="month"></span><span><a id="back_link" href="javascript:void(0)" onclick="next()">>></a></span>14
</div>15
<div id="weekDivId"><span>日</span><span>一</span><span>二</span><span>三</span><span>四</span><span>五</span><span>六</span></div>16
<div id="dateDiv1"><span id='date1'></span><span id='date2'></span><span id='date3'></span><span id='date4'></span><span id='date5'></span><span id='date6'></span><span id='date7'></span></div>17
<div id="dateDiv2"><span id='date8'></span><span id='date9'></span><span id='date10'></span><span id='date11'></span><span id='date12'></span><span id='date13'></span><span id='date14'></span></div>18
<div id="dateDiv3"><span id='date15'></span><span id='date16'></span><span id='date17'></span><span id='date18'></span><span id='date19'></span><span id='date20'></span><span id='date21'></span></div>19
<div id="dateDiv4"><span id='date22'></span><span id='date23'></span><span id='date24'></span><span id='date25'></span><span id='date26'></span><span id='date27'></span><span id='date28'></span></div>20
<div id="dateDiv5"><span id='date29'></span><span id='date30'></span><span id='date31'></span><span id='date32'></span><span id='date33'></span><span id='date34'></span><span id='date35'></span></div>21
<div id="dateDiv6"><span id='date36'></span><span id='date37'></span><span id='date38'></span><span id='date39'></span><span id='date40'></span><span id='date41'></span><span id='date42'></span></div>22
<input type='hidden' id='year_hidden' name='year_hidden' value="" />23
<input type='hidden' id='month_hidden' name='month_hidden' value="" />24
</div>25
</body>26
</html>
可以歇歇了!!
浙公网安备 33010602011771号