V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
sucaiking
V2EX  ›  Vue.js

如何在 vue 项目中,正确引用项目文件夹外的图片

  •  
  •   sucaiking · 2023-12-04 22:33:13 +08:00 · 1129 次点击
    这是一个创建于 365 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我并不想把一些图片放在/src 里,于是我试着创建了一个和项目 vue_code 同级的文件夹 photoData ,把图片放在里面。现在我打开网页时好像没法正确获取图片。

    经过查找资料,我现在使用的写法是:

    <img v-for="photo in photos" :key="photo.photo_id" :src="require('D:/vueproject/code' + photo.photo_path)" />

    但这种写法似乎会导致运行时需要 build 的 modules 数无限增大。请问下我正确的写法应当是什么。

    6 条回复    2023-12-05 21:12:45 +08:00
    lisongeee
        1
    lisongeee  
       2023-12-04 23:31:39 +08:00
    提前将 D:/vueproject/code 的 图片文件 使用 require.context 按需加载

    如果是 vite 可以使用 import.meta.glob
    cuttlefish
        2
    cuttlefish  
       364 天前
    不大明白,这样子引入目的是为了啥。
    coolcoffee
        3
    coolcoffee  
       364 天前   ❤️ 1
    你这种依赖系统路径的项目,换个电脑要怎么跑?

    你为啥不把图片文件都放在 public 目录里面,然后用 “/” 路径直接访问,或者是直接丢 oss+cdn 直接全外部依赖。
    flyqie
        4
    flyqie  
       364 天前 via Android
    无论如何都不要在项目源码里使用绝对路径。
    nashaofu
        5
    nashaofu  
       364 天前 via Android
    require.context 好像可以,很久没用了
    sucaiking
        6
    sucaiking  
    OP
       364 天前
    感谢各位坛友。几番试错后我发现自己一开始的想法及其离谱,用../去找父目录也很蠢。作为不需要太过讲究的课程作业,我最后的解决方案是用 http-server 起了个本地服务器,配置好端口之后用作图片源。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1387 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 17:44 · PVG 01:44 · LAX 09:44 · JFK 12:44
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.