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

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

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" />
相关推荐
00后程序员张3 小时前
完整教程:如何将iOS应用程序提交到App Store审核和上架
android·macos·ios·小程序·uni-app·cocoa·iphone
00后程序员张3 小时前
iOS应用性能优化全解析:卡顿、耗电、启动与瘦身
android·ios·性能优化·小程序·uni-app·iphone·webview
大力水手~6 小时前
小程序模仿iphone苹果手机滑动选时间
智能手机·小程序
杰建云1676 小时前
小程序如何做裂变?
小程序·小程序制作
Evavava啊7 小时前
iOS微信小程序WebView中按钮背景渐变显示问题解决方案
ios·微信小程序·h5·渲染
阳光雨滴7 小时前
微信小程序使用canvas自定义富文本内容做图片分享
微信小程序·小程序
杰建云1677 小时前
小程序如何做活动?
小程序·小程序制作
这是个栗子7 小时前
【微信小程序问题解决】微信小程序全局 navigationBarTitleText 不起作用
微信小程序·小程序·导航栏
lpfasd1238 小时前
从“惯性思维”到“规则驱动”:一次微信小程序修复引发的 AI 编程范式思考
人工智能·微信小程序·小程序
万岳科技程序员小金8 小时前
从0到1搭建AI真人数字人小程序:源码方案与落地流程详解
人工智能·小程序·ai数字人小程序·ai数字人系统源码·ai数字人软件开发·ai真人数字人平台搭建