成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

layui實(shí)現(xiàn)動態(tài)和靜態(tài)數(shù)據(jù)表分頁

caige / 2332人閱讀

開發(fā)管理后臺是每一個開發(fā)人員都要熟悉的一個環(huán)節(jié),作為后端程序員,公司的所有機(jī)密數(shù)據(jù)都掌握在我們手上,所以這個時候,如果不是公司的核心成員,是不能接觸到某些數(shù)據(jù)的,這個時候所有的工作都落到了我們的手上,從PS到Linux都需要我們親歷親為,還好發(fā)現(xiàn)了layui這個前端框架,很大程度上減輕了我們的壓力.

今天我們先來學(xué)習(xí)一下layui實(shí)現(xiàn)動態(tài)數(shù)據(jù)表,靜態(tài)數(shù)據(jù)表,以及表格的分頁,其中還涉及到動態(tài)刷新數(shù)據(jù)表,數(shù)據(jù)表工具欄使用,表單提交等功能,這個靜態(tài)分頁同樣適用在信息類網(wǎng)站,我的工作開發(fā)環(huán)境是debian桌面版,所以所有的實(shí)驗(yàn)也是在debian基礎(chǔ)上測試

layui動態(tài)數(shù)據(jù)表 動態(tài)數(shù)據(jù)表的效果圖

實(shí)現(xiàn)過程

業(yè)務(wù)邏輯我都寫到注釋里面了,這樣大家也友好一些,避免一會看代碼,一會看說明容易分神

前端代碼:

head.phtml(頭文件代碼)




    
    
    <?php echo $curTitle;?>
    
    
    
    
    
    
    
    
    
    


order_orderlist.phtml(主體業(yè)務(wù)代碼)

import("head"); ?>
注意:為保障訪問速度,查詢同時請配合時間范圍,默認(rèn)顯示一天以內(nèi)的記錄

-

后端php代碼

order.php(訂單控制器,部分業(yè)務(wù)代碼不用太深究)

    // 訂單列表
    public function orderList()
    {
        // 動態(tài)渲染前臺表格
        $operating = $this->request->getPost("getlist", "trim");
        // 首次這里不會執(zhí)行,數(shù)據(jù)表開始渲染的時候才會請求以下部分
        if ("orderlist" === $operating) {
            // 進(jìn)行分頁查詢
            $page = $this->request->getPost("page", "intval", 1);
            $limit = $this->request->getPost("limit", "intval", 10);
            $start = ($page - 1) * $limit;

            // 如果有其他條件查詢在這里可以帶上
            $merchant_no = $this->request->getPost("merchant_no", "trim", "");
            $order_no = $this->request->getPost("order_no", "trim", "");
            $start_time = $this->request->getPost("start_time", "trim", date("Y-m-d H:i:s", strtotime("-1 day")));
            $end_time = $this->request->getPost("end_time", "trim", date("Y-m-d H:i:s"), time());

            // 獲取符合條件的記錄數(shù)量
            if($GLOBALS["SESSION"]["admin_group_id"] >1){
                $merchant_no = $GLOBALS["SESSION"]["admin_username"];
            }
            $order_nums = orders::getItemNums($merchant_no, $order_no, $start_time, $end_time);

            // 分頁進(jìn)行查詢條件記錄
            $order_list = orders::getItem($merchant_no, $order_no, $start_time, $end_time, $start, $limit);
            $datas = ["code" => 0, "msg" => ""];
            // 將總的記錄條數(shù)傳給前臺進(jìn)行渲染分頁
            $datas["count"] = $order_nums;
            // 重新過濾一遍數(shù)據(jù),很多沒有用到的不能全部發(fā)給試圖,尤其是動態(tài)渲染的,很容易暴露,建議加工一下再傳
            foreach ($order_list as $k => $v) {
                $order_list[$k]["orderno"] = $v["order_id"];
                $order_list[$k]["user_orderno"] = $v["order_no"];
                $order_list[$k]["username"] = $v["merchant_no"];
                $order_list[$k]["pay_type"] = ($v["pay_type"] == 1) ? "支付寶掃碼" : "微信掃碼";
                $order_list[$k]["pay_status"] = ($v["callback_status"] > 0) ? "已支付" : "未支付";
                $order_list[$k]["pay_time"] = $v["callback_time"];
                $order_list[$k]["notice_result"] = ($v["push_status"] > 0) ? "已推送" : "未推送";
            }
            // 將數(shù)據(jù)通過json格式響應(yīng)給前臺渲染
            $datas["data"] = $order_list;
            echo json_encode($datas);
            safe_exit();
        }
        // 首次先現(xiàn)實(shí)模板頁
        self::$view->render("orders_orderlist");
    }

數(shù)據(jù)格式請參照官方指導(dǎo):數(shù)據(jù)接口格式,表格模塊
調(diào)試的時候可以打開chrome,firefoxconsolenetwork進(jìn)行查看,仔細(xì)研究分析

數(shù)據(jù)表工具條事件

工具欄是指在行單元格內(nèi)可以操作對應(yīng)的行,因?yàn)槭褂?b>layui的元素監(jiān)聽,很容易就獲取到相應(yīng)對應(yīng)整行的數(shù)據(jù).
比如獲取表單的數(shù)據(jù),只需要監(jiān)聽表單提交事件,直接就可以一次獲取到所有的參數(shù)和值:


這里是官方文檔的:

form.on("submit(*)", function(data){
  console.log(data.elem) //被執(zhí)行事件的元素DOM對象,一般為button對象
  console.log(data.form) //被執(zhí)行提交的form對象,一般在存在form標(biāo)簽時才會返回
  console.log(data.field) //當(dāng)前容器的全部表單字段,名值對形式:{name: value}
  return false; //阻止表單跳轉(zhuǎn)。如果需要表單跳轉(zhuǎn),去掉這段即可。
});

我們今天要操作的數(shù)據(jù)表也是要采用這種方式,首先我們看看看怎樣生成和渲染出工具條:

只需要在body部分插入一個容器,注意這里的javascripttypetext/html,這個是供layui解析用的,在這里的d也就是我們在渲染表格的時候的數(shù)據(jù),所有的字段的值都可以在這個d里面獲取到

    
 // 這里就是我們渲染表格字段的地方,和上面的容器進(jìn)行綁定,容器里面可以通過d.fixed來獲取到
 {fixed: "right", width:158,title:"操作", align:"center", toolbar: "#barDemo"}

然后我們就可以對工具條綁定事件了,這里我只使用了編輯事件

table.on("tool(fucktest)", function(obj){ //注:tool是工具條事件名,test是table原始容器的屬性 lay-filter="對應(yīng)的值"
            var data = obj.data; //獲得當(dāng)前行數(shù)據(jù)
            var layEvent = obj.event; //獲得 lay-event 對應(yīng)的值(也可以是表頭的 event 參數(shù)對應(yīng)的值)
            var tr = obj.tr; //獲得當(dāng)前行 tr 的DOM對象

            if(layEvent === "detail"){ //查看
                //do somehing
            } else if(layEvent === "del"){ //刪除
                layer.confirm("真的刪除行么", function(index){
                    obj.del(); //刪除對應(yīng)行(tr)的DOM結(jié)構(gòu),并更新緩存
                    layer.close(index);
                    //向服務(wù)端發(fā)送刪除指令
                });
            } else if(layEvent === "edit"){ //編輯
                    // 開始根據(jù)用戶id來進(jìn)行獲取用戶進(jìn)入新窗口
                var index = layer.open({
                    type: 2,
                    title:"編輯管理員",
                    area: ["700px", "560px"],
                    maxmin: true,
                    content: "index.php?c=adminUser&a=editUser&uid="+data.admin_id
                });
                layer.full(index);

            }
        })

這樣在點(diǎn)擊編輯之后就能激活對應(yīng)的事件了,我們這里是打開新的一個全屏彈窗來修改管理員資料

在修改完成后,如果只是單純的重載數(shù)據(jù)表可以使用我們前面使用的方式,如果是刷新頁面直接使用location.reload()

       // 重載數(shù)據(jù)表
       var active = {
            reload:function(){
                var demoReload = $("#demoReload");
                var dateReload = $("#dateReload");
                table.reload("testReload",{
                    where:{
                        username:demoReload.val(),
                        dates:dateReload.val()
                    }
                });
            }
        };
        $("#fresh-btn").click(function(){active.reload();});
        $("#fresh-page-btn").click(function(){location.reload();});

這里是官方的例子 toolbar-綁定列工具條

toolbar 對應(yīng)的模板,它可以存放在頁面的任意位置:

  
 
注意:屬性 lay-event="" 是模板的關(guān)鍵所在,值可隨意定義。

渲染工具條:

table.render({
  cols: [[
    {field:"id", title:"ID", width:100}
    ,{fixed: "right", width:150, align:"center", toolbar: "#barDemo"} //這里的toolbar值是模板元素的選擇器
  ]]
});
 
等價于:
ID

工具條綁定事件:

//監(jiān)聽工具條
table.on("tool(test)", function(obj){ //注:tool是工具條事件名,test是table原始容器的屬性 lay-filter="對應(yīng)的值"
  var data = obj.data; //獲得當(dāng)前行數(shù)據(jù)
  var layEvent = obj.event; //獲得 lay-event 對應(yīng)的值(也可以是表頭的 event 參數(shù)對應(yīng)的值)
  var tr = obj.tr; //獲得當(dāng)前行 tr 的DOM對象
 
  if(layEvent === "detail"){ //查看
    //do somehing
  } else if(layEvent === "del"){ //刪除
    layer.confirm("真的刪除行么", function(index){
      obj.del(); //刪除對應(yīng)行(tr)的DOM結(jié)構(gòu),并更新緩存
      layer.close(index);
      //向服務(wù)端發(fā)送刪除指令
    });
  } else if(layEvent === "edit"){ //編輯
    //do something
    
    //同步更新緩存對應(yīng)的值
    obj.update({
      username: "123"
      ,title: "xxx"
    });
  }
});

更加詳細(xì)的介紹請仔細(xì)研讀官方文檔 layui table模塊

靜態(tài)表格和分頁
在很多時候在pc端過多的使用動態(tài)渲染不是一個明智的選擇,比如稍微懂行的人都能看到你的API和需要的param,所以我們還是建議對安全要求比較高的程序上還是使用靜態(tài)表格,通過模板引擎也好,還是直接使用使用后端動態(tài)語言混合,用戶最終只能看到解析好的頁面,對程序保護(hù)也是很有必要的,我的一個hacker朋友在進(jìn)行滲透的時候都是這樣進(jìn)行鉆空子的

靜態(tài)表格我這里直接是使用php混合解析進(jìn)行展示:
前端模板:

index.php

import("head");?>

注意:此處僅顯示部分日志
$vv):?>
日志ID 操作用戶 操作 控制器 方法 是否成功 操作IP 備注信息 日期
import("foot");?>

這里的原理非常簡單,主要利用的是layui下的laypage模塊,使用jump來觸發(fā)事件

adminLogList方法:

   public function adminLogList()
    {   // 接收當(dāng)前頁,如果沒有收到默認(rèn)是第一頁
        $page = $this->request->getGet("page","intval",1);
        // 設(shè)置limit查找起始,DEFAULT_PER_PAGE為全局變量,設(shè)置的是每頁顯示10條
        $start = ($page-1)*DEFAULT_PER_PAGE;
        // 獲取總?cè)罩緮?shù)量
        $adminlog_num = adminLogs::getItemsNumber();
        // 分頁查找,其他查詢條件暫時不傳
        $admin_log_list = adminLogs::getItems("","","","","",$start);
        $log_list = array();
        foreach($admin_log_list as $kk => $vv){
            if($vv["admin_id"] > 0){
                try{
                    $admins = admins::getItemById($vv["admin_id"]);
                    $log_list[$kk]["username"] = $admins["username"];
                } catch (exception2 $e){
                    logexception($e->format_stack_trace());
                }
            } else {
                $log_list[$kk]["username"] = "Tourists";
            }
            $log_list[$kk]["log_id"] = $vv["log_id"];
            $log_list[$kk]["control"] = $vv["control"];
            $log_list[$kk]["action"] = $vv["action"];
            $log_list[$kk]["is_success"] = $vv["is_success"];

            $log_list[$kk]["client_ip"] = ip2location($vv["client_ip"]);
            $log_list[$kk]["remark"] = $vv["remark"];
            $log_list[$kk]["date"] = $vv["date"];
            $log_list[$kk]["title"] = $vv["title"];
            unset($admin_log_list[$kk]);
        }
        self::$view->setVar("currpage",$page);
        self::$view->setVar("log_num",$adminlog_num);
        self::$view->setVar("log_list",$log_list);
        self::$view->render("default_addloglist");
    }

最終效果,已經(jīng)完成靜態(tài)分頁,此部分功能也適用于信息類網(wǎng)站:

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/94662.html

相關(guān)文章

  • layui實(shí)現(xiàn)動態(tài)靜態(tài)數(shù)據(jù)表分頁

    開發(fā)管理后臺是每一個開發(fā)人員都要熟悉的一個環(huán)節(jié),作為后端程序員,公司的所有機(jī)密數(shù)據(jù)都掌握在我們手上,所以這個時候,如果不是公司的核心成員,是不能接觸到某些數(shù)據(jù)的,這個時候所有的工作都落到了我們的手上,從PS到Linux都需要我們親歷親為,還好發(fā)現(xiàn)了layui這個前端框架,很大程度上減輕了我們的壓力. 今天我們先來學(xué)習(xí)一下layui實(shí)現(xiàn)動態(tài)數(shù)據(jù)表,靜態(tài)數(shù)據(jù)表,以及表格的分頁,其中還涉及到動態(tài)刷新數(shù)據(jù)...

    Songlcy 評論0 收藏0
  • layui數(shù)據(jù)表格使用(一:基礎(chǔ)篇,數(shù)據(jù)展示、分頁組件、表格內(nèi)嵌表單圖片)

    摘要:表格展示神器之一表格前言在寫后臺管理系統(tǒng)中使用最多的就是表格數(shù)據(jù)展示了,使用表格組件能提高大量的開發(fā)效率,目前主流的數(shù)據(jù)表格組件有等博主個人比較傾向于,極簡,卻又不失飽滿的內(nèi)在,體積輕盈,組件豐盈。 表格展示神器之一:layui表格 前言:在寫后臺管理系統(tǒng)中使用最多的就是表格數(shù)據(jù)展示了,使用表格組件能提高大量的開發(fā)效率,目前主流的數(shù)據(jù)表格組件有bootstrap table、layui ...

    番茄西紅柿 評論0 收藏0
  • fsLayuiPlugin數(shù)據(jù)字典使用

    摘要:概述數(shù)據(jù)字典主要解決下拉框數(shù)據(jù)填充和數(shù)據(jù)表格轉(zhuǎn)義處理,一個數(shù)據(jù)字典可以多處使用。通過服務(wù)端異步請求加載數(shù)據(jù)列表。 概述 數(shù)據(jù)字典主要解決下拉框數(shù)據(jù)填充和數(shù)據(jù)表格轉(zhuǎn)義處理,一個數(shù)據(jù)字典可以多處使用。 1.多個頁面下拉框使用同樣的數(shù)據(jù),改一個地方需要把所有頁面都要修改 2.數(shù)據(jù)表格轉(zhuǎn)義代替自己手動寫templet解析模板數(shù)據(jù)字典提供一個通用的處理方式,支持配置靜態(tài)數(shù)據(jù)字典和動態(tài)數(shù)據(jù)...

    yhaolpz 評論0 收藏0
  • fsLayuiPlugin數(shù)據(jù)字典使用

    摘要:概述數(shù)據(jù)字典主要解決下拉框數(shù)據(jù)填充和數(shù)據(jù)表格轉(zhuǎn)義處理,一個數(shù)據(jù)字典可以多處使用。通過服務(wù)端異步請求加載數(shù)據(jù)列表。 概述 數(shù)據(jù)字典主要解決下拉框數(shù)據(jù)填充和數(shù)據(jù)表格轉(zhuǎn)義處理,一個數(shù)據(jù)字典可以多處使用。 1.多個頁面下拉框使用同樣的數(shù)據(jù),改一個地方需要把所有頁面都要修改 2.數(shù)據(jù)表格轉(zhuǎn)義代替自己手動寫templet解析模板數(shù)據(jù)字典提供一個通用的處理方式,支持配置靜態(tài)數(shù)據(jù)字典和動態(tài)數(shù)據(jù)...

    sunny5541 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<