gpt4 book ai didi

jquery - Yii2 - 如何使用分页将 JQuery 工具提示添加到 GridView

转载 作者:行者123 更新时间:2023-12-01 01:00:50 24 4
gpt4 key购买 nike

如何向 GridView 中的列数据添加工具提示?它在第一页上有效,但切换到其他页面后,工具提示不起作用。

主布局文件:

\yii\web\JqueryAsset::register($this);
\yii\bootstrap\BootstrapPluginAsset::register($this);
$js = <<< 'SCRIPT'
/* To initialize BS3 tooltips set this below */
$(function () {
$("[data-toggle='tooltip']").tooltip();
});;
/* To initialize BS3 popovers set this below */
$(function () {
$("[data-toggle='popover']").popover();
});
SCRIPT;
// Register tooltip/popover initialization javascript
$this->registerJs($js);

View 中的代码:

[   'class' => '\kartik\grid\DataColumn',
'attribute'=>'default_rate_id',
'value'=>function($data) {
if(isset($data->rate->code)) {
return Html::tag('div', $data->rate->code, ['data-toggle'=>'tooltip','data-placement'=>'left','title'=>$data->rate->name,'style'=>'cursor:default;']);
} else {
return '';
}
},
'width' => '60px',
'filterType'=>GridView::FILTER_SELECT2,
'filterWidgetOptions'=>[
'pluginOptions' =>['allowClear' =>true],
'data' => $this->listRateCodes(),
],
'filterInputOptions' =>['placeholder' =>' '],
'format'=>'raw',
],

解决方案:

感谢@arogachev,我已将主布局文件中的相应部分更新为如下。工具提示现在显示在 GridView 的每个页面上。

$js = <<< 'SCRIPT'
/* To initialize BS3 tooltips set this below */
$('body').tooltip({selector: '[data-toggle="tooltip"]'});
/* To initialize BS3 popovers set this below */
$('body').popover({selector: '[data-toggle="popover"]'});
SCRIPT;
// Register tooltip/popover initialization javascript
$this->registerJs($js);

最佳答案

发生这种情况是因为在这种情况下,GridView 的内容是动态的,并且会随着每个 AJAX 请求而更改。在第一页加载时它可以工作,因为什么都没有改变,但是一旦内容改变它就不会了。

解决方案是使用jQuery更改指定工具提示的方式:

$('body').tooltip({
selector: '[data-toggle="tooltip"]'
});

查看这些相关问题:

关于jquery - Yii2 - 如何使用分页将 JQuery 工具提示添加到 GridView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28146311/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com