- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在将变体下拉列表转换为支持 woocommerce 的网站的单选按钮时遇到问题。我已经尝试找到答案 here但我似乎无法使这个解决方案发挥作用。我还尝试编辑variable.php 文件中的代码。
到目前为止,最成功的是第二种方法,编辑variable.php代码并将标签更改为标签。问题是单击单选按钮时不会触发自然的 jQuery 事件。
如果你们知道一种更简单的方法将下拉菜单转换为单选按钮,或者只是触发 jQuery 事件,我们将不胜感激。
我可以得到的相关代码:
<?php $loop = 0; foreach ( $attributes as $name => $options ) : $loop++; ?>
<tr>
<td class="label"><label for="<?php echo sanitize_title($name); ?>"><?php echo $woocommerce->attribute_label($name); ?></label></td>
<td class="value"><select id="<?php echo esc_attr( sanitize_title($name) ); ?>" name="attribute_<?php echo sanitize_title($name); ?>">
<option value=""><?php echo __('Choose an option', 'woocommerce') ?>…</option>
<?php
if ( is_array( $options ) ) {
if ( empty( $_POST ) )
$selected_value = ( isset( $selected_attributes[ sanitize_title( $name ) ] ) ) ? $selected_attributes[ sanitize_title( $name ) ] : '';
else
$selected_value = isset( $_POST[ 'attribute_' . sanitize_title( $name ) ] ) ? $_POST[ 'attribute_' . sanitize_title( $name ) ] : '';
// Get terms if this is a taxonomy - ordered
if ( taxonomy_exists( sanitize_title( $name ) ) ) {
$terms = get_terms( sanitize_title($name), array('menu_order' => 'ASC') );
foreach ( $terms as $term ) {
if ( ! in_array( $term->slug, $options ) ) continue;
echo '<option value="' . $term->slug . '" ' . selected( $selected_value, $term->slug ) . '>' . apply_filters( 'woocommerce_variation_option_name', $term->name ) . '</option>';
}
} else {
foreach ( $options as $option )
echo '<option value="' . $option . '" ' . selected( $selected_value, $option ) . '>' . apply_filters( 'woocommerce_variation_option_name', $option ) . '</option>';
}
}
?>
相关Javascript。我将“select”元素更改为“input:radio”,但它仍然不起作用。
jQuery(文档).ready(函数($) {
/**
* Variations form handling
*/
$('form.variations_form')
// On clicking the reset variation button
.on( 'click', '.reset_variations', function( event ) {
$(this).closest('form.variations_form').find('.variations select').val('').change();
return false;
} )
// Upon changing an option
.on( 'change', '.variations select', function( event ) {
$variation_form = $(this).closest('form.variations_form');
$variation_form.find('input[name=variation_id]').val('').change();
$variation_form
.trigger( 'woocommerce_variation_select_change' )
.trigger( 'check_variations', [ '', false ] );
$(this).blur();
if( $().uniform && $.isFunction( $.uniform.update ) ) {
$.uniform.update();
}
} )
// Upon gaining focus
.on( 'focusin', '.variations select', function( event ) {
$variation_form = $(this).closest('form.variations_form');
$variation_form
.trigger( 'woocommerce_variation_select_focusin' )
.trigger( 'check_variations', [ $(this).attr('name'), true ] );
} )
// Check variations
.on( 'check_variations', function( event, exclude, focus ) {
var all_set = true;
var any_set = false;
var showing_variation = false;
var current_settings = {};
var $variation_form = $(this);
var $reset_variations = $variation_form.find('.reset_variations');
$variation_form.find('.variations select').each( function() {
if ( $(this).val().length == 0 ) {
all_set = false;
} else {
any_set = true;
}
if ( exclude && $(this).attr('name') == exclude ) {
all_set = false;
current_settings[$(this).attr('name')] = '';
} else {
// Encode entities
value = $(this).val()
.replace(/&/g, '&')
.replace(/"/g, '"')
.replace(/'/g, ''')
.replace(/</g, '<')
.replace(/>/g, '>');
// Add to settings array
current_settings[ $(this).attr('name') ] = value;
}
});
var product_id = parseInt( $variation_form.attr( 'data-product_id' ) );
var all_variations = window[ "product_variations_" + product_id ];
// Fallback
if ( ! all_variations )
all_variations = window[ "product_variations" ];
var matching_variations = find_matching_variations( all_variations, current_settings );
if ( all_set ) {
var variation = matching_variations.pop();
if ( variation ) {
// Found - set ID
$variation_form
.find('input[name=variation_id]')
.val( variation.variation_id )
.change();
$variation_form.trigger( 'found_variation', [ variation ] );
} else {
// Nothing found - reset fields
$variation_form.find('.variations select').val('');
if ( ! focus )
$variation_form.trigger( 'reset_image' );
}
} else {
$variation_form.trigger( 'update_variation_values', [ matching_variations ] );
if ( ! focus )
$variation_form.trigger( 'reset_image' );
if ( ! exclude ) {
$variation_form.find('.single_variation_wrap').slideUp('200');
}
}
if ( any_set ) {
if ( $reset_variations.css('visibility') == 'hidden' )
$reset_variations.css('visibility','visible').hide().fadeIn();
} else {
$reset_variations.css('visibility','hidden');
}
} )
// Reset product image
.on( 'reset_image', function( event ) {
var $product = $(this).closest( '.product' );
var $product_img = $product.find( 'div.images img:eq(0)' );
var $product_link = $product.find( 'div.images a.zoom:eq(0)' );
var o_src = $product_img.attr('data-o_src');
var o_title = $product_img.attr('data-o_title');
var o_href = $product_link.attr('data-o_href');
if ( o_src && o_href && o_title ) {
$product_img
.attr( 'src', o_src )
.attr( 'alt', o_title )
.attr( 'title', o_title );
$product_link
.attr( 'href', o_href );
}
} )
// Disable option fields that are unavaiable for current set of attributes
.on( 'update_variation_values', function( event, variations ) {
$variation_form = $(this).closest('form.variations_form');
// Loop through selects and disable/enable options based on selections
$variation_form.find('.variations select').each(function( index, el ){
current_attr_select = $(el);
// Disable all
current_attr_select.find('option:gt(0)').attr('disabled', 'disabled');
// Get name
var current_attr_name = current_attr_select.attr('name');
// Loop through variations
for ( num in variations ) {
var attributes = variations[ num ].attributes;
for ( attr_name in attributes ) {
var attr_val = attributes[ attr_name ];
if ( attr_name == current_attr_name ) {
if ( attr_val ) {
// Decode entities
attr_val = $("<div/>").html( attr_val ).text();
// Add slashes
attr_val = attr_val.replace(/'/g, "\\'");
attr_val = attr_val.replace(/"/g, "\\\"");
// Compare the meercat
current_attr_select.find('option[value="' + attr_val + '"]').removeAttr('disabled');
} else {
current_attr_select.find('option').removeAttr('disabled');
}
}
}
}
});
// Custom event for when variations have been updated
$variation_form.trigger('woocommerce_update_variation_values');
} )
// Show single variation details (price, stock, image)
.on( 'found_variation', function( event, variation ) {
var $variation_form = $(this);
var $product = $(this).closest( '.product' );
var $product_img = $product.find( 'div.images img:eq(0)' );
var $product_link = $product.find( 'div.images a.zoom:eq(0)' );
var o_src = $product_img.attr('data-o_src');
var o_title = $product_img.attr('data-o_title');
var o_href = $product_link.attr('data-o_href');
var variation_image = variation.image_src;
var variation_link = variation.image_link;
var variation_title = variation.image_title;
$variation_form.find('.variations_button').show();
$variation_form.find('.single_variation').html( variation.price_html + variation.availability_html );
if ( ! o_src ) {
o_src = ( ! $product_img.attr('src') ) ? '' : $product_img.attr('src');
$product_img.attr('data-o_src', o_src );
}
if ( ! o_href ) {
o_href = ( ! $product_link.attr('href') ) ? '' : $product_link.attr('href');
$product_link.attr('data-o_href', o_href );
}
if ( ! o_title ) {
o_title = ( ! $product_img.attr('title') ) ? '' : $product_img.attr('title');
$product_img.attr('data-o_title', o_title );
}
if ( variation_image && variation_image.length > 1 ) {
$product_img
.attr( 'src', variation_image )
.attr( 'alt', variation_title )
.attr( 'title', variation_title );
$product_link
.attr( 'href', variation_link );
} else {
$product_img
.attr( 'src', o_src )
.attr( 'alt', o_title )
.attr( 'title', o_title );
$product_link
.attr( 'href', o_href );
}
var $single_variation_wrap = $variation_form.find('.single_variation_wrap');
if ( variation.sku )
$product.find('.product_meta').find('.sku').text( variation.sku );
else
$product.find('.product_meta').find('.sku').text('');
$single_variation_wrap.find('.quantity').show();
if ( ! variation.is_in_stock && ! variation.backorders_allowed ) {
$variation_form.find('.variations_button').hide();
}
if ( variation.min_qty )
$single_variation_wrap.find('input[name=quantity]').attr( 'data-min', variation.min_qty ).val( variation.min_qty );
else
$single_variation_wrap.find('input[name=quantity]').removeAttr('data-min');
if ( variation.max_qty )
$single_variation_wrap.find('input[name=quantity]').attr('data-max', variation.max_qty);
else
$single_variation_wrap.find('input[name=quantity]').removeAttr('data-max');
if ( variation.is_sold_individually == 'yes' ) {
$single_variation_wrap.find('input[name=quantity]').val('1');
$single_variation_wrap.find('.quantity').hide();
}
$single_variation_wrap.slideDown('200').trigger( 'show_variation', [ variation ] );
} );
/**
* Initial states and loading
*/
$('form.variations_form .variations select').change();
/**
* Helper functions for variations
*/
// Search for matching variations for given set of attributes
function find_matching_variations( product_variations, settings ) {
var matching = [];
for (var i = 0; i < product_variations.length; i++) {
var variation = product_variations[i];
var variation_id = variation.variation_id;
if ( variations_match( variation.attributes, settings ) ) {
matching.push(variation);
}
}
return matching;
}
// Check if two arrays of attributes match
function variations_match( attrs1, attrs2 ) {
var match = true;
for ( attr_name in attrs1 ) {
var val1 = attrs1[ attr_name ];
var val2 = attrs2[ attr_name ];
if ( val1 !== undefined && val2 !== undefined && val1.length != 0 && val2.length != 0 && val1 != val2 ) {
match = false;
}
}
return match;
}
});
最佳答案
几年后,官方仓库中有一个解决方案: http://wordpress.org/plugins/woocommerce-radio-buttons/
缺少的部分是插件将 WooCommerce add-to-cart-variation.js
脚本出队并加载自己的脚本,以便通过更改单选按钮输入来触发正确的事件。
关于php - 将 Woo Commerce 下拉菜单转换为单选按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12374110/
我正在尝试在面包屑上方添加标题。我的问题是为什么 WooCommerce 条件在 template_redirect 上效果更好但不要在 init 上工作.例如: /** Woo General In
如何以编程方式设置隐藏在 woo-commerce WordPress 中的目录可见性? 就像这里提到的: https://docs.woothemes.com/document/catalog-vi
我的代码显示在所有产品类型中,例如简单产品、可变产品、自定义类型......对所有人都可用的方法,但我只想将其限制为我的自定义类型。 如何将我的自定义字段类型限制为英语类(class)产品类型 add
我正在寻找一种方法来重定向我的批发用户。 我为批发设置 woo-commerce 的方法是根据我命名为“批发”的 wordpress 用户角色将用户分配给批发。 我想保留普通用户的重定向而不做任何更改
我正在使用 Add a custom select field with collection times in WooCommerce checkout创建集合下拉列表 我的问题是如何让我的收集时间
我在将变体下拉列表转换为支持 woocommerce 的网站的单选按钮时遇到问题。我已经尝试找到答案 here但我似乎无法使这个解决方案发挥作用。我还尝试编辑variable.php 文件中的代码。
我想将销售价格移动到实际价格之下以进行变化,我设法为产品摘要部分执行此操作但无法找到任何变化过滤器。 请看下图。 我已经尝试过此代码但没有成功,我的代码适用于 Summery 部分 add_filte
我想修改 woo-commerce 特色产品小部件的 HTML 代码。问题是我在模板文件夹/插件文件夹中找不到它。 有人知道如何修改woo-commerce的特色产品小部件吗? 最佳答案 这是通过位于
我正在使用 woo canvas 主题开发网站。我想为移动响应布局添加自定义 css。Canvas 是响应式的,但我想添加自定义 css 以更改字体大小等。我正在使用以下代码在我的 Canvas 子主
如何在 Woo Canvas 中为我的菜单下拉菜单设置自定义宽度,使其与主选项卡的宽度相匹配?我的测试站点在 http://www.fopm.co.uk/eds 不正确的标签是打印服务和联系我们 谢谢
在我的 WooCommerce 网站中,我正在使用此插件 WooCommerce Order Cancel for Customers允许客户根据付款类型和时间延迟取消订单。但是取消按钮只出现在“wo
这是我到目前为止所拥有的: Scanner scan = new Scanner(System.in); String str = scan.nextLine(); int x
我正在尝试建立一个带有 woo commerce 的网上商店,这看起来是一个非常不错且易于使用的系统。但我真的遇到了一些麻烦。很多时候代码中有这样的函数:do_action( 'woocommerce
价格与名称(标题)对齐的问题 CSS 代码 .mgrt-product-title .price { padding-left: 749px; font-weight: bold; color:
我正在使用 Woo Testimonials Wordpress 插件来创建推荐信。不幸的是,在最近的更新之后,这不再正常工作。每个推荐书的反引号都丢失了,作者的引文与引文重叠。 有人知道如何解决这个
我正在实现一个“POST”api,用于通过 woo-commerce 创建订单: POST http://www.url.in/wp-json/wc/v1/orders 我还为其使用了外部库 Oaut
我有WordPress网站www.kampengCourse.id来选择语言课程。我想展示一下有多少人看过特定的产品。使用帖子视图计数器插件,它可以在主页和博客页面上显示帖子视图,但在商务产品页面上不
我是一名优秀的程序员,十分优秀!