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

步骤概览
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组件中使用相对路径访问图片,你可以确保前端代码在打包后能够正确访问服务器上的图片文件夹。这样,即使图片文件夹不在本地开发环境中,打包后的前端代码也能正常工作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值