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

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

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" />
相关推荐
2501_915921433 小时前
没有Mac如何完成iOS 上架:iOS App 上架App Store流程
android·ios·小程序·https·uni-app·iphone·webview
说私域4 小时前
基于定制开发开源AI智能名片与S2B2C商城小程序的旅游日志创新应用研究
人工智能·小程序·旅游
脑袋大大的5 小时前
钉钉小程序开发环境配置与前端开发指南
小程序·钉钉·企业应用开发
2301_805962937 小时前
微信小程序控制空调之接收MQTT消息
微信小程序·小程序·esp32
The_era_achievs_hero7 小时前
微信小程序121~130
微信小程序·小程序
難釋懷7 小时前
微信小程序WXSS 模板样式
微信小程序·小程序·notepad++
军军君018 小时前
基于Springboot+UniApp+Ai实现模拟面试小工具二:后端项目搭建
前端·javascript·spring boot·spring·微信小程序·前端框架·集成学习
默魔13 小时前
uniapp 微信小程序点击开始倒计时
微信小程序·小程序·uni-app
阿俊-全栈开发1 天前
crmeb多门店对接拉卡拉支付小程序聚合收银台集成全流程详解
小程序·php·拉卡拉聚合收银台·拉卡拉三方支付