php post插入数据出错,在控制器中解析$ _Post数据并呈现Cgridview时出错 - php

我在将正确的值传递给视图中的网格小部件时遇到问题。使用ajax从jquery传递数据。

这是代码:

$('#find-product').click(function(e) {

e.preventDefault();

alert($('#find-product').data("url"));

/*

* Make the ajax call to send the selected option to the controller for processing

* URL : $('#find-product').data("url") , the path of the controller's action

* Dropdown : the obejct that is passed to the controller

*

* Dropdown.category : the category selected

* Dropdown.price : the price range selected

*

*

*/

$.ajax({

url: $('#find-product').data("url"),

data: {

Dropdown: {

category: $('#supp-category').find(":selected").text(),

price: $('#supp-price').find(":selected").text()

}

},

type: "POST",

error: function(xhr, tStatus, e) {

if (!xhr) {

alert(" We have an error ");

alert(tStatus + " " + e.message);

} else {

alert("else: " + e.message); // the great unknown

}

},

success: function(resp) {

document.location.href = $('#find-product').data("url");

}

})

});

所以我想将名为Dropdown的对象发送到控制器操作。在这种情况下,它的/ products / dropdown。

在actionDropdown()中,我试图形成CDbCriteria并将其传递给CActiveDataProvider,以便可以使用它来呈现网格。

这是ProductsController中的actionDropdown的代码::

public function actionDropdown() {

$criteria = new CDbCriteria;

$criteria->compare('category', $_POST['Dropdown']['category'], true);

$dataProvider = new CActiveDataProvider('Products', array(

'criteria' => $criteria,

));

$this->render('selectproducts', array(

'dataProvider' => $dataProvider,

));

}

这是称为选择产品的视图。

$this->widget('bootstrap.widgets.TbGridView', array(

'id' => 'products-grid',

'dataProvider' => $dataProvider,

'filter' => $dataProvider,

'columns' => array(

'id',

'name',

'category',

'brand',

'weight_unit',

'price_unit',

'flavors',

'providers',

),

));

?>

现在,这给了我一个CException错误。这是错误堆栈跟踪::

CException

CActiveDataProvider and its behaviors do not have a method or closure named "getValidators". (/var/www/html/yii/framework/base/CComponent.php:266)

#0 /var/www/html/yii/framework/web/helpers/CHtml.php(2236): CComponent->__call('getValidators', Array)

#1 /var/www/html/yii/framework/web/helpers/CHtml.php(2236): CActiveDataProvider->getValidators('id')

#2 /var/www/html/yii/framework/web/helpers/CHtml.php(1434): CHtml::activeInputField('text', Object(CActiveDataProvider), 'id', Array)

#3 /var/www/html/EasyAesthetics/protected/extensions/yiibooster/widgets/TbDataColumn.php(109): CHtml::activeTextField(Object(CActiveDataProvider), 'id', Array)

#4 /var/www/html/EasyAesthetics/protected/extensions/yiibooster/widgets/TbDataColumn.php(74): TbDataColumn->renderFilterCellContent()

#5 /var/www/html/yii/framework/zii/widgets/grid/CGridView.php(532): TbDataColumn->renderFilterCell()

#6 /var/www/html/yii/framework/zii/widgets/grid/CGridView.php(510): CGridView->renderFilter()

#7 /var/www/html/yii/framework/zii/widgets/grid/CGridView.php(480): CGridView->renderTableHeader()

#8 /var/www/html/yii/framework/zii/widgets/CBaseListView.php(167): CGridView->renderItems()

#9 [internal function]: CBaseListView->renderSection(Array)

#10 /var/www/html/yii/framework/zii/widgets/CBaseListView.php(150): preg_replace_callback('/{(\w+)}/', Array, '{summary}?{item...')

#11 /var/www/html/yii/framework/zii/widgets/CBaseListView.php(135): CBaseListView->renderContent()

#12 /var/www/html/yii/framework/web/CBaseController.php(173): CBaseListView->run()

#13 /var/www/html/EasyAesthetics/protected/views/products/selectproducts.php(37): CBaseController->widget('bootstrap.widge...', Array)

#14 /var/www/html/yii/framework/web/CBaseController.php(126): require('/var/www/html/E...')

#15 /var/www/html/yii/framework/web/CBaseController.php(95): CBaseController->renderInternal('/var/www/html/E...', Array, true)

#16 /var/www/html/yii/framework/web/CController.php(869): CBaseController->renderFile('/var/www/html/E...', Array, true)

#17 /var/www/html/yii/framework/web/CController.php(782): CController->renderPartial('selectproducts', Array, true)

#18 /var/www/html/EasyAesthetics/protected/controllers/ProductsController.php(248): CController->render('selectproducts', Array)

#19 /var/www/html/yii/framework/web/actions/CInlineAction.php(49): ProductsController->actionDropdown()

#20 /var/www/html/yii/framework/web/CController.php(308): CInlineAction->runWithParams(Array)

#21 /var/www/html/yii/framework/web/filters/CFilterChain.php(133): CController->runAction(Object(CInlineAction))

#22 /var/www/html/yii/framework/web/filters/CFilter.php(40): CFilterChain->run()

#23 /var/www/html/yii/framework/web/CController.php(1145): CFilter->filter(Object(CFilterChain))

#24 /var/www/html/yii/framework/web/filters/CInlineFilter.php(58): CController->filterAccessControl(Object(CFilterChain))

#25 /var/www/html/yii/framework/web/filters/CFilterChain.php(130): CInlineFilter->filter(Object(CFilterChain))

#26 /var/www/html/yii/framework/web/CController.php(291): CFilterChain->run()

#27 /var/www/html/yii/framework/web/CController.php(265): CController->runActionWithFilters(Object(CInlineAction), Array)

#28 /var/www/html/yii/framework/web/CWebApplication.php(282): CController->run('dropdown')

#29 /var/www/html/yii/framework/web/CWebApplication.php(141): CWebApplication->runController('products/dropdo...')

#30 /var/www/html/yii/framework/base/CApplication.php(180): CWebApplication->processRequest()

#31 /var/www/html/EasyAesthetics/index.php(13): CApplication->run()

#32 {main}

我一生都无法找出导致此错误的原因。请提供任何帮助,任何可以使我朝正确方向发展的提示。

提前致谢。

麦克斯

参考方案

问题出在filter中的TbGridView参数。筛选器必须是模型的实例,而不是dataprovider。

$this->widget('bootstrap.widgets.TbGridView', array(

'id' => 'products-grid',

'dataProvider' => $dataProvider,

'filter' => $dataProvider->model, // Simplest way

'columns' => array(

'id',

'name',

'category',

'brand',

'weight_unit',

'price_unit',

'flavors',

'providers',

),

));

或仅将YourModel::model()分配为您的过滤器参数。

PHP:对数组排序 - php

请如何排序以下数组Array ( 'ben' => 1.0, 'ken' => 2.0, 'sam' => 1.5 ) 至Array ( 'ken' => 2.0, 'sam' => 1.5, 'ben' =&…PHP PDO组按列名称查询结果 - php

以下PDO查询返回以下结果:$db = new PDO('....'); $sth = $db->prepare('SELECT ...'); 结果如下: name curso ABC stack CDE stack FGH stack IJK stack LMN overflow OPQ overflow RS…PHP:不推荐使用password_hash的'salt'选项 - php

我正在使用密码哈希进行注册。我需要手动创建Salt,以下是我使用的代码:$options = [ 'cost' => 11, 'salt' => mcrypt_create_iv(22, MCRYPT_DEV_URANDOM) ]; $password = password_hash( $this->…PHP-全局变量的性能和内存问题 - php

假设情况:我在php中运行一个复杂的站点,并且我使用了很多全局变量。我可以将变量存储在现有的全局范围内,例如$_REQUEST['userInfo'],$_REQUEST['foo']和$_REQUEST['bar']等,然后将许多不同的内容放入请求范围内(这将是适当的用法,因为这些数据指的是要求自…PHP strtotime困境 - php

有人可以解释为什么这在我的服务器上输出为true吗?date_default_timezone_set('Europe/Bucharest'); var_dump( strtotime('29.03.2015 03:00', time()) === strtotime('29.03.2015 04:00…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值