Jam*_*use 1 wordpress woocommerce
我正在尝试限制对 WooCommerce 感谢页面的访问,以便用户只能查看一次(目前您可以将 URL 粘贴到另一个浏览器中并仍然可以看到它。)
我正在考虑在加载感谢页面后创建/附加一个自定义订单元到订单,然后将整个页面模板包装在 if 语句中以检查此元是否存在。因此,当他们将其粘贴到另一个浏览器/窗口中时,模板会看到该元数据存在并向他们显示不同的消息。
这是正确的做法吗?这就是我到目前为止所做的,但它不起作用!
//functions.php
add_action( 'wp_footer', 'hasLoadedPlayPage', 20 );
function hasLoadedPlayPage( $order ){
if( !is_wc_endpoint_url( 'order-received' ) ) return;
$order->update_meta_data('hasLoadedPlayPage', 'Yes');
$order->save();
}
//thankyou.php
$hasAnswered = get_post_meta($order->ID, 'hasLoadedPlayPage', true);
if(! $hasAnswered){
echo "NOT SEEN";
} else {
echo "SEEN";
}
Run Code Online (Sandbox Code Playgroud)
任何人能给我的指导将不胜感激!
谢谢
詹姆士
小智 6
对我来说看起来不错,除了你需要使用add_action('woocommerce_thankyou'...而不是wp_footer. 但由于woocommerce_thankyou仅接收订单 id 作为参数,因此您需要使用$order = wc_get_order($order_id)WC_Order 对象。就像是:
//functions.php
add_action( 'woocommerce_thankyou', 'hasLoadedPlayPage', 20, 1);
function hasLoadedPlayPage( $order_id ){
$order = wc_get_order($order_id);
$order->update_meta_data('hasLoadedPlayPage', 'Yes');
$order->save();
}
//thankyou.php
$hasAnswered = get_post_meta($order->ID, 'hasLoadedPlayPage', true);
if(! $hasAnswered){
echo "NOT SEEN";
} else {
echo "SEEN";
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5894 次 |
| 最近记录: |