node.js 模拟后端接口返回数据以及图片路径

我是一位学习前端的程序员,有些时候想自己在本地模拟后端数据,因此使用 node.js进行模拟最简单不过了!

但又出现了一个问题

很多后端都要图片路径,我在 CSDN 找了很多资料都无法解决。

所以在此分享方法给大家

 第一步, 编写node.js 代码 ,源码如下

     需要在当前目录下创建一个 img 目录 (用于存放所需图片的文件夹)

const express = require('express')
const app = express()

const cors=require("cors");
 app.use(cors())

//使用 node.js 进行静态资源托管
   app.use("/img",express.static("./img"))
// 前端发来的get请求  路径为 /user
   app.get("/user",(req,res)=>{
    res.send(
      [{
          id:1,
          name:"李大力",
   //路径为本地服务器 + 托管前缀 + 文件夹下的图片路径名
          img_url:'http://127.0.0.1/img/5.jpeg',   
        },{
          id:2,
          name:"李小明",
          img_url:'http://127.0.0.1/img/6.jpeg',
        }
      ]
    )
   })

 app.listen(80, () => {
     console.log('启动成功! at http://127.0.0.1')
})

// 点开终端 启动服务器  node test.js

 第二步,动态绑定进行使用(以 uni-app 为例 )

uni.request({
		url:"http://127.0.0.1/user",
		success:(data)=>{
			this.userdata=data.data
		  }
		})

第三步,动态绑定使用

<img :src="userdata.img_url">

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 可以使用 uni.request 函数发起 HTTP 请求来获取图片数据。 具体方法是在 uni.request 中设置 responseType 为 'arraybuffer',然后将请求返回的二进制数据转换为 base64 编码并赋值给图片元素的 src 属性。 例如: ``` uni.request({ url: 'http://example.com/image.jpg', responseType: 'arraybuffer', success: (res) => { let base64 = wx.arrayBufferToBase64(res.data) let imageSrc = 'data:image/jpg;base64,' + base64 this.imageSrc = imageSrc } }) ``` 在模板中,可以使用 v-bind 指令将图片元素的 src 属性绑定到 imageSrc 变量上。 ``` <template> <view> <image v-bind:src="imageSrc"></image> </view> </template> ``` ### 回答2: 在uniapp中写接口返回图片数据,可以按照以下步骤进行操作: 首先,需要在后台服务器端编写一个接口用于返回图片数据。这个接口可以是使用任何编程语言实现的,比如PHP、Node.js等。接口的功能是获取图片路径或者图片的二进制数据,并返回前端应用。 1. 后台服务器端编写接口的代码如下(以Node.js为例): ```javascript const fs = require('fs'); const path = require('path'); const express = require('express'); const app = express(); app.get('/getImage', (req, res) => { const imagePath = path.join(__dirname, 'images', 'sample.jpg'); // 图片路径 // 读取图片的二进制数据 fs.readFile(imagePath, (err, data) => { if (err) throw err; // 设置响应头,指定返回数据类型为图片 res.setHeader('Content-Type', 'image/jpeg'); // 返回图片数据 res.send(data); }); }); app.listen(3000, () => { console.log('Server is running on port 3000'); }); ``` 2. 运行上述代码,启动服务器。服务器将在3000端口监听请求。 3. 在uniapp中,可以使用uni.request方法发起请求获取图片数据。示例如下: ```javascript export default { methods: { getImageData() { uni.request({ url: 'http://localhost:3000/getImage', // 接口地址 method: 'GET', responseType: 'arraybuffer', // 设置返回数据的类型 success: (res) => { const base64Data = uni.arrayBufferToBase64(res.data); // 将返回的arraybuffer类型数据转为base64格式 this.imageData = `data:image/jpeg;base64,${base64Data}`; // 将base64格式数据赋值给前端展示的图片 } }); } } } ``` 4. 在uniapp页面中调用getImageData方法,发起请求并获取到图片数据后,将其赋值给前端展示的图片源,即可在前端页面中显示接口返回图片数据。 通过以上步骤,就可以在uniapp中写接口返回图片数据,并在前端应用中展示图片。 ### 回答3: 在uniapp中,编写接口返回图片数据需要按照以下步骤进行操作: 首先,需要在后端服务器中创建一个接口来将图片数据返回前端。可以使用Node.js、PHP、Java等后端语言来编写该接口。 接下来,在前端uniapp的代码中,可以使用uni.request函数来发送网络请求获取图片数据。这个函数可以发送HTTP请求到后端接口并获取返回数据。 在uni.request函数中,需要设置请求的url为后端接口的地址,并指定请求的方法(例如GET或POST)。同时,还可以设置请求头、请求参数等信息,以便服务器能够正确处理请求。 当接收到后端返回图片数据后,可以在前端使用uni-app提供的相关组件(如<image>标签)来展示图片。可以将接收到的图片数据赋值给该组件的src属性,从而显示图片。 在图片展示的过程中,可以根据需要对图片进行进一步处理,比如调整大小、裁剪、添加滤镜等操作。uni-app提供了丰富的组件和插件来实现这些功能。 最后,根据具体需求和业务逻辑,确定是否需要对接口进行其他的错误处理或数据处理操作。比如判断接口返回的状态码,处理图片加载失败的情况等。 总之,在uniapp中编写接口返回图片数据需要通过后端服务器创建接口前端发送网络请求、接收数据并在前端显示图片的过程来完成。通过合理的代码编写和组件使用,可以轻松实现该功能,并为用户提供良好的使用体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值