vue中拼接图片地址但是图片路径有#(或者其他字符)怎么办

当在vue项目中碰到带有#图片路径(或者其他字符)怎么办

先看一个例子

//假设图片的路径是这个样的(但是需求的图片是最后面一个'/'
//后面的所有字符串才是图片地址然后用一个新的地址拼接去请求)
// 原本地址
let picsrc = 'https:xxx/xxx/xxx/47cbf4c89aa56#dnsakdnsakl#dsdsa 001.jpg'
console.log(picsrc) // https:xxx/xxx/xxx/47cbf4c89aa56#dnsakdnsakl#dsdsa 001.jpg

再来看我上面的需求是将最后面一个 ‘/’ 后面的所有字符串才是图片地址然后用一个新的地址拼接去请求

let fName = picsrc.substr(picsrc.lastIndexOf('/') + 1) // 截取最后一个 ‘/’ 后面的所有数据
console.log(fName) // 47cbf4c89aa56#dnsakdnsakl#dsdsa 001.jpg
// 用一个新的地址去请求
axios.get('http://localhost:3000/image?ObjNm=' + fName, (res) => {
  console.log(res)
})

那么结果如下

在这里插入图片描述

然后找错误找到这里:Request URL: http://localhost:3000/image?ObjNm=47cbf4c89aa56答案是在请
求的url地址中直接使用一些特殊字符,在服务器端接收的时候经常出现数据丢失的情况同时传递参数
时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。

处理方法进行字符转义

// 下面说到encodeURIComponent对应的解码
 axios.get('http://localhost:3000/image?ObjNm=' + encodeURIComponent(fName), (res) => {
   console.log(res)
 })

浏览器显示
在这里插入图片描述
备注:服务器是本地搭建node服务

js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,
js相应3个解码函数:unescape,decodeURI,decodeURIComponent

方法介绍

escape 方法

escape 方法返回一个包含了 charstring 内容的字符串值(Unicode 格式)所有空格、标点、重音符号以及
其他非 ASCII 字符都用 %xx 编码代替,但是escape 方法不能够用来对统一资源标示码 (URI) 进行编码。
对其编码应使用 encodeURI 和encodeURIComponent 方法。

encodeURI 方法

将文本字符串编码为一个有效的统一资源标识符 (URI)。encodeURI 方法返回一个编码的 URI。如果您将编码结
果传递给 decodeURI,那么将返回初始的字符串。encodeURI 方法不会对下列字符进行编码:
":"、"/"、";" 和 "?"。请使用 encodeURIComponent 方法对这些字符进行编码。

encodeURIComponent 方法

将文本字符串编码为一个统一资源标识符 (URI) 的一个有效组件。encodeURIComponent 方法返回一个已编码
的 URI。如果您将编码结果传递给 decodeURIComponent,那么将返回初始的字符串。因为
 encodeURIComponent方法对所有的字符编码。但是有一点如果该字符串代表一个路径(vue路由路径举个例子)
例如 /home/Acccept/befau,其中的斜杠也将被编码
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Vue,您可以在模板使用 v-for 指令遍历数组,并使用对象的 id 属性动态绑定图片的 URL。 示例: ``` <template> <div> <img v-for="item in items" :key="item.id" :src="'path/to/img/' + item.id + '.jpg'" /> </div> </template> <script> export default { data() { return { items: [ { id: 1 }, { id: 2 }, { id: 3 }, // ... ], }; }, }; </script> ``` 在上面的代码,我们将遍历 items 数组并为每个元素渲染一个图像。图像的 URL 将通过拼接字符串计算,其包含了对象的 id 属性。 ### 回答2: 在Vue,我们可以通过使用v-for指令来遍历数组,并根据数组的id来渲染对应的图片。 首先,我们需要在Vue实例的data选项定义一个包含多个对象的数组,其每个对象都包含一个id和一个imgUrl属性,分别表示图片的唯一标识和图片地址。例如: ```javascript data: { images: [ { id: 1, imgUrl: 'img1.jpg' }, { id: 2, imgUrl: 'img2.jpg' }, { id: 3, imgUrl: 'img3.jpg' } ] } ``` 接下来,在模板使用v-for指令进行渲染,将每个对象的imgUrl属性绑定到img标签的src属性上,并使用对象的id属性作为key属性,以便Vue可以正确地追踪元素的身份。例如: ```html <div v-for="image in images" :key="image.id"> <img :src="image.imgUrl" alt="image"> </div> ``` 通过使用v-for指令和绑定对象的id和imgUrl属性,Vue会自动根据数组的数据来渲染对应的图片。 注意:为了使上述代码能够正常工作,你需要将实际的图片地址替换为对应图片地址,并确保路径正确。 ### 回答3: 在Vue,我们可以使用v-for指令来遍历一个数组,并根据数组的id来渲染对应的图片。 首先,我们需要在Vue的data选项定义一个数组,该数组包含了多个对象,每个对象都有一个id字段和一个img字段,示例代码如下: ```javascript data() { return { images: [ { id: 1, img: 'image1.jpg' }, { id: 2, img: 'image2.jpg' }, { id: 3, img: 'image3.jpg' }, // 其他图片对象 ] } } ``` 然后,我们可以在模板使用v-for指令来遍历images数组,并通过v-bind指令将id作为key绑定到遍历的元素上,示例代码如下: ```html <template> <div> <div v-for="image in images" :key="image.id"> <img :src="image.img" alt="图片"> </div> </div> </template> ``` 在上述代码,v-for指令会遍历images数组,每次遍历会将当前元素赋值给image变量,然后使用v-bind指令将image.id作为key绑定到遍历的div元素上,这样Vue就能够正确地跟踪每个元素的身份,并在更新数组时进行优化。同时,通过使用:image.img绑定到img标签的src属性上,我们可以根据数组每个对象的img字段的值来渲染对应的图片。 这样,我们就可以根据数组的id渲染对应的图片了。当数组的id发生变化时,Vue会自动更新DOM图片元素和相关属性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值