商城公告功能开发总结

效果如下
商城公告功能开发总结_第1张图片

1.定在头部

        position: fixed;
        z-index: 999;
        top: 0;
        opacity:1;

2.ajax处理json数据

        // 获取商城公告
        function getNotice() { // 获取公告函数
            var res;
            $.ajax({
               type: "POST",
               url: "{sh::U('Store/Mall/ajaxGetNotice',array('mid'=>$mid))}",
               dataType:'json', // 设为json之后,就能够很好的处理获取的json数据,json.status
               async: false,
               success: function(json){
                    res = json;  
               }
            });
            return res;
        }

设置dataType:'json'之后,json数据就直接可以通过json.的方式处理了。

3.最后加载,页面更好看。

$(document).ready(function(e) { // 主函数
            // 获取公告
            var action_name = "{sh::ACTION_NAME}"; // 页面使用thinkphp常量
            var json = getNotice();
            if ( action_name == 'index' && json.status == 1) { // 首页并且公告存在
                $(".top").css("margin-top", "70px"); // jquery设置css
                $(".main-sidebar").css("top" ,"70px");
                var html = '';
                $.each(json.info, function(i, n){ // n为文本内容
                    html += "<li><strong>"+n.content+"</strong></li>"
                });
                $(".top-notice").show();
                $('#notice ul').html(""+html);
                $('#notice').unslider();  // 轮播
            }
        });

4.获取sql语句的thinkphp处理

// 获取公告
    function ajaxGetNotice() {
        if (IS_AJAX) {
            $this->mid;
            // 获取有效的,且结束时间大于当前时间的,或者日期等于0的公告
            $mallNoticeModel = M('Mall_notice');
            $where['mall_id'] = $this->mid;
            $where['status']  = 1;
            $where['endtime'] = array(array('eq',0),array('gt',time()), 'or') ;
            //SELECT * from sh_mall_notice where mall_id = 9 and status = 1 and (endtime = 0 or endtime>1458354366);
            $notice = $mallNoticeModel->where($where)->order('sort desc')->select();
            if (!empty($notice)) {
                $this->ajaxReturn(array('status'=>'1','info'=>$notice,'msg'=>"获取成功"),'JSON');
            } else {
                $this->ajaxReturn(array('status'=>'2','info'=>$notice,'msg'=>"公告不存在"),'JSON');
            }
        }
    }

$where['endtime'] = array(array('eq',0),array('gt',time()), 'or') ;
巧妙的处理了这种逻辑关系。

你可能感兴趣的:(商城公告功能开发总结)