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 的情况,简单的赋值语句就足够了。

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

相关推荐
#麻辣小龙虾#5 分钟前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar10 分钟前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github
weixin_4713830323 分钟前
Taro-02-页面路由
前端·taro
星栈独行30 分钟前
Makepad 应用如何读文件、调接口、保存数据
前端·程序人生·ui·rust·github
IT_陈寒1 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
tedcloud1232 小时前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge
xinhuanjieyi2 小时前
html修复游戏种太阳错误
前端·游戏·html
林希_Rachel_傻希希3 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
Cache技术分享3 小时前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端
独泪了无痕4 小时前
Vue3中防御XSS攻击的“特效药”-DOMPurify
前端·vue.js·安全