我试图在CakePHP项目的编辑页面上实现SlickGrid,当页面加载时,我在javascript控制台中得到以下错误:
slick.grid.js:2173TypeError:'Slick.Editors.Text is not a constructor' (evaluating 'new (editor || getEditor(activeRow, activeCell))')数据正确地呈现在我页面的网格中,但当我单击一个单元格进行编辑时,它就变成了白色,并且我不能键入任何内容。如果我单击另一个单元格,该单元格将变为白色,而第一个单元格将保持白色。
下面是我的php/jQuery代码:
<?php echo $this->Html->script("/js/slickgrid/lib/jquery-1.7.min.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/lib/jquery.event.drag-2.0.min.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/lib/jquery-ui-1.8.16.custom.min.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/slick.core.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/slick.grid.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/slick.editors.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/slick.formatters.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/slick.dataview.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/plugins/slick.cellselectionmodel.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/plugins/slick.cellrangedecorator.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/plugins/slick.cellrangeselector.js"); ?>
<?php echo $this->Html->script("/js/slickgrid/plugins/slick.rowselectionmodel.js"); ?>
<?php // Setup rows and cols array for grid
$columns = array();
foreach($route['Stop'] as $stop) {
$columns[] = array( "name" => $stop['name'],
"field" => $stop['id'],
"id" => $stop['id'],
"editor" => "Slick.Editors.Text");
}
$tripId = 1;
$thisTrip['id'] = $tripId;
foreach($route['RouteTrip'] as $routeTrip) {
if($routeTrip['trip_id'] != $tripId) {
$rows[] = $thisTrip;
$tripId = $routeTrip['trip_id'];
$thisTrip['id'] = $tripId;
}
else {
$thisTrip[$routeTrip['stop_id']] = $routeTrip['time'];
}
}
?>
<?php
echo $this->Html->scriptBlock('
var rows = '.json_encode($rows).';
var columns = '.json_encode($columns).';
var options = { rowHeight:21,
defaultColumnWidth:100,
editable:true,
enableAddRow:true,
enableCellNavigation:true,
asyncEditorLoading:false,
autoHeight:true,
autoEdit:true
};
slickgrid = new Slick.Grid($("#scheduleTable"), rows, columns, options);
slickgrid.setSelectionModel(new Slick.CellSelectionModel());
slickgrid.updateRowCount();
slickgrid.render();
');
?>编辑器和编辑器的格式是正确的,并且每列都有一个“$rows”属性,其值为"Slick.Editors.Text“。
帮助?
发布于 2012-06-13 11:28:20
当我开始使用slickgrid时,我也得到了这个错误。
错误是因为您已将编辑器指定为字符串而不是类。因此,删除"editor“=> "Slick.Editors.Text”中的双引号,并将其命名为"editor“=> Slick.Editors.Text
这为我解决了这个错误。希望这个解决方案也能解决你的问题。
发布于 2012-06-05 15:36:51
包括slick.editors.js文件。
另外,请确保编辑器被指定为一个类,而不是一个字符串(我不熟悉PHP,因此从源代码看这一点对我来说并不明显,但我怀疑是这样的)。
https://stackoverflow.com/questions/10891043
复制相似问题