信息发布→ 登录 注册 退出

Yii2 GridView URL参数清理与优化教程

发布时间:2025-11-05

点击量:

yii2 gridview url参数清理与优化教程

本教程旨在解决Yii2 GridView在使用自定义过滤器后,URL中出现大量空查询参数的问题。我们将通过覆盖并修改Yii2 GridView的J*aScript资源文件,并在应用配置中调整AssetManager,实现自动移除未填充的URL参数,从而优化URL的整洁性和可读性,避免直接修改vendor目录文件,确保项目维护性和升级的便利性。

引言:URL参数清理的重要性

在使用Yii2的GridView组件结合自定义过滤器时,我们经常会遇到一个问题:即使某些过滤器字段未填写,其对应的空参数仍然会出现在浏览器URL中,例如:localhost:20024/consignment?fid=&post_code=&pud2_mrn=&pud2_status=PUDP&pud_status=&...。这种包含大量空参数的URL不仅冗长、不美观,可能对用户体验造成影响,也可能在某些情况下对搜索引擎优化(SEO)或服务器日志分析带来不便。本教程将提供一种优雅的解决方案,通过修改Yii2 GridView的默认行为,在请求发送前自动移除这些无用的空参数。

核心解决方案:覆盖并修改GridView的J*aScript资产

Yii2 GridView的过滤逻辑主要由其前端J*aScript文件 yii.gridView.js 控制。为了实现参数清理,我们需要修改这个文件中的 applyFilter 方法。为了避免直接修改 vendor 目录下的核心文件(这会导致在Yii更新时被覆盖),我们将采取“覆盖”策略。

步骤一:复制并自定义 yii.gridView.js

首先,将Yii2核心库中的 yii.gridView.js 文件复制到您的项目 web 目录下的自定义位置,例如 web/js/custom。

源文件路径:vendor/yiisoft/yii2/assets/yii.gridView.js

目标路径示例:web/js/custom/yii.gridView.js

步骤二:修改 applyFilter 方法以移除空参数

打开您刚刚复制到 web/js/custom/yii.gridView.js 的文件。找到 applyFilter 方法。在该方法内部,您会找到一行类似 var pos = settings.filterUrl.indexOf('?'); 的代码。

在这行代码之前,插入以下J*aScript代码片段:

// ... 其他代码 ...

/**
 * Applies the filter to the grid.
 * @param {object} settings the grid filter settings.
 * @param {string} settings.filterUrl the URL to send the filter request to.
 * @param {string} settings.filterSelector the selector for the filter form.
 */
var applyFilter = function (settings) {
    var $form = $(settings.filterSelector);
    var data = $form.serializeArray();

    // --- 在此处插入代码以移除空参数 ---
    $.each(data, function (index, obj) {
        if (obj.value.length === 0) {
            data[index] = null; // 将空值的参数设置为null
        }
    });
    // 过滤掉所有null项
    data = $.grep(data, function(n){ return n !== null; });
    // --- 插入代码结束 ---

    var pos = settings.filterUrl.indexOf('?');
    var url = pos < 0 ? settings.filterUrl : settings.filterUrl.substring(0, pos);

    // ... 后续代码 ...
};

// ... 其他代码 ...

代码解释:

VALL-E VALL-E

VALL-E是一种用于文本到语音生成 (TTS) 的语言建模方法

VALL-E 134 查看详情 VALL-E
  • $form.serializeArray() 会将表单数据序列化为一个对象数组,每个对象包含 name 和 value 属性。
  • $.each(data, function (index, obj) { ... }) 遍历这个数组。
  • if (obj.value.length === 0) 检查当前参数的值是否为空字符串。
  • data[index] = null; 将值为空的参数项设置为 null。
  • data = $.grep(data, function(n){ return n !== null; }); 这一行至关重要,它会从 data 数组中移除所有值为 null 的项,从而有效地删除了空参数。

步骤三:配置 AssetManager 使用自定义文件

最后一步是告诉Yii2您的应用程序应该使用您自定义的 yii.gridView.js 文件,而不是Yii核心库中的默认文件。这通过修改您的应用程序配置文件(通常是 config/web.php 或 config/main.php)中的 assetManager 组件来完成。

在您的配置文件中找到 components 数组,并添加或修改 assetManager 配置,如下所示:

return [
    // ... 其他配置 ...
    'components' => [
        // ... 其他组件配置 ...
        'assetManager' => [
            'bundles' => [
                'yii\grid\GridViewAsset' => [
                    'sourcePath' => '@webroot/js/custom', // 指向您自定义js文件的目录
                    'basePath' => '@webroot/js/custom',   // 同上
                    'baseUrl' => '@web/js/custom',        // 通过web访问的URL路径
                    'js' => [
                        'yii.gridView.js',                // 指定自定义的js文件名
                    ],
                ],
            ],
        ],
        // ... 其他组件配置 ...
    ],
    // ... 其他配置 ...
];

配置解释:

  • 'yii\grid\GridViewAsset':这是Yii2 GridView组件使用的资产包的类名。我们通过配置这个类来覆盖其默认行为。
  • 'sourcePath' 和 'basePath':这两个参数告诉AssetManager您的自定义J*aScript文件的物理路径。@webroot 是Yii2的路径别名,指向应用程序的 web 目录。
  • 'baseUrl':这个参数定义了通过Web服务器访问这些资产的URL路径。@web 也是Yii2的路径别名,代表Web根目录的URL。
  • 'js':这个数组指定了要加载的J*aScript文件。在这里,我们指向了我们自定义的 yii.gridView.js。

重要提示: 请确保 sourcePath、basePath 和 baseUrl 中的路径与您实际存放 yii.gridView.js 文件的位置和Web可访问路径相匹配。

总结与注意事项

通过以上三个步骤,您已经成功地修改了Yii2 GridView的行为,使其在提交过滤器时自动移除URL中的空查询参数。

优点:

  • URL整洁: 显著改善URL的可读性和美观性。
  • 避免修改核心文件: 通过AssetManager的覆盖机制,我们避免了直接修改 vendor 目录下的文件,确保了项目的可维护性和Yii2框架升级的顺畅。
  • 服务器负载优化: 减少了不必要的参数传输,虽然影响微小,但在高并发场景下仍有积极意义。

注意事项:

  • 路径准确性: 务必仔细检查 assetManager 配置中的路径是否正确指向您自定义的J*aScript文件。任何路径错误都可能导致自定义文件未被加载,或者应用程序无法正常工作。
  • 兼容性: 本教程基于Yii2的默认GridView实现。如果您使用了第三方Grid组件或对GridView进行了深度定制,可能需要根据实际情况调整修改方案。
  • 前端框架冲突: 确保您的自定义J*aScript代码与项目中使用的其他前端库(如jQuery)没有版本或语法上的冲突。

通过本教程,您不仅解决了Yii2 GridView URL参数冗余的问题,也学习了如何安全地覆盖Yii2核心组件的默认行为,这对于构建健壮和可维护的Yii2应用程序至关重要。

以上就是Yii2 GridView URL参数清理与优化教程的详细内容,更多请关注php中文网其它相关文章!


相关文章: J*aScript中正确使用querySelectorAll与复杂CSS选择器  蛙漫漫画免费阅读入口_蛙漫官方正版无广告纯净版  从OpenAI API响应中高效提取生成文本  QQ邮箱在线登录平台 QQ邮箱个人邮箱网页版入口  Python中高效访问嵌套字典与列表中的键值对  CSS Flexbox如何实现多行排列_flex-wrap wrap自动换行显示  excel怎么提取文本中数字 excel函数提取技巧  PyTorch模型训练准确率不提升:诊断与修复常见指标计算错误  LINUX怎么安装MySQL_LINUX数据库安装配置教程  支付宝解绑银行卡步骤_支付宝如何解除绑定银行卡  Win10磁盘清理工具在哪 Win10打开并使用磁盘清理【教程】  漫蛙2(台版)官方入口地址 漫蛙2(台版)正版漫画网页端  汽车之家官方网站官网入口_汽车之家网页版直接进入  期待已久:小米17 Ultra、小米首款NAS本月登场  Golang如何安装Swagger工具_GoSwagger文档生成环境  晋江读书网页版在线登录 晋江读书电脑版官网  自定义Bag-of-Words实现:处理带负号的词汇权重  蛙漫漫画官网在线入口 蛙漫全本漫画免费阅读平台  J*aScript Promise链中如何正确终止后续.then执行并处理错误  优化Log4j2控制台输出性能:解决异步日志瓶颈  邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧  192.168.1.1管理中心入口 192.168.1.1路由器网页设置平台  sublime如何优雅地处理行尾空格_sublime自动清理多余空白字符配置  Golang如何实现容器化日志收集与分析_Golang容器日志收集分析方法  Excel Power Pivot如何处理XML数据源 构建高级数据模型  TikTok搜索结果不显示如何解决 TikTok搜索刷新优化方法  如何在低配置电脑上搭建轻量级J*a环境_占用更小的环境选择技巧  Google翻译怎么语音输入_Google翻译语音输入功能使用与设置方法  c++如何实现一个简单的软件渲染器_c++从零开始的3D图形学  Linux如何构建多环境配置管理_Linux多环境配置方案  Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】  58动漫网在线官方网 58动漫网正版动漫入口网址  谷歌邮箱网页版官方页面入口 谷歌邮箱网页端快速访问  使用J*aScript检测输入元素是否包含在特定类中  处理嵌套交互式控件:前端可访问性指南  JUnit5/Mockito:优雅测试内部依赖与异常处理的实践  Typer应用中动态命令行参数的解析与处理  顺丰国际快递查询 国际件官方查询入口  腾讯视频怎么举报不良内容_腾讯视频内容举报流程与违规信息处理方法  AO3镜像入口大全 AO3网页版内容访问全集  css元素hover动画延迟生效怎么办_使用animation-delay调整触发时间  J*a初级项目如何接入API数据_第三方接口请求与响应解析  Yandex搜索引擎官方地址 俄罗斯网络世界的主要入口  J*aScript中localStorage数据的获取、清洗与格式化教程  Angular中单选按钮的正确使用与常见陷阱解析  Kafka Streams中基于消息头条件过滤消息的实现指南  Sublime Text怎么显示空格和制表符_Sublime显示不可见字符设置  在J*a中如何使用Exception包装底层异常_异常包装与信息传递方法说明  C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入  AO3官方可用镜像 Archive of Our Own网页版最新入口 

在线客服
服务热线

服务热线

4008988990

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!