Skip to main content

Image

WdImage

Applicable Scenarios

Used for displaying images on the page.

Basic Capabilities Description

  1. Basic image properties provide image selection/address input, layout mode, and click-to-preview full-size image configuration. The layout mode defaults to height self-adaptation to better adapt to image display across multiple devices.
  2. Advanced properties of images support configuring the alternative text (the alt attribute of the img tag) and provide a lazy loading switch (lazy loading is often suitable for pages with many images, reducing the loading of invalid resources).

Extended Scenarios Description

How to choose the layout mode for images with fixed height and width

Example

An image with a width of 300 and height of 150 is designed; how to choose the layout mode

Configuration Method

In Style-Layout, configure the width and height according to the values provided by the design. In Properties-Basic Properties-Layout Mode, you can select either Stretch to Fill or Crop to Fill:

Image 02d87ed907345958da99fb3f0d24c61a

Note: In Mini Programs, setting the image height directly to a percentage in the style panel will not take effect. It is not recommended to configure image height as a percentage in Mini Programs. If you need to set the image height to a percentage in a Mini Program, you must define a fixed height for its parent container—meaning the parent container containing the image must have a definite height—for the percentage-based image height setting to be meaningful.

Component Usage Limits

Note that due to styling limitations on the Mini Program side, the height of the image component must not be set to auto; otherwise, it will fail to render.

Example

Interactive Preview

Layout Mode

From left to right: Crop to Fill, Scale Proportionally, Stretch to Fill, Height Auto, Width Auto

Click to Preview Full-size Image

This feature is disabled by default. After enabling this feature, clicking on the image will display the image preview.

Again Click to Close Preview

This feature is disabled by default. You must enable the Click to Preview Full-size Image feature before enabling this feature. After clicking the image to display the image preview, click the pop-up layer again to close the preview.

Alternative Text

The alt attribute of the image tag

Style API Custom Styles

/* Modify the background color of the image preview pop-up layer */
.wd-image-preview-container .wd-image__mask {
background-color: #ddd;
}
/* Modify the close button in the top-right corner of the image preview pop-up layer */
.wd-image-preview-container .wd-image__mask-close {
width: 14px;
height: 14px;
background-image: url();
}

Properties

External properties received by the component

Property Name
Property Identifier
Type
Description
Replace textaltstring

The alt attribute of the tag

Example: "[图片]"

Long press to display the menu in the mini programshowMenuByLongpressboolean

Long press the image to display the menu for sending to friends, favorite, save image, search, and recognition code. Support recognition: mini program code, WeChat/WeCom personal code, WeChat group code, and Public Account QR Code. Note: The feature requires directly long-pressing the image component. If "click to preview large image" is enabled and the pop-up large image appears, long-pressing the large image is invalid.

Valid only in Mini Program

Default value: true

lazy loadinglazyLoadboolean

Load images on demand. If the image is not shown, it will not be loaded.

Address.srcstring

The image address supports cloud storage cloudID or HTTPS protocol address. WeChat Mini Program does not support HTTP protocol.

Change the image to display

Example: "https://qcloudimg.tencent-cloud.cn/raw/4a29d51b504f12b4933ce4490110b4dc.svg"

layout modefitstring

Change image layout mode

Example: "widthFix"

Click to preview the large imageimgPreviewboolean

When turned on, click the image to show it in full size.

Click again to close previewmaskClosableboolean

When turned on, click again to close the image preview.

Default value: true

Events

Events exposed by the component. You can listen to component events to trigger external actions

Event Name
Event Code
Event Output Parameters event.detail
Applicable Scenarios
Description
load successfullyloadCompatible with all platforms

-

Loading failederrorCompatible with all platforms

-

clicktapCompatible with all platforms

-

Properties API

Through the Property API, you can access the internal state and property values of components. You can access internal values using$w.componentId.propertyName, such as $w.input1.value. For details, please refer to Property API

Read-only Property Name
Property Identifier
Type
Description
Address.srcstring

Change the image to display

layout modefitstring

Change image layout mode

Replace textaltstring

The alt attribute of the tag

Method API

None

Style API

Through the Style API, you can override the styles of internal elements in components to achieve customization. For example, in the low-code editor, you can write styles for all button components using #wd-page-root .wd-btn, and control individual component styles with :scope. For detailed instructions, please refer toStyle API

Name
Class Name
Description and Examples
root element.wd-imageimage component root element
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope.wd-image {
  /* Write CSS styles here */
}
PC-side root element.wd-pc-imageWrite styles for images on PC
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope.wd-pc-image {
  /* Write CSS styles here */
}
H5 root element.wd-h5-imageWrite styles for buttons on the H5 side
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope.wd-h5-image {
  /* Write CSS styles here */
}
Mini program root element.wd-mp-imageCan write styles for images in the mini program
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope.wd-mp-image {
  /* Write CSS styles here */
}
Preview popup element.wd-image-preview-containerClick the preview image to open the pop-up preview
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope .wd-image-preview-container {
  /* Write CSS styles here */
}
Preview background.wd-image-maskClick to preview image overlay
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope .wd-image-mask {
  /* Write CSS styles here */
}
close button.wd-image-mask__icon-closeClick to preview the image's close button in the top-right corner
/* :scope refers to the current component element */
/* For details, refer to the Style API documentation */
:scope .wd-image-mask__icon-close {
  /* Write CSS styles here */
}
图片加载错误样式.wd-image.wd-image__error::before图片加载错误时,可以通过以下样式修改默认图片占位

      .wd-image.wd-image__error::before{
        background:url("https://xx.png");
        background-size: cover;
      }
  

Learn about Style API

CSS Variables

.wd-image-mask,
.wd-image {
/* Desktop Dialog Style */
--wd-image-mask-pc: var(--wd-bg-mask);
/* H5 and Mini Program Dialog Style */
--wd-image-mask-h5: var(--wd-black);
/* Dialog Close Button */
--wd-image-close-icon: url('');
/* Fallback image when the image fails to load */
--wd-image-error-image: url('');
}

Version Changes

None

Frequently Asked Questions

How to correctly set the external URL for an image in an expression?

When setting an external URL for an image in a Mini Program, do not use src=. Simply enter the full https address. For example:

https://example.com/image.jpg

Why do externally linked images not display?

Many websites' images verify the page referrer, likely due to enabled hotlink protection. When accessed directly, there's no referrer source, but when used on your page, access may be blocked by referrer verification. You may try alternative image resources or check the loading failure messages in F12 developer tools.

Possible Causes:

  1. The image link is set to hotlink protection, only allowing access from specific domains.
  2. The page referrer is invalid and has been identified as malicious behavior by the image website.
  3. The image link has expired or does not exist.
  4. Images using HTTP protocol addresses are not supported on HTTPS pages, which only allow access to images via HTTPS protocol (cloud:// protocol for cloud storage will ultimately be converted to HTTPS)

Please check and fix the above issues before retrying.

Why do images display in the editor but not in the Mini Program?

In the editor, only Web pages can be used to simulate the rendering effects of the Mini Program. Due to the constraints of the Mini Program's rendering mechanism, setting the image height to auto is unsupported; similarly, when the image height is set to 100%, it may fail to display properly if the parent container lacks a defined height.

If encountering the above issues in the Mini Program, verify whether the height is set to auto or 100%. If so, it is recommended to set specific width and height for the image, or define a specific width, then adjust the rendering mode to height: auto.

Setting an http address, but not displaying in the WeChat Mini Program?

The Mini Program will no longer support displaying content via the http protocol; https protocol addresses are required. For details, refer to iOS WeChat 8.0.58 Failure to Load http Images.