如何加载(多个)定义的 Klarna 付款方式?
How to load (multiple) defined Klarna payment methods?
我正在构建一种 Klarna Payments 的沙箱集成(使其在原则上运行并稍后将逻辑实施到真实商店中)。文档中描述的第一步 session creating 已经奏效。现在我正在尝试显示 Klarna 小部件。
documentation 中的示例显示了如何加载一种付款方式(pay_later
/ 发票)。
Klarna.Payments.load({
container: '#klarna-payments-container',
payment_method_category: 'pay_later'
}, function (res) {
console.debug(res);
})
我对 pay_now
进行了同样的尝试,但没有成功(页面上的消息“付款方式不可用”和 {show_form: false}
res
对象)。实际上,我想查看包含三种付款方式的表格:pay_now
、pay_later
和 pay_over_time
。
我看了一下load()
的documentation。我的期望是找到像 payment_method_categories
这样的参数。但是该方法只有 payment_method_category
并且它需要是一个字符串...
如何获取可用和加载的 Klarna 付款方式的定义列表?
可能某些设置位于 Klarna 后端/“控制中心”(Playground)中,或者需要 API 调用以使这些方法可用。如果是这样,需要做什么以及如何做?
Klarna Payments 文档有点令人困惑,或者我只是误解了它。不管怎样,我想,小部件提供了(完整的)表格,按照它的步骤我将获得付款表格。这是错的。该小部件仅显示包含有关付款方式的信息的块(-s)。实际形式(单选按钮和一个或多个用于 authorize
调用的按钮等)是实施者关心的问题。
要获得多个已定义的 Klarna 付款方式,需要执行以下步骤:
1
Klarna 需要为此(测试)商家帐户激活这些方法。
session initialization call (POST /payments/v1/sessions
) 的响应中列出了可用的方法:
{
"session_id": "...",
"client_token": "...",
"payment_method_categories": [
{
"identifier": "direct_bank_transfer",
...
},
{
"identifier": "pay_later",
...
},
{
"identifier": "pay_over_time",
...
},
...
]
}
2
将单个支付块加载到单独的 HTML 容器中:
<script>
window.klarnaAsyncCallback = function () {
Klarna.Payments.init({
client_token: CLIENT_TOKEN
});
Klarna.Payments.load(
{
container: '#klarna-payments-container1',
payment_method_category: 'pay_later'
},
function (res) {
console.debug(res);
}
);
Klarna.Payments.load(
{
container: '#klarna-payments-container2',
payment_method_category: 'pay_over_time'
},
function (res) {
console.debug(res);
}
);
Klarna.Payments.load(
{
container: '#klarna-payments-container3',
payment_method_category: 'direct_bank_transfer'
},
function (res) {
console.debug(res);
}
);
};
</script>
<div id="klarna-payments-container1"></div>
<div id="klarna-payments-container2"></div>
<div id="klarna-payments-container3"></div>
结果应该是这样的:
就是这样。没有提供可见的表单元素(意思是:它 是 已经是正确的结果)。实现者负责表单,现在可以自由创建和装饰自定义表单。
我正在构建一种 Klarna Payments 的沙箱集成(使其在原则上运行并稍后将逻辑实施到真实商店中)。文档中描述的第一步 session creating 已经奏效。现在我正在尝试显示 Klarna 小部件。
documentation 中的示例显示了如何加载一种付款方式(pay_later
/ 发票)。
Klarna.Payments.load({
container: '#klarna-payments-container',
payment_method_category: 'pay_later'
}, function (res) {
console.debug(res);
})
我对 pay_now
进行了同样的尝试,但没有成功(页面上的消息“付款方式不可用”和 {show_form: false}
res
对象)。实际上,我想查看包含三种付款方式的表格:pay_now
、pay_later
和 pay_over_time
。
我看了一下load()
的documentation。我的期望是找到像 payment_method_categories
这样的参数。但是该方法只有 payment_method_category
并且它需要是一个字符串...
如何获取可用和加载的 Klarna 付款方式的定义列表?
可能某些设置位于 Klarna 后端/“控制中心”(Playground)中,或者需要 API 调用以使这些方法可用。如果是这样,需要做什么以及如何做?
Klarna Payments 文档有点令人困惑,或者我只是误解了它。不管怎样,我想,小部件提供了(完整的)表格,按照它的步骤我将获得付款表格。这是错的。该小部件仅显示包含有关付款方式的信息的块(-s)。实际形式(单选按钮和一个或多个用于 authorize
调用的按钮等)是实施者关心的问题。
要获得多个已定义的 Klarna 付款方式,需要执行以下步骤:
1
Klarna 需要为此(测试)商家帐户激活这些方法。
session initialization call (POST /payments/v1/sessions
) 的响应中列出了可用的方法:
{
"session_id": "...",
"client_token": "...",
"payment_method_categories": [
{
"identifier": "direct_bank_transfer",
...
},
{
"identifier": "pay_later",
...
},
{
"identifier": "pay_over_time",
...
},
...
]
}
2
将单个支付块加载到单独的 HTML 容器中:
<script>
window.klarnaAsyncCallback = function () {
Klarna.Payments.init({
client_token: CLIENT_TOKEN
});
Klarna.Payments.load(
{
container: '#klarna-payments-container1',
payment_method_category: 'pay_later'
},
function (res) {
console.debug(res);
}
);
Klarna.Payments.load(
{
container: '#klarna-payments-container2',
payment_method_category: 'pay_over_time'
},
function (res) {
console.debug(res);
}
);
Klarna.Payments.load(
{
container: '#klarna-payments-container3',
payment_method_category: 'direct_bank_transfer'
},
function (res) {
console.debug(res);
}
);
};
</script>
<div id="klarna-payments-container1"></div>
<div id="klarna-payments-container2"></div>
<div id="klarna-payments-container3"></div>
结果应该是这样的:
就是这样。没有提供可见的表单元素(意思是:它 是 已经是正确的结果)。实现者负责表单,现在可以自由创建和装饰自定义表单。