我在结帐表单中添加了一个按钮:

并在functions.php文件中添加了一个AJAX代码段:

add_action('wp_head', 'ajax_call_place_order');

function ajax_call_place_order() {

?>

jQuery(document).ready(function($) {

$(document).on("click", "#ajax-order-btn" ,function(e) {

e.preventDefault();

var data = {

action: 'ajax_order',

};

$.post('<?php echo esc_url( home_url() ); ?>/wp-admin/admin-ajax.php', data);

});

});

}

这是AJAX回调,可通过该回调以编程方式创建订单:

add_action('wp_ajax_ajax_order', 'ajax_order_callback_wp');

add_action( 'wp_ajax_nopriv_ajax_order', 'ajax_order_callback_wp' );

function ajax_order_callback_wp() {

$address = array(

'first_name' => 'John',

'last_name' => 'Doe',

'company' => 'Speed Society',

'email' => 'joe@testing.com',

'phone' => '760-555-1212',

'address_1' => '123 Main st.',

'address_2' => '104',

'city' => 'San Diego',

'state' => 'Ca',

'postcode' => '92121',

'country' => 'US'

);

$order = wc_create_order();

$order->add_product( get_product('275962'), 1); // This is an existing SIMPLE product

$order->set_address( $address, 'billing' );

$order->calculate_totals();

$order->update_status("Completed", 'Imported order', TRUE);

}

问题是我找不到一种方法来获取当前的订单数据,并在以编程方式创建订单而不是当前的硬编码数据时使用该数据.我需要在Checkout页面上与当前订单完全相同的订单.

我正在尝试使用WC_Checkout以及方法create_order()和get_checkout_fields(),但没有成功.

解决方法:

对于PHP订单创建,我使用了来自WC_Checkout create_order()方法的自定义克隆,该克隆非常有效.所有提交的数据将按顺序自动设置.

对于自定义订单元数据和自定义订单项目元数据,可以将所有woocommerce默认挂钩用作:

> woocommerce_checkout_create_order

> woocommerce_checkout_update_order_meta

> woocommerce_checkout_create_order_line_item

>等等…

我还对jQuery代码进行了一些必要的更改以使其正常工作,并通过Ajax *(现在位于页脚中)*向PHP发送了必要的格式化数据.

通过Ajax创建订单的完整代码:

add_action('wp_footer', 'checkout_billing_email_js_ajax' );

function checkout_billing_email_js_ajax() {

// Only on Checkout

if( is_checkout() && ! is_wc_endpoint_url() ) :

?>

jQuery(function($){

if (typeof wc_checkout_params === 'undefined')

return false;

$(document.body).on("click", "#ajax-order-btn" ,function(evt) {

evt.preventDefault();

$.ajax({

type: 'POST',

url: wc_checkout_params.ajax_url,

contentType: "application/x-www-form-urlencoded; charset=UTF-8",

enctype: 'multipart/form-data',

data: {

'action': 'ajax_order',

'fields': $('form.checkout').serializeArray(),

'user_id': <?php echo get_current_user_id(); ?>,

},

success: function (result) {

console.log(result); // For testing (to be removed)

},

error: function(error) {

console.log(error); // For testing (to be removed)

}

});

});

});

endif;

}

add_action('wp_ajax_ajax_order', 'submited_ajax_order_data');

add_action( 'wp_ajax_nopriv_ajax_order', 'submited_ajax_order_data' );

function submited_ajax_order_data() {

if( isset($_POST['fields']) && ! empty($_POST['fields']) ) {

$order = new WC_Order();

$cart = WC()->cart;

$checkout = WC()->checkout;

$data = [];

// Loop through posted data array transmitted via jQuery

foreach( $_POST['fields'] as $values ){

// Set each key / value pairs in an array

$data[$values['name']] = $values['value'];

}

$cart_hash = md5( json_encode( wc_clean( $cart->get_cart_for_session() ) ) . $cart->total );

$available_gateways = WC()->payment_gateways->get_available_payment_gateways();

// Loop through the data array

foreach ( $data as $key => $value ) {

// Use WC_Order setter methods if they exist

if ( is_callable( array( $order, "set_{$key}" ) ) ) {

$order->{"set_{$key}"}( $value );

// Store custom fields prefixed with wither shipping_ or billing_

} elseif ( ( 0 === stripos( $key, 'billing_' ) || 0 === stripos( $key, 'shipping_' ) )

&& ! in_array( $key, array( 'shipping_method', 'shipping_total', 'shipping_tax' ) ) ) {

$order->update_meta_data( '_' . $key, $value );

}

}

$order->set_created_via( 'checkout' );

$order->set_cart_hash( $cart_hash );

$order->set_customer_id( apply_filters( 'woocommerce_checkout_customer_id', isset($_POST['user_id']) ? $_POST['user_id'] : '' ) );

$order->set_currency( get_woocommerce_currency() );

$order->set_prices_include_tax( 'yes' === get_option( 'woocommerce_prices_include_tax' ) );

$order->set_customer_ip_address( WC_Geolocation::get_ip_address() );

$order->set_customer_user_agent( wc_get_user_agent() );

$order->set_customer_note( isset( $data['order_comments'] ) ? $data['order_comments'] : '' );

$order->set_payment_method( isset( $available_gateways[ $data['payment_method'] ] ) ? $available_gateways[ $data['payment_method'] ] : $data['payment_method'] );

$order->set_shipping_total( $cart->get_shipping_total() );

$order->set_discount_total( $cart->get_discount_total() );

$order->set_discount_tax( $cart->get_discount_tax() );

$order->set_cart_tax( $cart->get_cart_contents_tax() + $cart->get_fee_tax() );

$order->set_shipping_tax( $cart->get_shipping_tax() );

$order->set_total( $cart->get_total( 'edit' ) );

$checkout->create_order_line_items( $order, $cart );

$checkout->create_order_fee_lines( $order, $cart );

$checkout->create_order_shipping_lines( $order, WC()->session->get( 'chosen_shipping_methods' ), WC()->shipping->get_packages() );

$checkout->create_order_tax_lines( $order, $cart );

$checkout->create_order_coupon_lines( $order, $cart );

/**

* Action hook to adjust order before save.

* @since 3.0.0

*/

do_action( 'woocommerce_checkout_create_order', $order, $data );

// Save the order.

$order_id = $order->save();

do_action( 'woocommerce_checkout_update_order_meta', $order_id, $data );

echo 'New order created with order ID: #'.$order_id.'.' ;

}

die();

}

代码进入您的活动子主题(或活动主题)的function.php文件中.经过测试和工作.

标签:ajax,woocommerce,wordpress,php,jquery

来源: https://codeday.me/bug/20191024/1922779.html

ajax 提交订单,php-在Woocommerce 3中通过ajax提交并在结帐时创建订单相关推荐

  1. php购物车生成订单,php – 在购物车,结帐和查看订单中设置产品自定义字段和显示值...

    更新 – 更正了拼写错误:代码末尾的$product_id变量名称 First: "Duplicating this custom field with key and value, in ...

  2. ajax与后台php,怎么在thinkPHP5中使用ajax实现与后台数据交互

    怎么在thinkPHP5中使用ajax实现与后台数据交互 发布时间:2021-03-20 17:20:01 来源:亿速云 阅读:87 作者:Leah 这篇文章给大家介绍怎么在thinkPHP5中使用a ...

  3. ajax地址为jsp,AJAX_在jsp中运用ajax(简单入门),由于ajax为我们带来太多的好处 - phpStudy...

    在jsp中运用ajax(简单入门) 由于ajax为我们带来太多的好处,所以在很多应用中我们都会优先选择这种技术,于是我也为之所吸引,现跟大家分享下一个简单的入门例子. regist.jsp文件:一个简 ...

  4. html ajax请求c#,c# – 获取通过webclient中的AJAX生成的html

    一般方法是这样的: >使用像Fiddler这样的工具,找出浏览器发出的HTTP请求,以便获取您正在寻找的数据. >使用WebClient获取所需的HTTP请求. 请查看我对this que ...

  5. c .net ajax,Asp.net mvc 2中使用Ajax的三种方式

    在Asp.net MVC中,我们能非常方便的使用Ajax.这篇文章将介绍三种Ajax使用的方式,分别为原始的Ajax调用.Jquery.Ajax Helper.分别采用这三种方式结合asp.net m ...

  6. 静态页中利用AJAX.NET实现无刷新页面

    一. 导言 我们知道,ASP.net应用程序事实是在服务器上运行的,用户的请求要不断地送往远程的服务器,服务器执行完本地的程序后把重新装载页面再发送客户端.所以就出现了不断刷新的问题,页面不断闪烁.用 ...

  7. jquery中ajax中的参数,jquery中的ajax参数

    jquery中将ajax封装成了函数,我们使用起来非常方便,jquery会自动根据内容选择post还是get方式提交数据,并且会自动编码,但是要想完全掌握jquery中的ajax,我们必须将它的各个参 ...

  8. ajax远程调用,jquery中的ajax方法怎样通过JSONP进行远程调用

    关于JSONP的概念和为什么要使用JSONP网上已经有很多教程,这一节主要演示下在JQUERY中的ajax方法怎样通过JSONP进行远程调用 首先介绍下$.ajax的参数 type:请求方式 GET/ ...

  9. vue可以用ajax,Vue 中使用Ajax请求

    Vue 项目中常用的 2 个 ajax 库 (一)vue-resource vue 插件, 非官方库,vue1.x 使用广泛 vue-resource 的使用 下载 npm install vue-r ...

最新文章

  1. python turtle画画 30排以内_Python竟能画这么漂亮的花,帅呆了(代码分享)
  2. 使用memcache做web缓存
  3. Pymol | Pymol绘制GridBox图
  4. 怎么查找表_MySQL索引是怎么支撑千万级表的快速查找?
  5. 【读薄Effective Java】创建和销毁对象
  6. larval mysql 查询转数组_laravel 中将DB::select 得到的内容转为数组
  7. squirrelsql安装
  8. 什么是顺序一致性呢?
  9. c iostream.源码_通达信《K线上画趋势线预警》精选指标(附源码)
  10. XGBoost、LightGBM与CatBoost算法对比与调参
  11. vue 搜索框header_vue项目header模块编写
  12. java集群插件_别说,Cerebro还真好用!老板再也不用担心ES集群了
  13. 如何下载官方windows10的ios镜像文件
  14. Helix QAC/QAC++ — 软件静态测试工具
  15. ABAP ALV详细教程(二)
  16. python人脸比对算法_python实现人脸识别经典算法(一) 特征脸法
  17. xp系统如何通过cmd运行命令符查看电脑配置的两种方法
  18. 【deepin 20.1】终端的介绍
  19. SEM竞价员一天的工作流程了解一下?
  20. dns 劫持什么意思、dns 劫持原理及几种解决方法

热门文章

  1. BitPay商家现在可以通过比特币现金(BCH)获得结算
  2. Logback日志跨线程追踪实践
  3. php array_multisort对数据库结果多个字段进行排序
  4. Java Eclipse解决中文字体太小
  5. MS UC 2013-0-虚拟机-标准化-部署-3-虚拟机-生产
  6. AndEngine引擎学习之绘制直线
  7. 如何删除exchange2007默认证书
  8. JQuery读书笔记--JQuery-Form中的AjaxForm和AjaxSubmit的区别
  9. [Shell 脚本] 备份数据库文件至OSS服务(纯shell脚本无sdk)
  10. docker安装nginx实例