前端代码在打包后访问服务器上特定目录中的图片,而图片文件夹本身并不在本地开发环境中。

步骤概览
1、配置 Nginx 静态文件夹
2、在 Vue.js 中配置图片路径
3、打包和部署前端文件

1. 配置 Nginx 静态文件夹

首先,确保Nginx配置文件 (nginx.conf) 设置正确,以便在 D:\nginx-1.21.6\html\dist\pdf\web\产品图片 目录中提供静态文件。

编辑你的 nginx.conf 文件,添加静态文件服务配置:

server {
    listen 80;
    server_name your_server_name;

    location / {
        root   D:/nginx-1.21.6/html/dist;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html;
    }

    location /pdf/web/产品图片/ {
        alias D:/nginx-1.21.6/html/dist/pdf/web/产品图片/;
    }

    # 其他配置项...
}

这样,Nginx会将请求 /pdf/web/产品图片/ 映射到 D:/nginx-1.21.6/html/dist/pdf/web/产品图片/ 目录。

2. 在 Vue.js 中配置图片路径

在你的Vue.js代码中,使用静态路径来访问图片。在组件中,可以直接使用服务器上的相对路径。

假设你有一个 row.img 字段,它包含图片文件名,你可以这样构建图片路径:

<template>
  <div>
    <el-button @click="handlePreviewA(row)">预览图片</el-button>
    
    <el-dialog :visible.sync="dialogVisible" width="30%">
      <img :src="dialogImageUrl" alt="预览图片" style="width: 100%;" />
    </el-dialog>
  </div>
</template>

<script>
export default {
  data() {
    return {
      dialogImageUrl: '',
      dialogVisible: false
    }
  },
  methods: {
    handlePreviewA(row) {
      if (row.img == null) {
        this.$message.error("暂无图片");
      } else {
        // 使用绝对路径访问Nginx服务器上的图片
        this.dialogImageUrl = `/pdf/web/产品图片/${row.img}`;//注意:这里的row.img要匹配服务器的图片命名
        this.dialogVisible = true;
      }
    }
  }
}
</script>

<style>
/* 添加你自己的样式 */
</style>

3. 打包和部署前端文件

运行以下命令来打包你的Vue.js项目:

npm run build

将打包生成的 dist 文件夹复制到 D:\nginx-1.21.6\html 目录下。

总结

通过在Nginx配置文件中设置静态文件路径,并在Vue.js组件中使用相对路径访问图片,你可以确保前端代码在打包后能够正确访问服务器上的图片文件夹。这样,即使图片文件夹不在本地开发环境中,打包后的前端代码也能正常工作。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
是的,SpringBoot可以提供接口让前端下载后端`resources`目录下的文件。可以通过以下步骤实现: 1. 在`application.properties`或`application.yml`配置`spring.resources.static-locations`属性,指定资源文件的路径,例如: ``` spring.resources.static-locations=classpath:/static/,file:/path/to/resources/ ``` 这里配置了两个路径,一个是`classpath:/static/`,表示在`src/main/resources/static/`目录下查找静态资源;另一个是`file:/path/to/resources/`,表示在指定的`/path/to/resources/`目录下查找资源。 2. 创建一个Controller,用于处理下载请求,例如: ```java @RestController public class DownloadController { @GetMapping("/download") public ResponseEntity<Resource> downloadFile() throws IOException { Resource resource = new ClassPathResource("/static/test.txt"); HttpHeaders headers = new HttpHeaders(); headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=test.txt"); return ResponseEntity.ok() .headers(headers) .contentLength(resource.contentLength()) .contentType(MediaType.parseMediaType("application/octet-stream")) .body(resource); } } ``` 这里假设要下载的文件为`test.txt`,位于`src/main/resources/static/test.txt`。 3. 在前端页面添加下载链接,例如: ```html <a href="/download">Download</a> ``` 当用户点击该链接时,会向后端发送一个GET请求,后端会返回一个`test.txt`文件供用户下载。 注意:在实际开发,需要根据具体需求进行配置和实现。此处只是提供一个示例,具体实现方式可能会有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值