Liquid:在assign定义变量时使用allow_false

前言:在 Liquid 模板语言中,allow_false 是一个特定的选项,用于控制变量赋值时是否允许 false 值被视为有效值。虽然 Liquid 的官方文档并没有详细列出 allow_false 的说明,但它通常是在一些主题或框架(如 Shopify 的 Liquid)中使用的扩展特

一、问题发现:

  • product-card.liquid中参数定义
ini 复制代码
{%- assign show_rating = show_rating | default: settings.show_product_rating, allow_false: true -%}
{%- assign show_vendor = show_vendor | default: settings.show_vendor, allow_false: true -%}
{%- assign show_quick_buy = show_quick_buy | default: settings.show_quick_buy, allow_false: true -%}
{%- assign show_secondary_image = show_secondary_image | default: settings.show_secondary_image, allow_false: true -%}
{%- assign text_alignment = text_alignment | default: settings.product_info_alignment -%}


{%- assign show_parameters = show_parameters | default: true -%} /* 初始写法 */
{%- assign show_parameters = show_parameters | default: true, allow_false: true -%} /* 正确写法,此时代码可以识别并且使用传递过来的false参数 */
......
......
  • 其他位置调用product-card.liquid
yaml 复制代码
  {%- render 'product-card', 
    product: mega_menu_block.settings.product, 
    background: mega_menu_block.settings.product_card_background, 
    text_color: mega_menu_block.settings.product_card_text_color, 
    show_vendor: false, 
    show_rating: false, 
    show_badges: false, 
    show_swatches: false,
    show_secondary_image: false, 
    show_parameters: false,
    text_alignment: 'center'
  -%}

在调用中发现,我传递的show_parameters为false的参数不生效,这时我的代码是 {%- assign show_parameters = show_parameters | default: true -%},经过与主题写法的对比,发现差异在allow_false,经过查阅:

  • allow_false: true : 允许 show_rating 变量的值为 false,并且保留这个值,而不是用默认值替换。这对于需要明确控制显示状态的布尔值非常有用。

  • allow_false : 在 show_parameters 的情况下,如果没有 allow_false,则 false 会被视为有效值,因此如果 show_parameters 被设置为 false,它不会被替换为 true,但也没有明确的控制。

总结:实际影响

  • 如果你希望某个变量可以明确地设置为 false 并且不被替换为默认值 ,那么使用 allow_false: true 是合适的。
  • 如果你希望变量默认为 true,并且不需要处理 false 的情况,简单的赋值语句就足够了。

通过这两种写法,你可以根据需要灵活地控制变量的默认行为及其布尔值的处理。

相关推荐
2401_831501732 小时前
Python学习之Day05学习(定制数据对象,面向对象)
前端·python·学习
GISer_Jing2 小时前
得物前端二面潜在问题详解
前端·javascript·面试
飞天巨兽3 小时前
HTTP基础教程详解
前端·网络·网络协议·http
FIN66683 小时前
昂瑞微IPO前瞻:技术破局高端射频模组,国产替代第二波浪潮下的硬科技突围
前端·科技·搜索引擎·产品运营·创业创新·制造·射频工程
玉树临风江流儿4 小时前
Cmake使用CPack实现打包
java·服务器·前端
xier1234565 小时前
一个全新的react表格组件方案
前端
IT_陈寒6 小时前
5种JavaScript性能优化技巧:从V8引擎原理到实战提速200%
前端·人工智能·后端
蒋星熠6 小时前
Maven项目管理与构建自动化完全指南
java·前端·python·自动化·maven
sweethhheart6 小时前
【typora激活使用】mac操作方式
前端·数据库·macos