jquery.jqGrid.min.js не работает - PullRequest
       2

jquery.jqGrid.min.js не работает

2 голосов
/ 19 декабря 2010

Я использовал 3.8.2 JQGrid файл jquery.jqGrid.min.js, который является только необходимым файлом со всеми модулями в нем, который будет выбран оттуда при загрузке, который не работает с одной из ошибок =}) .navGrid не является функцией.

Я тогда скачал папку tonytomov-jqGrid-c3a2a2d из http://github.com/tonytomov/jqGrid/tree/master и использовал ее, которая имеет путь ко всем модулям, находящимся в папке js и работает нормально. Ниже приведен файл jquery.jqGrid.js из github. Я знаю, что jquery.jqGrid.js предназначен для разработки, но jquery.jqGrid.min.js у меня вообще не работает.

Почему это? Я много экспериментировал и вот что я нашел. Может быть, я что-то упустил.

//This file should be used if you want to debug and develop
function jqGridInclude()
{
    var pathtojsfiles = "/Scripts/js/"; // need to be ajusted
    // set include to false if you do not want some modules to be included
    var modules = [
        { include: true, incfile:'i18n/grid.locale-en.js'}, // jqGrid translation
        { include: true, incfile:'grid.base.js'}, // jqGrid base
        { include: true, incfile:'grid.common.js'}, // jqGrid common for editing
        { include: true, incfile:'grid.formedit.js'}, // jqGrid Form editing
        { include: true, incfile:'grid.inlinedit.js'}, // jqGrid inline editing
        { include: true, incfile:'grid.celledit.js'}, // jqGrid cell editing
        { include: true, incfile:'grid.subgrid.js'}, //jqGrid subgrid
        { include: true, incfile:'grid.treegrid.js'}, //jqGrid treegrid
        { include: true, incfile:'grid.grouping.js'}, //jqGrid grouping 
        { include: true, incfile:'grid.custom.js'}, //jqGrid custom 
        { include: true, incfile:'grid.postext.js'}, //jqGrid postext
        { include: true, incfile:'grid.tbltogrid.js'}, //jqGrid table to grid
        { include: true, incfile:'grid.setcolumns.js'}, //jqGrid setcolumns
        { include: true, incfile:'grid.import.js'}, //jqGrid import
        { include: true, incfile:'jquery.fmatter.js'}, //jqGrid formater
        { include: true, incfile:'JsonXml.js'}, //xmljson utils
        { include: true, incfile:'grid.jqueryui.js'}, //jQuery UI utils
        { include: true, incfile:'jquery.searchFilter.js'} // search Plugin
    ];
    var filename;
    for(var i=0;i<modules.length; i++)
    {
        if(modules[i].include === true) {
            filename = pathtojsfiles+modules[i].incfile;
            if(jQuery.browser.safari) {
                jQuery.ajax({url:filename,dataType:'script', async:false, cache: true});
            } else {
                if (jQuery.browser.msie) {
                    document.write('<script charset="utf-8" type="text/javascript" src="'+filename+'"></script>');
                } else {
                    IncludeJavaScript(filename);
                }
            }
        }
    }
    function IncludeJavaScript(jsFile)
    {
        var oHead = document.getElementsByTagName('head')[0];
        var oScript = document.createElement('script');
        oScript.setAttribute('type', 'text/javascript');
        oScript.setAttribute('language', 'javascript');
        oScript.setAttribute('src', jsFile);
        oHead.appendChild(oScript);
    }
}
jqGridInclude();

// My Js

jQuery().ready(function () {
    var lastSel;
    jQuery("#sandgrid").jqGrid({
        url: '/JQSandbox/MyGridData/',
        datatype: 'json',
        mtype: 'POST',
        height: 255,
        width: 640,
        colNames: ['Index', 'Name', 'City', 'State'],
        colModel: [
                { name: 'companyID', index: 'companyID', width: 5 },
                { name: 'companyName', index: 'companyName', width: 30 },
                { name: 'companyCity', index: 'companyCity', width: 30 },
                { name: 'companyState', index: 'companyState', width: 4, sortable: false}],

        pager: jQuery('#sandgridp'),
        rowNum: 5,
        rowList: [5, 10, 20, 50],
        sortname: 'companyID',
        sortorder: "desc",
        viewrecords: true,
        altRows: true,
        caption: 'Sandbox Grid',
        ondblClickRow: function (id) {
            if (id && id !== lastSel) {
                jQuery('#sandgrid').restoreRow(lastSel);
                lastSel = id;
                alert("You've seleted " + id);
            }
        },
        subGrid: true,
        subGridUrl: '/JQSandbox/MySubGridData/',
        subGridModel: [
        {
            name: ['Name', 'Department', 'Hire Date', 'Supervisor'],
            width: [80, 20, 80, 10],
            align: ['left', 'left', 'left', 'center'],
            params: ['companyID']
        }]
    }).navGrid('#sandgridp', { edit: false, add: false, del: false });

});

1 Ответ

3 голосов
/ 19 декабря 2010

Как можно увидеть в комментарии jquery.jqGrid.min.js

Модули: grid.base.js;jquery.fmatter.js;grid.custom.js;grid.common.js;jquery.searchFilter.js;grid.inlinedit.js;grid.celledit.js;jqModal.js;jqDnR.js;grid.subgrid.js;grid.grouping.js;grid.treegrid.js;grid.import.js;JsonXml.js;grid.setcolumns.js;grid.postext.js;grid.tbltogrid.js;grid.jqueryui.js;

Вы выбрали все модули jqGrid за исключением grid.formedit.js.На странице загрузки jqGrid она называется «Редактирование формы» (см. Группу «Редактирование»).Я протестировал и теперь могу загрузить все модули со страницы загрузки jqGrid .Так что это не должно быть технической проблемой.

Так что вам нужно просто скачать jqGrid еще раз, и у вас не возникнет проблем с использованием navGrid в jquery.jqGrid.min.js.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...