原生微信小程序研发,如何对图片进行统一管理?

目标: 统一在配置文件中管理图片,用变量存储,换图标时只需修改链接即可,无需更改业务代码,且方便查找。

tips: 不建议在 asset 中存储大量图片,原因是官方要求小程序内存要限制在2M以内,图片放多了占资源,会扩大包体积。若仅放几个代表性小图标则影响不大。

1. 创建 config/img 文件,放置图片链接,方便统一管理

管理图片的cdn链接(或其他链接,只要能加载出图片即可)

js 复制代码
// config/image.js 统一管理图片链接
const IMG_BASE_URL = 'https://cdn.example.com/'; // 云存储基础 URL

export default {
  // 静态图片(直接使用完整 URL)
  IELTSImg: 'https://cdn.example.com/2025/07/07/5c238a94de137ee6bcabefbe1e1fd37a.png',
  defaultLogo:`https://cdn.example.com/2025/07/07/2f32b9151953f0e8caee46b57ac1b3da.png`, // 默认兜底logo
  // 用IMG_BASE_URL 拼接
  logos:{
	  logo: `${IMG_BASE_URL}logo.png`,
	  defaultAvatar: `${IMG_BASE_URL}default-avatar.png`,
	  // 动态图片(封装生成逻辑)
	  userAvatar: (userId, size = '100x100') => {
	    return `${IMG_BASE_URL}avatars/${userId}_${size}.jpg?timestamp=${Date.now()}`;
	  },
  },
  // 小图标
  icons: {
  },
};

2. 在 app.js 中 定义全局变量。

这里全局变量用的 globalData

js 复制代码
// app.js
import imgConfig from './config/img.js'
App({
  onLaunch: function(options) {
    this.autoUpdate();
  },
  globalData: {
    userInfo: null,
    imgs: imgConfig, // 图片配置
  }
})

3. 在页面中引用

方式 1:直接在页面的js文件下引入。需要在每一个要引入的页面加如下代码:

const app = getApp(); const images = app.globalData.imgs;

js 复制代码
// pages/home/index.js
// 这两句是核心
const app = getApp();
const images = app.globalData.imgs;
Page({
  data: {
    logo: imgs.logo,
    userAvatar: imgs.userAvatar('user123'),
  },
});

方式 2:在 WXML 中直接调用(需通过 JS 传递) 如果不想在 JS 中定义 data,可以封装一个工具函数:

js 复制代码
// utils/image.js
const getAppImages = () => {
  const app = getApp();
  return app.globalData.images;
};
 
export { getAppImages };

这个工具函数可以全局引用。

页面 js 中,引入刚才定义好的工具方法:

js 复制代码
// pages/home/index.js
import { getAppImages } from '../../utils/image';
Page({
  onLoad() {
    this.images = getAppImages();
  },
});

页面 wxml 中,使用images变量:

html 复制代码
<!-- pages/home/index.wxml -->
<image src="{{images.logo}}" mode="aspectFit" />
相关推荐
于慨21 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz21 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶21 小时前
前端交互规范(Web 端)
前端
CHU72903521 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing21 小时前
Page-agent MCP结构
前端·人工智能
王霸天21 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc1 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说1 天前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js