设为首页 收藏本站
查看: 992|回复: 0

[经验分享] 通过ajax调用php生成json转给js,生成html

[复制链接]

尚未签到

发表于 2015-8-25 14:33:27 | 显示全部楼层 |阅读模式
DSC0000.gif DSC0001.gif php代码
1 DSC0002.gif 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数据数组转换成json
24        $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        else
32        {
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代码:

js代码:
  1function prev() DSC0003.gif {
  2 DSC0004.gif     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 DSC0005.gif DSC0006.gif     {
  7       var prav_month = 12;
  8       prav_year = parseInt(prav_year) - 1;
  9 DSC0007.gif     }
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 DSC0008.gif }
20   
21function 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
41function 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            else
96            {
97                //$("#date"+i).html("");
98                $("#date"+i).html("");
99            }
100        }
101    });
102}
103function isLeapYear(year){
104    if(year % 4 ==0 || (year % 400 == 0 && year % 100 != 0)) return true;
105    return false;
106}  
  html代码:

Code
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()">&lt;&lt;</a></span><span id="year"></span><span id="month"></span><span><a id="back_link" href="javascript:void(0)" onclick="next()">&gt;&gt;</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>  
  
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-104117-1-1.html 上篇帖子: 用PHP模拟HTTP中的POST请求JSP网页,提交数据 下篇帖子: PHP防盗链技术
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表