vue3 query中文传参 需不需要解码
时间: 2024-09-18 20:04:47 浏览: 90
vue params、query传参使用详解
在Vue3中使用`query`插件处理URL查询字符串时,如果参数是中文字符,通常需要进行编码才能正确传递。JavaScript本身默认使用`encodeURIComponent()`函数对URL中的特殊字符(包括非ASCII字符)进行编码,这包括中文字符。
当你将包含中文的参数设置到URL上,例如:
```javascript
this.$router.push({
name: 'your-route',
params: {
chineseParam: '这是一个中文字符串'
}
});
```
在发送请求之前,`chineseParam`会被自动编码为`%E6%88%91%E4%B8%AA%E6%98%AF%E4%B8%80%E4%B8%AA%E4%B8%AD%E6%96%87%E5%AD%97%E5%BC%BA`的形式。
接收端接收到这个编码后的值后,需要使用`decodeURIComponent()`函数将其转换回原始的中文文本:
```javascript
let decodedChinese = decodeURIComponent(this.params.chineseParam);
```
所以,总的来说,是需要解码的,但在Vue3的`query`插件层面通常是自动处理的,但如果你手动构造URL或直接操作了参数,就需要记得手动解码。
阅读全文