Fashion striped rainbow print casual shirt after rain
Fashion striped rainbow print casual shirt after rain
Fashion striped rainbow print casual shirt after rain
Fashion striped rainbow print casual shirt after rain
Fashion striped rainbow print casual shirt after rain
Fashion striped rainbow print casual shirt after rain
1/2
Fashion striped rainbow print casual shirt after rain
Fashion striped rainbow print casual shirt after rain
1/2

Fashion striped rainbow print casual shirt after rain

$29.89
$40.00
Color
Please select a color
Size
Please select a size
Quantity
Barcode:
  • Style : Casual , Boho , Street , Vintage
  • Season : Spring , Autumn , Summer
  • Material : Polyester
  • Color : Green
  • Pattern Type : Print
  • Occasion : Street , Outdoors , Vacation , Home
  • Sleeve Length : Short Sleeve

Size Chart

cm
SizeSMLXL2XL
Shoulder3941.54446.549
Bust103108113118123
Length7172737475
Sleeve Length2122232425
inch
Size inchSMLXL2XL
Shoulder15.416.317.318.319.3
Bust40.642.544.546.548.4
Length28.028.328.729.129.5
Sleeve Length8.38.79.19.49.8
class SpzCustomDiscountFlashsale extends SPZ.BaseElement { constructor(element) { super(element); this.xhr_ = SPZServices.xhrFor(this.win); this.getFlashSaleApi = "\/api\/storefront\/promotion\/flashsale\/display_setting\/product_setting"; this.timer = null; this.variantId = "1001136f-dda0-44e0-b0c4-12736fcfc313"; // 促销活动数据 this.flashsaleData = {} } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } buildCallback() { this.templates_ = SPZServices.templatesForDoc(); this.viewport_ = this.getViewport(); // 挂载bind函数 解决this指向问题 this.render = this.render.bind(this); this.resize = this.resize.bind(this); this.switchVariant = this.switchVariant.bind(this); } mountCallback() { // 获取数据 this.getData(); this.element.onclick = (e) => { const cur = this.win.document.querySelector(".app_discount_flashsale_desc"); if (this.flashsaleData.product_setting.is_redirection && appDiscountUtils.inProductBody(this.element) && e.target !== cur) { this.win.open(`/promotions/discount-default/${this.flashsaleData.discount_info.id}`); } } // 绑定 this.viewport_.onResize(this.resize); // 监听子款式切换,重新渲染 this.win.document.addEventListener('dj.variantChange', this.switchVariant); } unmountCallback() { // 解绑 this.viewport_.removeResize(this.resize); this.win.document.removeEventListener('dj.variantChange', this.switchVariant); // 清除定时器 if (this.timer) { clearTimeout(this.timer); this.timer = null; } } resize() { if (this.timer) { clearTimeout(this.timer) this.timer = null; } this.timer = setTimeout(() => { this.render(); }, 200) } switchVariant(event) { const variant = event.detail.selected; if (variant.product_id == '8e1423d6-7338-4ff0-bf6c-8e0b0f276226' && variant.id != this.variantId) { this.variantId = variant.id; this.getData(); } } getData() { const reqBody = { product_id: "8e1423d6-7338-4ff0-bf6c-8e0b0f276226", product_type: "", variant_id: this.variantId } this.flashsaleData = {}; this.win.fetch(this.getFlashSaleApi, { method: "POST", body: JSON.stringify(reqBody), headers: { "Content-Type": "application/json" } }).then(async (response) => { if (response.ok) { this.flashsaleData = await response.json(); this.render(); } else { this.clearDom(); } }).catch(err => { this.clearDom(); }); } clearDom() { const children = this.element.querySelector('*:not(template)'); children && SPZCore.Dom.removeElement(children); } render() { this.templates_ .findAndRenderTemplate(this.element, { isMobile: appDiscountUtils.judgeMobile(), isRTL: appDiscountUtils.judgeRTL(), inProductDetail: appDiscountUtils.inProductBody(this.element), flashsaleData: this.flashsaleData, image_domain: this.win.SHOPLAZZA.image_domain, }) .then((el) => { this.clearDom(); this.element.appendChild(el); }) } } SPZ.defineElement('spz-custom-discount-flashsale', SpzCustomDiscountFlashsale);