我的第一个项目(八):(解决问题)图片资源无法加载(Error: Cannot find module "../../xxx" )

第一个,项目,解决问题,图片,资源,无法,加载,error,cannot,find,module,xxx · 浏览次数 : 158

小编点评

**问题分析:** 当使用 `createImage()` 函数来初始化图片时,如果图片路径包含 `.` 或 `/` 符号,则会引发错误,因为这些符号被视为文件路径中的路径分隔符。 **解决方案:** 在 `createImage()` 函数中处理图片路径中的 `.` 和 `/` 符号,以确保正确的路径获取。以下是修改后的解决方案: ```javascript function createImage(src) { let img; // 处理路径中的 '.' 和 '/' 符号 if (src.includes(".")) { img = new Image(); img.src = require(`./img/${src}`); } else { img = new Image(); img.src = src; } return img; } ``` **修改后的代码示例:** ```javascript // ... const bg = createImage("4.jpg"); bg.onload = function () { console.log("img加载完毕"); context.drawImage(bg, 0, 0, 480, 650); }; // ... ``` **注意:** 这仅适用于处理图片路径,对于其他类型的资源,例如字体或 CSS,可能需要进行不同的处理。

正文

好家伙,问题一堆

 

先开一个测试页模拟游戏模块的运行

原先的图片初始化方法失效了,(vue里面自然是用不了这种方法的)

function createImage(src) {
    let img;
if (typeof src === "string") { img = new Image(); img.src = src; } else { img = []; for (let i = 0; i < src.length; i++) { img[i] = new Image(); img[i].src = src[i]; } } return img; } const IMAGES = { bg: "img/4.jpg", } const bg = createImage(IMAGES.bg);

 

我们来改一下:

function createImage(src) {
        let img;
        if (typeof src === "string") {
          img = new Image();
          img.src = require(src);
        } else {
          img = [];
          for (let i = 0; i < src.length; i++) {
            img[i] = new Image();
            img.src = require(src[i]);
          }
        }
        return img;
      }

      let bg = createImage("4.jpg")

      bg.onload = function () {
        console.log("img加载完毕")
        context.drawImage(bg, 0, 0, 480, 650)
      }

 

 

 

嗯,报错了

搜一下报错

"Error: Cannot find module '4.jpg'"

自然是,百度一下,删删改改

此处,

 

 

require()不可

src = "./xxx/xxx"

let a = require(src)

的方式调用外部资源

 

 

function createImage(src) {
        let img;
        if (typeof src === "string") {
          img = new Image();
          img.src = require('./img/' + src);
        } else {
          img = [];
          for (let i = 0; i < src.length; i++) {
            img[i] = new Image();
            img.src = require('./img/' + src[i]);
          }
        }
        return img;
      }

      let bg = createImage("4.jpg")

      bg.onload = function () {
        console.log("img加载完毕")
        context.drawImage(bg, 0, 0, 480, 650)
      }

 

图片初始化成功!!

ok了

 

最后将我们所有的图片资源完成初始化

测试页.vue文件完整代码如下:

 

<template>
  <div>
    <div ref="stage"></div>
    <button @click="drawsth()">添加</button>
    <img src="../assets/logo.png" alt="">
  </div>
</template>

<script>
// import { PlaneBattle } from "../../../../PB for Vue/startgame"
// console.log(document.getElementById('stage'))
// plane.create(document.getElementById('stage'));
export default {

  methods: {
    drawsth() {
      //canvas初始化
      console.log("我被执行啦")
      let canvas = document.createElement('canvas');
      this.$refs.stage.appendChild(canvas);
      canvas.width = 480;
      canvas.height = 650;
      canvas.ref = canvas;
      canvas.style = "border: 1px solid red;"
      const context = canvas.getContext("2d");

      //图片初始化方法
      function createImage(src) {
        let img;
        if (typeof src === "string") {
          img = new Image();
          img.src = require('./img/' + src);
        } else {
          img = [];
          for (let i = 0; i < src.length; i++) {
            img[i] = new Image();
            img.src = require('./img/' + src[i]);
          }
        }
        return img;
      }
      //createImage()方法测试样例
      // let bg = createImage("4.jpg")
      // bg.onload = function () {
      //   console.log("img加载完毕")
      //   context.drawImage(bg, 0, 0, 480, 650)
      // }
      const IMAGES = {
        b: "bullet1.png",
        bg: "4.jpg",
        copyright: "shoot_copyright.png",
        pause: "game_pause.png",
        loading_frame: ["game_loading1.png", "game_loading2.png", "game_loading3.png",
          "game_loading4.png"
        ],
        hero_frame_live: ["hero1.png", "hero2.png"],
        hero_frame_death: ["hero_blowup_n1.png", "hero_blowup_n2.png", "hero_blowup_n3.png",
          "hero_blowup_n4.png"
        ],
        e1_live: ["enemy1.png"],
        e1_death: ["enemy1_down1.png", "enemy1_down2.png", "enemy1_down3.png", "enemy1_down4.png"],
        e2_live: ["enemy2.png"],
        e2_death: ["enemy2_down1.png", "enemy2_down2.png", "enemy2_down3.png", "enemy2_down4.png"],
        e3_live: ["enemy3_n1.png", "enemy3_n2.png"],
        e3_death: ["enemy3_down1.png", "enemy3_down2.png", "enemy3_down3.png", "enemy3_down4.png",
          "enemy3_down5.png", "enemy3_down6.png"
        ],
        c1: "lanqiu.jpg"
      };
      //初始化各个图片
      const b = createImage(IMAGES.b);
      const bg = createImage(IMAGES.bg);
      const copyright = createImage(IMAGES.copyright);
      const pause = createImage(IMAGES.pause);
      const loading_frame = createImage(IMAGES.loading_frame);
      const hero_frame = {
        live: createImage(IMAGES.hero_frame_live),
        death: createImage(IMAGES.hero_frame_death),
      };
      const e1 = {
        live: createImage(IMAGES.e1_live),
        death: createImage(IMAGES.e1_death),
      };
      const e2 = {
        live: createImage(IMAGES.e2_live),
        death: createImage(IMAGES.e2_death),
      };
      const e3 = {
        live: createImage(IMAGES.e3_live),
        death: createImage(IMAGES.e3_death),
      };
      const c1 = createImage(IMAGES.c1);
      console.log(c1)


    }
  }
}

</script>

<style>
#stage {
  width: 480px;
  height: 650px;
  margin: 0 auto;
}
</style>

 

与我的第一个项目(八):(解决问题)图片资源无法加载(Error: Cannot find module "../../xxx" )相似的内容:

我的第一个项目(八):(解决问题)图片资源无法加载(Error: Cannot find module "../../xxx" )

好家伙,问题一堆 先开一个测试页模拟游戏模块的运行 原先的图片初始化方法失效了,(vue里面自然是用不了这种方法的) function createImage(src) { let img; if (typeof src "string") { img = new Image(); img.src

我的第一个项目(七):(解决问题)Vue中canvas无法绘制图片

好家伙, 现在,我想要把我的飞机大战塞到我的主页里去,想办法把文件导入 然后,直接死在第一步,图片渲染都成问题 先用vue写一个测试文件 来测试canvas的绘制

我的第一个项目(五):(前后端)注册用户名查重

好家伙, bug终究还是来了,而且是很离谱的bug 来吧,发现问题,再解决问题 1.注册无法检测到用户名重复 也就是说一个用户名可无限注册, 来看bug(。。。) (看来是后端验证逻辑出了问题) 要是这么上线估计直接寄了 2.完成注册用户名查重 大概率是后端出了问题 这里我们先去看看后端,从后端去改

我的第一个项目(十) :处理全局变量(解决模块化后变量无法获取的问题)

好家伙, 飞机大战分包分的差不多了, 但是又出现了问题: 文件目录如下: 然而关于变量 helloworld.vue完整代码

[转帖]Nginx 反向代理解决跨域问题

https://juejin.cn/post/6995374680114741279 编写代码两分钟,解决跨域两小时,我吐了。 如果对跨域还不了解的朋友,可以看这篇:【基础】HTTP、TCP/IP 协议的原理及应用 最近一段时间,在搞一个 SDK 的项目,使用的 TS + rollup。rollup

如何在 Windows Server 2022 阿里云服务器上搭建自己的 MQTT 服务器之一Apache-Apollo服务器。

一、简介 最近,在做一个项目的时候,需要在线管理网络继电器,以前也做过硬件的项目,但是这样的项目不多。现在我想实现一个在线可以接受网络继电器发送的信号,也可以向网络继电器发送命令,控制其的运行。这个功能的实现需要物联网的支持,我在咨询了网络继电器卖家,想要在线实现网络硬件的管理有三种解决方案。 第一

在 Net Core 开发中如何解决 Cannot access a disposed object 这个问题

一、简介 Net Core跨平台项目开发多了,总会遇到各种各样的问题,我就遇到了一个这样的问题,不能访问 Cannot access a disposed object 错误,经过自己多方努力,查阅资料,终于找到了解决办法,引发这个问题的原因大多数是多次读取请求Body流造成的,需要换一种获取请求B

如何在2023年开启React项目

在这里,我想给你一个新的React项目入门的简要概述。我想反思一下优点和缺点,反思一下作为一个开发者所需要的技术水平,反思一下作为一个React开发者,每个启动项目都能为你提供哪些功能。最后,你将了解到针对不同需求的3种解决方案。 **免责声明**:从个人开发者的角度来看,我完全支持React团队在

【开源】最近写了一个简单的网址导航网站

前言 随着团队的成长,要管理的项目或使用的内部系统越来越多,很多内部系统都没有域名,使用IP+端口,很难记。 为了解决这个痛点,我抽空写了个导航网站~ 目前用下来效果还不错,可以基本完美的解决这个问题。 项目名称是 SiteDirectory ,代码在 Github 开源了: https://git

SpringBoot进阶教程(七十六)多维度排序查询

在项目中经常能遇到,需要对某些数据集合进行多维度排序的需求。对于集合多条件排序解决方案也有很多,今天我们就介绍一种,思路大致是设置一个分值的集合,这个分值是按照需求来设定大小的,再根据分值的大小对集合排序。 v需求背景 我们来模拟一个需求,现在需要查询一个用户列表,该列表需要实现的排序优先级如下: