0

デザイナーとして、私は、表示するデータがない場合にユーザーに行動を促す美しい「空の状態」メッセージの概念の大ファンです。(実際、これ専用の tumblr ブログ全体があります: http://emptystat.es/ )

Flexigrid の幸せで献身的なユーザーとして、私が構築しているシステムにグリッドに表示する検索結果がない場合、空の状態のメッセージを代用できるようにしたいと考えています (たとえば、「保留中のリクエストはありません。 ! [新規] をクリックして開始します。")。理想的には、このような空の状態のメッセージはグラフィックであり、個々の行よりも大きく、グリッドの内容全体を置き換えます。行が返されない場合に、フレキシグリッドの内容をグラフィックの空の状態メッセージに置き換える方法について、誰かアドバイスをいただけますか?

ありがとう!

4

2 に答える 2

0
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>Flexigrid</title>
    <link rel="stylesheet" type="text/css" href="../css/flexigrid.css">
    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
    <script type="text/javascript" src="../js/flexigrid.js"></script>
    </head>
    <body>
    <p>This is a sample implementation attached to a form, to add additional parameters.</p>

    <form id="sform">
        <p>
        The values you entered will be place in name column for demo's sake.<br />
        Value 1 : <input type="text" name="val1" value="" autocomplete="off" /><br />
         Value 2 : Is a hidden input with value 3<input type="hidden" name="val2" value="3" /><br />
         Value 3 : 
         <select name="val3">
            <option value="1">One</option>
              <option value="2">Two</option>
              <option value="3">Three</option>
              <option value="4">Four</option>
              <option value="5">Five</option>
         </select><br />
         Value 4 : <input type="checkbox" name="val4" id="val4" value="4" /><label for="val4">This will pass a value 4 if checked</label>
         </p>
         <p>
             <input type="submit" value="Submit" />
         </p>
    </form>
    <button onclick=hide()>HIDE</button>
    <button onclick=show()>SHOW</button>
    <table id="empty1" style="display:none">
    <tr><td><b>Please</b> <u>fill some</u> data</td></tr>
    </table>
    <table id="flex1" style="display:block">
    <tr><td>1</td></tr>
    <tr><td>2</td></tr>
    <tr><td>3</td></tr>
    </table>
    <script type="text/javascript">
    var old = undefined
    function hide() {
        if (old == undefined) {
            old = flex1.innerHTML
            flex1.innerHTML = empty1.innerHTML
        }
    }
    function show() {
        if (old != undefined) {
            flex1.innerHTML = old
            old = undefined
        }
    }
    $("#flex1").flexigrid({
        url: 'post2.php',
        dataType: 'json',
        colModel : [
            {display: 'ISO', name : 'iso', width : 40, sortable : true, align: 'center'},
            {display: 'Name', name : 'name', width : 180, sortable : true, align: 'left'},
            {display: 'Printable Name', name : 'printable_name', width : 120, sortable : true, align: 'left'},
            {display: 'ISO3', name : 'iso3', width : 130, sortable : true, align: 'left', hide: true},
            {display: 'Number Code', name : 'numcode', width : 80, sortable : true, align: 'right'}
            ],
        searchitems : [
            {display: 'ISO', name : 'iso'},
            {display: 'Name', name : 'name', isdefault: true}
            ],
        sortname: "iso",
        sortorder: "asc",
        usepager: true,
        title: 'Countries',
        useRp: true,
        rp: 15,
        showTableToggleBtn: true,
        width: 700,
        onSubmit: addFormData,
        height: 200
    });

    //This function adds paramaters to the post of flexigrid. You can add a verification as well by return to false if you don't want flexigrid to submit           
    function addFormData(){
        //passing a form object to serializeArray will get the valid data from all the objects, but, if the you pass a non-form object, you have to specify the input elements that the data will come from
        var dt = $('#sform').serializeArray();
        $("#flex1").flexOptions({params: dt});
        return true;
    }

    $('#sform').submit(function (){
        $('#flex1').flexOptions({newp: 1}).flexReload();
        return false;
    });
    </script>
    </body>
    </html>
于 2013-10-23T17:33:04.053 に答える
0

サイトですでにこのフレームワークを使用していたため、dojo を使用してこれを解決しました。さまざまなライブラリに同様のソリューションがあると確信しています。基本的に、フレキシグリッドを作成した後、フレキシグリッドにデータがない場合に通知し、指定されている場合はテーブルに背景画像を配置する新しいクラスを作成しました。

dojo.provide("app.components.EmptyStateFlexigrid");
dojo.require("dijit._Widget");

// Provides a custom Flexigrid with an empty-state
dojo.declare("app.components.EmptyStateFlexigrid", [dijit._Widget], {
    emptyStateUrl: null,
    id: null,
    url: null,
    colModel: null,
    buttons: null,
    sortField: null,
    sortOrder: null,
    height: null,
    usePager: null,
    resizable: null,

    // Create the flexigrid object
    makeGrid: function() {
        var gridObj = $('#' + this.id + "_flexigrid");
        gridObj.flexigrid({
            url: this.url,
            dataType : 'json',
            colModel : this.colModel,
            buttons : this.buttons,
            sortname : this.sortField,
            sortorder : this.sortOrder,
            height: this.height,
            usepager : this.usePager,
            resizable: this.resizable,
            onSuccess: this.checkEmptyState,
            useRp : true,
            rpOptions: [2, 10, 15, 20, 30, 50],
            rp : 15,
            showTableToggleBtn : false
        });
    }
},

// EMPTY-STATE: make a nice graphic here if there is no data
// Note that "this" is a flexigrid object
checkEmptyState: function() {
    var self = dijit.byId(this.id);
    var gridObj = $('#' + this.id + "_flexigrid");
    if (gridObj[0].id === this.id + '_flexigrid') {
        var gridChildren = gridObj.children();
        if (gridChildren.length === 0) {
            var gblocks = $(".gBlock");
            for (var i = 0; i < gblocks.length; i++) {
                var styleObj = gblocks[i].style;
                // The only way I could find to identify "our" flexigrid (if there is
                // more than one on the page) is to test to see if the height is the
                // same as our height. Kind of a lousy hack, but the best I could figure
                // out. -pbanka
                if (styleObj.height == self.height + 'px') {
                    styleObj.backgroundSize = "450px";
                    styleObj.backgroundRepeat = "no-repeat";
                    styleObj.backgroundImage = "url('" + self.emptyStateUrl + "')";
                }
            }
        }
    }
},
于 2013-10-23T18:00:18.330 に答える