Добавление условного к усам /php
Рассматривать:
<?php
/**
* Single variation display
*
* This is a javascript-based template for single variations (see https://codex.wordpress.org/Javascript_Reference/wp.template).
* The values will be dynamically replaced after selecting attributes.
*
* @see https://docs.woocommerce.com/document/template-structure/
* @author WooThemes
* @package WooCommerce/Templates
* @version 2.5.0
*/
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
?>
<script type="text/template" id="tmpl-variation-template">
<div class="woocommerce-variation-description">{{{ data.variation.variation_description }}}</div>
<div class="woocommerce-variation-price">{{{ data.variation.price_html }}}</div>
<div class="woocommerce-variation-availability">{{{ data.variation.availability_html }}}</div>
<div class="woocommerce-variation-custom-text-field">
GTIN: <span class="sku">{{{ data.variation.wccaf_gtin }}}</span>
</div>
<div class="woocommerce-variation-custom-text-field">
MPN: <span class="sku">{{{ data.variation.wccaf_mpn }}}</span>
</div>
</script>
<script type="text/template" id="tmpl-unavailable-variation-template">
<p><?php _e( 'Sorry, this product is unavailable. Please choose a different combination.', 'woocommerce' ); ?></p>
</script>
Как реализовать условное, такое, что если IF {{{ data.variation.wccaf_gtin }}}
возвращает пустое / пустое значение, ТОГДА эхо "GTIN недоступен"?
Что я пробовал:
Я прочитал это на вики:
Шаблон с тегом раздела:
{{#x}} Некоторый текст {{/x}} Здесь, когда x является логическим значением, тег section действует как условный оператор if
Так я попробовал
<div class="woocommerce-variation-custom-text-field">
GTIN: <span class="sku">{{#repo}}{{ data.variation.wccaf_gtin }}{{/repo}}{{^repo}}N/A{{/repo}}</span>
</div>
который не работает.
Но я совершенно новичок в усах, и мне нужно некоторое руководство.
0 ответов
Это не шаблон усов, как отмечается в комментарии, это пользовательский WordPress wp.template
решение.
У него нет логических тегов, но есть теги оценки <# #>
,
Из быстрого Google, вот пример, как бы вы написали чек, используя их:
<# if ( data.trueValue ) { #>
<p> I am only output if <code>data.trueValue</code> is true.
<# } #>
Согласно Усы Документация
// if exist
{{#repo}}
<b>{{name}}</b>
{{/repo}}
// if not exist
{{^repo}}
No repos :(
{{/repo}}
Вы можете попробовать это
<div class="woocommerce-variation-custom-text-field">
GTIN: <span class="sku">{{#data.variation.wccaf_gtin}}{{ data.variation.wccaf_gtin }}{{/data.variation.wccaf_gtin}}{{^data.variation.wccaf_gtin}}N/A{{/data.variation.wccaf_gtin}}</span>
</div>
Попробуйте то же самое, используя ints-jst
Код:
<div id="try-jst">
<div class="woocommerce-variation-description">
<js-t> print(data.variation.variation_description);</js-t>
</div>
<div class="woocommerce-variation-price">
<js-t> print(data.variation.price_html);</js-t>
</div>
<div class="woocommerce-variation-availability">
<js-t> print(data.variation.availability_html);</js-t>
</div>
<div class="woocommerce-variation-custom-text-field">
GTIN:
<span class="sku">
<js-t>
if(!!data.variation.wccaf_gtin) {
print(data.variation.wccaf_gtin);
} else {
print("unavailable");
}
</js-t>
</span>
</div>
<div class="woocommerce-variation-custom-text-field">
MPN:
<span class="sku">
<js-t>
if(!!data.variation.wccaf_mpn) {
print(data.variation.wccaf_mpn);
} else {
print("unavailable");
}
</js-t>
</span>
</div>
</div>
Авторсценария:
<script>
/* var data = {
variation: {
variation_description: 'variation_description',
price_html: 'price_html',
availability_html: 'availability_html',
wccaf_gtin: '',
wccaf_mpn: '123',
}
}; */
// jQuery version
compile($('#try-jst')[0]);
run();
// Plain Javascript
/**
* compile(document.getElementById('try-jst'));
* run();
*/
</script>
Выход:
<div id="try-jst">
<div class="woocommerce-variation-description">variation_description</div>
<div class="woocommerce-variation-price">price_html</div>
<div class="woocommerce-variation-availability">availability_html</div>
<div class="woocommerce-variation-custom-text-field"> GTIN: <span class="sku">unavailable</span></div>
<div class="woocommerce-variation-custom-text-field"> MPN: <span class="sku">123</span></div>
</div>
Так что вы можете попробовать.