跳到主要内容

图片

WdImage

适用场景

用于在页面进行图片的展示。

基础能力说明

  1. 图片的基础属性提供图片选择/地址输入、布局模式、点击预览大图配置,布局模式默认高度自适应,更好的适配多端图片展示效果
  2. 图片的高级属性支持配置图片的替代文字(img 标签的 alt 属性),提供懒加载开关(懒加载多适用于图片较多的页面,可减少无效资源的加载)

扩展场景说明

定高定宽的图片,如何选择布局模式

示例

设计提供了宽 300、高 150 的图片,如何选择布局

配置方法

样式-布局中宽度和高度按照设计提供的数值配置,属性-基础属性-布局模式,选择拉伸填满或者裁剪填满都可以:

注:小程序中图片高度在样式面板中直接配置百分比会不生效,不建议小程序的图片高度配置百分比。如果您要配置小程序中图片高度为百分比,需要为其父级容器定一个确定的高度,即包含图片的父容器有确定的高度,图片的高度设定成百分比才有意义

组件使用限制

需注意,由于小程序端样式限制问题,图片组件的高度不得设置为 auto,否则将无法渲染。

示例

交互式预览

布局模式

从左至右依次为:剪裁填满,等比缩放,拉伸填满,高度自适应,宽度自适应

点击预览大图

此功能默认关闭,开启此功能后,点击图片会展示图片预览

再次点击关闭预览

此功能默认关闭,需先开启点击预览大图,才可开启此功能。 点击图片展示图片预览后,再次点击弹出层可关闭预览。

替代文字

图片标签的 alt 属性

样式 API 自定义样式

/* 修改图片预览弹出层背景色 */
.wd-image-preview-container .wd-image__mask {
background-color: #ddd;
}
/* 修改图片预览弹出层右上角关闭按钮 */
.wd-image-preview-container .wd-image__mask-close {
width: 14px;
height: 14px;
background-image: url();
}

属性

组件接收的外部传入的属性

属性名
属性标识
类型
说明
地址srcstring

更改需要展示的图片

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

布局模式fitstring

更改图片的布局模式

示例:"widthFix"

点击预览大图imgPreviewboolean

开启后,点击图片后图片会展示为大图

再次点击关闭预览maskClosableboolean

开启后,再次点击蒙层会关闭图片预览

默认值:true

替代文字altstring

标签的 alt 属性

示例:"[图片]"

小程序端长按展示功能菜单showMenuByLongpressboolean

长按图片显示发送给朋友、收藏、保存图片、搜一搜、识别码菜单。支持识别:小程序码、微信/企微个人码、微信群码、公众号二维码

仅小程序端有效

默认值:true

懒加载lazyLoadboolean

图片按需加载,若图片没有被展示,则不会加载

事件

组件暴露的事件,可以监听组件的事件来触发一些外部的动作

事件名
事件code
事件出参 event.detail
适用情况
说明
加载成功load兼容三端

-

加载失败error兼容三端

-

点击tap兼容三端

-

属性 API

通过属性 API,可以获取组件内部的状态和属性值,可以通过$w.componentId.propertyName 来访问组件内部的值,如 $w.input1.value ,详请请参考 属性 API

只读属性名
属性标识
类型
说明
地址srcstring

更改需要展示的图片

布局模式fitstring

更改图片的布局模式

替代文字altstring

标签的 alt 属性

方法 API

样式 API

通过样式 API,可以覆盖组件中内部元素的样式来实现自定义,例如在低代码编辑器中中通过 #wd-page-root .wd-btn 即可为所有的按钮组件编写样式,通过 :scope 可以控制单个组件样式, 详细说明请参考样式 API

名称
类名
说明和示例
根元素.wd-image图片组件根元素
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope.wd-image {
  /* 在这里编写CSS 样式 */
}
PC 端根元素.wd-pc-image可以为 PC 端的图片编写样式
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope.wd-pc-image {
  /* 在这里编写CSS 样式 */
}
H5 端根元素.wd-h5-image可以为 H5 端的按钮编写样式
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope.wd-h5-image {
  /* 在这里编写CSS 样式 */
}
小程序端根元素.wd-mp-image可以为小程序端的图片编写样式
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope.wd-mp-image {
  /* 在这里编写CSS 样式 */
}
预览弹窗元素.wd-image-preview-container点击预览图片时打开的预览弹窗
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope .wd-image-preview-container {
  /* 在这里编写CSS 样式 */
}
预览背景.wd-image-mask点击预览图片时的蒙层
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope .wd-image-mask {
  /* 在这里编写CSS 样式 */
}
关闭按钮.wd-image-mask__icon-close点击预览图片时的右上角的关闭按钮
/* :scope 指的是当前组件元素 */
/* 具体可参考样式 API 文档 */
:scope .wd-image-mask__icon-close {
  /* 在这里编写CSS 样式 */
}

了解样式 API

CSS 变量

.wd-image-mask,
.wd-image {
/* PC端弹窗样式 */
--wd-image-mask-pc: var(--wd-bg-mask);
/* H5及小程序端弹窗样式 */
--wd-image-mask-h5: var(--wd-black);
/* 弹窗关闭按钮 */
--wd-image-close-icon: url('');
/* 图片加载错误时默认展示图片 */
--wd-image-error-image: url('');
}

版本变化

常见问题

如何在表达式中正确设置图片的外部 URL?

在小程序中设置图片的外部 URL 时,不需要使用 src=,直接填写完整的 https 地址即可。例如:

https://example.com/image.jpg

为什么外链图片不显示?

很多网站的图片都会判断页面来源,可能是图片设置了防盗链,在直接输入的时候没有访问来源,但在你的页面中使用时,会判断页面来源来禁止访问。可以尝试使用其他图片资源,或检查 F12 开发者工具中的加载失败信息。

可能原因:

  1. 图片链接被设置为防盗链,只允许特定域名访问。
  2. 页面来源不合法,被图片网站识别为恶意行为。
  3. 图片链接已失效或不存在。
  4. 图片使用了 HTTP 协议的地址,通过 HTTPS 页面只支持访问 HTTPS 协议的图片(云存储的 cloud://协议最终会被转换为 HTTPS)

请检查并修复上述问题后进行重试。

为什么在编辑器中可以显示图片,在小程序中不显示图片?

在编辑器中只能使用 Web 页面来模拟小程序的渲染效果,由于小程序的渲染机制限制,图片的高度不支持设置为 auto,或者图片高度设置为 100% 时,由于父容器没有具体的高度,可能也无法正常显示。

建议在小程序中遇到上述问题时,可以尝试确认下是否高度设置了 auto 或者 100%,如果有设置,建议给图片设置具体的宽高或者设置一个具体的宽度,再将图片的渲染方式改为高度自适应。