donglue1886 2017-05-16 11:19
浏览 53
已采纳

Symfony Twig - 图像没有显示

Little bit confused here. I have looked at a few threads and they are not solving it.

1)  <img src="/web/uploads/ce438b2eb1c01d85f3d6d6c52efc1175.png"/>

2)   <img src="{{ asset('/uploads/ce438b2eb1c01d85f3d6d6c52efc1175.png')}}"/>

Edit:

2) Works
1) does not.

The crazy thing is, in PHPstorm, if I do /web in the src route it selects it for me, then it selects uploads for me and can even see the file. It just wont display!?

The below works for me, it displays the image. So there is no real rush on this now. However it is interesting to why 1) doesn't work?

  <img src="{{ asset('/uploads/' ~ media)}}"/>
  • 写回答

4条回答 默认 最新

  • douhuiwan5141 2017-05-16 12:16
    关注

    The answer should be easy to find by searching the docs.

    <img src="/web/uploads/ce438b2eb1c01d85f3d6d6c52efc1175.png"/>
    

    doesn't work, simply because, if this code you've wrote it inside, let's say, AppBundle/Resources/views/Default/index.html.twig file, then this means the web/uploads/ directory structure should be present inside this directory (AppBundle/Resources/views/Default/) - and having the image inside it.

    Which is not your case. So for AppBundle/Resources/views/Default/index.html.twig, the src should be:

    <img src="../../../../../uploads/ce438b2eb1c01d85f3d6d6c52efc1175.png
    

    That's why the asset() function is useful. Because it maps the path to your public directory (declared in composer.json file, under the symfony-web-dir key); so, no matter from where you are calling this function, it will always return the path to the public directory, so you don't have to worry about all those ../../ inclusions.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵