据我所知,header minicart将从客户数据中获取数据
供应商/ magento /模块结帐/视图/前端/ web / js /视图/minicart.js
define([
'uiComponent',
'Magento_Customer/js/customer-data',
'jquery',
'ko',
'sidebar'
], function (Component, customerData, $, ko) {
'use strict';
......
this.cart = customerData.get('cart');
......
}
查看客户数据js vendor/magento/module-customer/view/frontend/web/js/customer-data.js
,我们可以从本地存储中获取客户数据。例如,在浏览器控制台中,运行以下行:localStorage.getItem('mage-cache-storage')
,我们还可以获取购物车信息。
{
"cart": {
"summary_count": 1,
....
"items": [
{
......
"qty": 1,
"item_id": "11728",
"configure_url": "http://magento2-demo/checkout/cart/configure/id/11728/product_id/1817/",
"is_visible_in_site_visibility": true,
"product_name": "Breathe-Easy Tank",
"product_url": "http://magento2-demo/breathe-easy-tank.html",
"product_has_url": true,
"canApplyMsrp": false
}
],
.......
}
}
导航到
vendor / magento / module-checkout / CustomerData / DefaultItem.php
protected function doGetItemData()
{
.......
return [
'options' => $this->getOptionList(),
'qty' => $this->item->getQty() * 1,
'item_id' => $this->item->getId(),
'configure_url' => $this->getConfigureUrl(),
'is_visible_in_site_visibility' => $this->item->getProduct()->isVisibleInSiteVisibility(),
'product_name' => $this->item->getProduct()->getName(),
'product_url' => $this->getProductUrl(),
'product_has_url' => $this->hasProductUrl(),
.....
}
供应商/ magento /模块结帐/CustomerData/AbstractItem.php
/**
* {@inheritdoc}
*/
public function getItemData(Item $item)
{
$this->item = $item;
return \array_merge(
['product_type' => $item->getProductType()],
$this->doGetItemData()
);
}
为了获得SKU项,我认为我们需要向中添加数据getItemData()
(应该尝试使用Plugin)。然后覆盖模板html vendor/magento/module-checkout/view/frontend/web/template/minicart/item/default.html
<div class="product-item-details">
<!-- ko text: product_sku --><!-- /ko -->
更新Magento 2.1.0版本
在Magento 2.1.0中,您只需要覆盖default.html
。这是因为该方法doGetItemData
已经具有产品sku。